Página 1 de 1

Paquetes para Spark

Publicado: 8 de febrero de 2021 - 11:39 a. m.
por fred-gie
Hola, soy nuevo en WAPT y Python.

Utilizo el cliente de mensajería instantánea Spark en mi empresa y me gustaría implementar Spark mediante WAPT.
He creado el paquete para la versión 2.9.4, instalación y desinstalación que funciona muy bien.
También me gustaría copiar un archivo de configuración en "user_appdata".
Y ahí es donde necesito una mano amiga.

Me gustaría verificar que la carpeta Spark exista en la carpeta Roaming del usuario.
Si es así, copiaré mi archivo allí.
Si no, creo la carpeta Spark y copio mi archivo en ella.

Aquí están las líneas de código que creé, pero no funciona, algo debe faltar, pero no puedo ver qué.

Código: Seleccionar todo

def session_setup():
    user_config_dir = makepath(user_appdata(),'Spark')
    Spark_Config = 'spark.properties'

     if not isdir(user_config_dir):
        mkdirs(user_config_dir)
        filecopyto (Spark_Config,user_config_dir)
    if isdir(user_config_dir):
        filecopyto (Spark_Config,user_config_dir)
Gracias de antemano por su ayuda.

Versión del servidor WAPT: 1.8.2
Versión del agente WAPT: 1.8.2.7334
Versión de configuración de WAPT: 1.8.2.7334
Versión de implementación de WAPT: 1.8.2.7334

Re: Paquetes para Spark

Publicado: 11 de febrero de 2021 - 13:45
por dcardon
El código Python es correcto, pero debe tenerse en cuenta el contexto de ejecución. Al ejecutar `session_setup()`, el paquete ya está instalado y los archivos ya no están disponibles en el contexto de ejecución. Deben copiarse a una ubicación en el equipo (por ejemplo, el directorio Spark en Archivos de Programa o el directorio persistente de WAPT) para recuperarlos al ejecutar `session_setup()`.

Re: Paquetes para Spark

Publicado: 12 de febrero de 2021 - 14:52
por fred-gie
Hola y gracias por tu respuesta.
Modifiqué mi script y ahora funciona si ejecuto "session-setup" desde pyscripter, pero no con WAPTConsole.
Tengo la impresión de que no ejecuta la sección "session_setup" durante la instalación.

Aquí está el guión si tienes alguna idea.

Código: Seleccionar todo

from setuphelpers import *

uninstallkey = []

def install():
    def vers_spark(key):
        return key['name'].replace('Spark','')
    install_exe_if_needed("spark_2_9_4-with-jre.exe",silentflags='-q',key='3057-7228-2063-7466',min_version='2.9.4',killbefore=['spark.exe'],get_version=vers_spark)
    uninstallkey.remove('3057-7228-2063-7466')

    #Copie du fichier config dans dossier d'install:
    Cpy_conf = makepath(programfiles32,'Spark')

    isdir(Cpy_conf)
    filecopyto ('spark.properties',Cpy_conf)
    copytree2 ('PHX-32.adiumemoticonset',makepath(programfiles32,'Spark','PHX-32.adiumemoticonset'))

def uninstall():
    run('"%s" -q' % makepath(programfiles32,'Spark','uninstall.exe'))


def session_setup():

    user_config_dir = makepath(user_appdata(),'Spark')
    Spark_Config = 'spark.properties'
    #Creation répertoire dans roaming et copie du fichiers config.
    if not isdir(user_config_dir):
        mkdirs(user_config_dir)
        filecopyto (Spark_Config,user_config_dir)
        copytree2 ('PHX-32.adiumemoticonset',makepath(user_appdata(),'Spark','xtra','emoticons','PHX-32.adiumemoticonset'))
    if isdir(user_config_dir):
        filecopyto (Spark_Config,user_config_dir)
        copytree2 ('PHX-32.adiumemoticonset',makepath(user_appdata(),'Spark','xtra','emoticons','PHX-32.adiumemoticonset'))

GRACIAS

Re: Paquetes para Spark

Publicado: 17 de febrero de 2021 - 11:32 a. m.
por fred-gie
Hola,

tengo problemas para ejecutar la sección `def session_setup()`.
Funciona cuando la pruebo en PyScripter, pero no sucede nada durante la instalación.
código de `session_setup`en la `install` , funciona.
¿Se requiere algún argumento para forzar la ejecución de esta sección?

Gracias de antemano por su ayuda.

Versión de WAPT Server Debian: 1.8.2
Versión de WAPT Agent: 1.8.2.7334
Versión de WAPT Setup: 1.8.2.7334
Versión de WAPT Deploy: 1.8.2.7334

Re: Paquetes para Spark

Publicado: 18 de febrero de 2021 - 10:49 a. m.
por dcardon
La función session_setup() se inicia mediante el comando wapt-get.exe session_setup ALL en la sesión del usuario.
En una instalación estándar del agente WAPT, el comando wapt-get.exe session_setup ALL se ejecuta de forma predeterminada.

Re: Paquetes para Spark

Publicado: 19 de febrero de 2021 - 12:39 p. m.
por fred-gie
Hola y gracias por tu respuesta.

Reescribí el guión varias veces, pero desafortunadamente no todo funciona.

- Instalar la aplicación, desinstalarla, crear una carpeta temporal en el directorio de instalación y copiar archivos y carpetas en la carpeta temporal funcionan.

Código: Seleccionar todo

# -*- coding: utf-8 -*-
from setuphelpers import *

uninstallkey = []

def install():
    def vers_spark(key):
        return key['name'].replace('Spark','')
    install_exe_if_needed("spark_2_9_4-with-jre.exe",silentflags='-q',key='3057-7228-2063-7466',min_version='2.9.4',killbefore=['spark.exe'],get_version=vers_spark)
    uninstallkey.remove('3057-7228-2063-7466')

    #Creation du dossier tmp et copie du fichier config et répertoire smilley.
    isdir(makepath(programfiles32,'Spark'))
    mkdirs (makepath(programfiles32,'Spark','tmp'))
    filecopyto ('spark.properties', makepath(programfiles32,'Spark','tmp'))
    copytree2 ('xtra', makepath(programfiles32,'Spark','tmp','xtra'))
    if not isdir(makepath(user_appdata,'Spark')):
        mkdirs(makepath(user_appdata,'Spark'))
        filecopyto (makepath(programfiles32,'Spark','tmp','spark.properties'),makepath(user_appdata,'Spark'))
        copytree2 (makepath(programfiles32,'Spark','tmp'),makepath(user_appdata,'Spark'))
    if isdir(makepath(user_appdata,'Spark')):
        filecopyto (makepath(programfiles32,'Spark','tmp','spark.properties'),makepath(user_appdata,'Spark'))
        copytree2 (makepath(programfiles32,'Spark','tmp'),makepath(user_appdata,'Spark'))
    
 def uninstall():
    run('"%s" -q' % makepath(programfiles32,'Spark','uninstall.exe'))
Mover el contenido de la carpeta tmp a user_appdata funciona localmente "en mi PC" a través de PyScripter, pero no funciona con el agente en la máquina de destino.
Modifiqué el archivo wapt-get.ini en la PC en cuestión y configuré loglevel=debug, pero no tengo más información sobre cómo funciona.
Las partes "si no" y "si" no son procesadas por el agente, independientemente de su posición en el script "def install():" o "def session():".
¿Es un problema del agente o del guión?

Re: Paquetes para Spark

Publicado: 9 de marzo de 2021 - 11:37
por fred-gie
Funciona, pero no es instantáneo.
Tengo la impresión de que la instalación se realiza en varias etapas, e incluso puede que finalice después de reiniciar el ordenador.