Paquetes para Spark

Preguntas sobre paquetes WAPT / Solicitudes y ayuda sobre paquetes WAPT.
Reglas del foro
Reglas del foro de la comunidad
* Soporte en inglés en www.reddit.com/r/wapt
* El soporte de la comunidad en francés está disponible en este foro
* Por favor, anteponga [RESUELTO] al título del tema si está resuelto.
* Por favor, no edite un tema que esté etiquetado como [RESUELTO]. Abra un nuevo tema haciendo referencia al anterior.
* Especifique la versión de WAPT instalada, la versión completa y el número de compilación (2.2.1.11957 / 2.2.2.12337 / etc.), así como la edición Enterprise/Discovery.
* Las versiones 1.8.2 y anteriores ya no son compatibles. Las únicas preguntas aceptadas sobre la versión 1.8.2 están relacionadas con la actualización a una versión compatible (2.1, 2.2, etc.).
* Especifique el sistema operativo del servidor (Linux/Windows) y la versión (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019).
* Especifique el sistema operativo de la máquina de administración/creación de paquetes y de la máquina con el agente problemático, si corresponde (Windows 7/10/11/Debian 11/etc.).
* Evite hacer varias preguntas al abrir un tema, ya que podría ser ignorado. Si hay varios temas, ábralos por separado, preferiblemente uno tras otro y no todos a la vez (es decir, no sature el foro con spam).
* Incluya fragmentos de código, capturas de pantalla y otras imágenes directamente en la publicación. Los enlaces a Pastebin, Bitly y otros sitios de terceros serán eliminados sistemáticamente.
* Como en cualquier foro comunitario, el soporte es proporcionado voluntariamente por los miembros. Si necesita soporte comercial, puede comunicarse con el departamento de ventas de Tranquil IT al 02.40.97.57.55.
Bloqueado
Fred-Gie
Mensajes: 5
Inscripción: 5 de febrero de 2021 - 17:20

8 de febrero de 2021 - 11:39

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
Avatar de usuario
dcardón
Experto en WAPT
Mensajes: 1908
Inscripción: 18 de junio de 2014 - 09:58
Ubicación: Saint Sébastien sur Loire
Contacto :

11 de febrero de 2021 - 13:45

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()`.
Denis Cardon - Tranquil IT
¡Comparte tus experiencias en WAPT! Envíanos las URL de tus blogs y artículos en la "Tu opinión del foro y los publicaremos en el de WAPT
Fred-Gie
Mensajes: 5
Inscripción: 5 de febrero de 2021 - 17:20

12 de febrero de 2021 - 14:52

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
Fred-Gie
Mensajes: 5
Inscripción: 5 de febrero de 2021 - 17:20

17 de febrero de 2021 - 11:32

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
Avatar de usuario
dcardón
Experto en WAPT
Mensajes: 1908
Inscripción: 18 de junio de 2014 - 09:58
Ubicación: Saint Sébastien sur Loire
Contacto :

18 de febrero de 2021 - 10:49

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.
Denis Cardon - Tranquil IT
¡Comparte tus experiencias en WAPT! Envíanos las URL de tus blogs y artículos en la "Tu opinión del foro y los publicaremos en el de WAPT
Fred-Gie
Mensajes: 5
Inscripción: 5 de febrero de 2021 - 17:20

19 de febrero de 2021 - 12:39

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?
Fred-Gie
Mensajes: 5
Inscripción: 5 de febrero de 2021 - 17:20

9 de marzo de 2021 - 11:37

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.
Bloqueado