Página 2 de 2

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 20 de julio de 2018 - 10:27
por sfonteneau
Debes colocar tu script en la carpeta de instalación de wapt.

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 20 de julio de 2018 - 10:49 a. m.
por louisinger
Bueno, es un archivo .pyd, fue mi error, gracias

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 20 de julio de 2018 - 13:48
por sfonteneau
No dudes en publicar tu guion una vez que lo hayas terminado.

¡Contribuirás a la comunidad de Wapt!

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 20 de julio de 2018 - 15:39
por louisinger
Aquí está mi código, anonimizado y con los máximos comentarios posibles. Espero que te sirva.

Código: Seleccionar todo

def isGroup(myPackage):
    """
        Renvoie True si le paquet est un paquet groupe de l'AD.
        :param myPackage: nom du paquet à tester.
        :return boolean: True si myPackage appartient à groupPackages, False si non.
        :exemple:
            > isGroup('lot1')
            True
            > isGroup('tis-java8')
            False
    """
    groupPackages = {'lot1','lot2','lot3','lot4'}
    for group in groupPackages:
        if group == myPackage:
            return True
    return False


def haveGroup(depends):
    """
        Renvoie true si la ligne de dépendance en paramètre contient un des groupes.
        :param depends: ligne de dépendance au format "dependance1,dependance2,..."
        :return boolean: True si il y a un groupe False si non.
        :exemple:
            > haveGroup('tis-chrome, tis-microsoft-office, lot1')
            True
            > haveGroup('tis-chrome')
            False
    """
    if not depends :
        return False
    else :
        packages = depends.split(',')
        for p in packages:
            if isGroup(p):
                return True
        return False


def main(get_group):
    """
        Repartie les clients WAPT dans différents groupes (groupes AD).    
        :param get_group: fonction qui renvoie le nom du package group
    """
	# const
    USER = 'admin'
    URL_SERVER = '**********'
    RESULT_LIMIT = 1500
    TEMP_DIR_ROOT = 'c:/temp/*******'
    PATH_TO_CONFIGFILE = r'C:/Users/administrateur/AppData/Local/waptconsole/waptconsole.ini'
    FORCE = False

    remove_tree(TEMP_DIR_ROOT)
    myWapt = Wapt(config_filename = PATH_TO_CONFIGFILE)
    
    mycrt = r"****************"
    credentials_url = waptguihelper.login_password_dialog('admin loggin', URL_SERVER, USER, '')
    passwd_private_key = waptguihelper.key_password_dialog('Password for private key',mycrt, '')

    USER = credentials_url['user']
    PASSWORD = credentials_url['password']
    PASSWORD_KEY = passwd_private_key['keypassword']
    data = json.loads(wgets('https://%s:%s@%s/api/v1/hosts?limit=%s' % (USER, PASSWORD, URL_SERVER, RESULT_LIMIT)))
    uuid, depends, fqdn, tmpdir = '','','',''
    
    if FORCE:
            print("Force : True")
    
    for value in data['result']:    
        uuid = value.get('uuid')
        depends = value.get('depends')
        fqdn = value.get('computer_fqdn')
        if not haveGroup(depends) or FORCE:
            group_name = get_group(fqdn)
            tmpdir = makepath(TEMP_DIR_ROOT, uuid)
            myWapt.edit_host(uuid, target_directory = tmpdir, append_depends = group_name)
            myWapt.build_upload(r'%s'%tmpdir, private_key_passwd = PASSWORD_KEY, wapt_server_user = USER, wapt_server_passwd = PASSWORD)
            print("%s (%s) ---> %s"%(uuid,fqdn,group_name))

                
if __name__ == "__main__":
    main(get_group = mafonctiongetGroup)

PD: Eso definitivamente merece algunas pegatinas de Tranquil IT, ¿no crees?

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 23 de julio de 2018 - 09:47
por sfonteneau
¿No desea proporcionar la versión anónima de la función mafonctiongetGroup? :rollo:

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 23 de julio de 2018 - 13:09
por louisinger
Es una función específica de cada organización, e incluso anónima, dudo que tenga sentido proporcionarla. Pero veré qué puedo hacer ;)

Re: [RESUELTO] Cómo cifrar tus contraseñas de Wapt

Publicado: 23 de julio de 2018 - 13:47
por louisinger
Aquí está getGroup:
Suponiendo que los títulos de los puestos estén en el formato: X000Y100.organisation.fr
donde X000 es la referencia del sitio.

Código: Seleccionar todo

def toSiteName(computer_fqdn):
    """
        Renvoie le nom du site en fonction du host name.
        :param computer_fqdn: full hostname d'un poste client.
        :return string: nom du site en majuscule
    """
    host = computer_fqdn.split('.')[0][0:4]
    return host.upper()

def getGroup(fqdn):
    """
        Renvoie le groupe en fonction du nom de l'hote
    """
    site_name = toSiteName(fqdn)
    group_name = alias_groupe.get(switcher.get(site_name, 0), 'hors-lot')
    return group_name
Alias_groupe tiene el formato:

Código: Seleccionar todo

alias_groupe = {
    0:'hors-lot'
    1:'lot1',
    2:'lot2',
    3:'lot3'
}
y el conmutador que permite cambiar entre sitios y grupos:

Código: Seleccionar todo

switcher = {
    'X000':1
    'X001':2
    'X002':1
    'Y010':3
}
Aquí lo tienes, es simple y simplista, pero ahorra una gran cantidad de tiempo a la hora de clasificar las máquinas.