[RESOLU]Cisco Immunet antivirus

Questions about WAPT Packaging / Requêtes et aides autour des paquets Wapt.
Règles du forum
Règles du forum communautaire
* English support on www.reddit.com/r/wapt
* Le support communautaire en français se fait sur ce forum
* Merci de préfixer le titre du topic par [RESOLU] s'il est résolu.
* Merci de ne pas modifier un topic qui est taggé [RESOLU]. Ouvrez un nouveau topic en référençant l'ancien
* Préciser version de WAPT installée, version complète ET numéro de build (2.2.1.11957 / 2.2.2.12337 / etc.) AINSI QUE l'édition Enterprise / Discovery
* Les versions 1.8.2 et antérieures ne sont plus maintenues. Les seules questions acceptées vis à vis de la version 1.8.2 sont liés à la mise à jour vers une version supportée (2.1, 2.2, etc.)
* Préciser OS du serveur (Linux / Windows) et version (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019)
* Préciser OS de la machine d'administration/création des paquets et de la machine avec l'agent qui pose problème le cas échéant (Windows 7 / 10 / 11 / Debian 11 / etc.)
* Eviter de poser plusieurs questions lors de l'ouverture de topic, sinon il risque d'être ignorer. Si plusieurs sujet, ouvrir plusieurs topic, et de préférence les uns après les autres et pas tous en même temps (ie ne pas spammer le forum).
* Inclure directement les morceaux de code, les captures d'écran et autres images directement dans le post. Les liens vers les pastebin, les bitly et autres sites tierces seront systématiquement supprimés.
* Comme tout forum communautaire, le support est fait bénévolement par les membres. Si vous avez besoin d'un support commercial, vous pouvez contacter le service commercial Tranquil IT au 02.40.97.57.55
nliaudat
Messages : 29
Inscription : 08 août 2019 - 08:31

23 oct. 2019 - 16:09

Working sample to deploy and add exclusions for free Immunet antivirus

setup.py

Code : Tout sélectionner

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

uninstallkey = []

config_path = makepath(programfiles,'Immunet','local.xml')

def install():
    print('installing %s' % control.asrequirement())


    install_exe_if_needed("ImmunetSetup.exe",'/S',key='',min_version='7.0.0',accept_returncodes=[0,1638])



def uninstall():
    print('uninstalling %s' % control.asrequirement())
    #not a silent uninstaller => manual command
    run(r'"C:\Program Files\Immunet\7.0.0\uninstall.exe" /S /remove 1')

def session_setup():
    print('Session setup for %s' % control.asrequirement())

    #can be run under session setup cause user has permission to write
    update_config()


def update_package():
    print('Update package content from upstream binary sources')


def audit():
    print('Auditing %s' % control.asrequirement())



def update_config():

    import xml.etree.ElementTree as etree

    config = etree.parse(config_path)

    '''
<config>
  <exclusions>
   <info>
    <item>256|3|0|1|.dwg</item>
    <item>256|3|0|1|.dxf</item>
    <item>256|2|1|0|C:\Program Files (x86)\wapt\</item>
    <item>256|2|1|0|C:\powerplan</item>
    <item>256|1|0|0|toolbox.exe</item>
   </info>
  </exclusions>
  '''
    exclusions = config.find('exclusions/info')


    items = []

    dwg = dxf = wapt = need_write = False

    for item in exclusions.iter():
        #list all items
        if item.text:
            if len(item.text.split()) > 0:
                items.append(item.text)
        if item.text.find('.dwg') > 0: #dwg is found
            dwg = True
        if item.text.find('.dxf') > 0:
            dxf = True
        if item.text.find('wapt') > 0:
            wapt = True


    #print(items)

    if dwg == False :
        dwg = etree.SubElement(exclusions, 'item')
        dwg.text = '256|3|0|1|.dwg'
        print('add .dwg exclusion')
        need_write = True

    if dxf == False :
        dxf = etree.SubElement(exclusions, 'item')
        dxf.text = '256|3|0|1|.dxf'
        print('add .dxf exclusion')
        need_write = True

    if wapt == False :
        wapt = etree.SubElement(exclusions, 'item')
        wapt.text = '256|2|1|0|C:\\Program Files (x86)\\wapt\\'
        print('add wapt exclusion')
        need_write = True

    if need_write == True:
        config.write(config_path)


    '''
<scansettings>
    <clamav>
     <options>
      <ondemand>
       <scanarchives>1</scanarchives>
       <scanpacked>1</scanpacked>
      </ondemand>
     </options>
    </clamav>
    <tetra>
     <options>
      <ondemand>
       <scanarchives>1</scanarchives>
       <scanpacked>1</scanpacked>
      </ondemand>
     </options>
    </tetra>
   </scansettings>

  '''

Verrouillé