Write setup for Zabbix agent
This commit is contained in:
parent
d56bbde138
commit
caaa97c4f9
|
@ -1,5 +1,5 @@
|
|||
package : fws-zabbix-agent
|
||||
version : 4.0.1.0-0
|
||||
version : 4.0.1-1
|
||||
architecture : all
|
||||
section : base
|
||||
priority : optional
|
||||
|
@ -7,7 +7,7 @@ maintainer : Daniel Berteaud
|
|||
description : Zabbix Agent (Zabbix SIA)
|
||||
depends :
|
||||
conflicts :
|
||||
maturity :
|
||||
maturity : DEV
|
||||
locale :
|
||||
target_os :
|
||||
min_os_version :
|
||||
|
@ -24,7 +24,7 @@ audit_schedule :
|
|||
editor :
|
||||
keywords :
|
||||
licence :
|
||||
homepage :
|
||||
homepage : https://zabbix.com
|
||||
package_uuid :
|
||||
signer :
|
||||
signer_fingerprint:
|
||||
|
|
35
setup.py
35
setup.py
|
@ -1,8 +1,39 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
from setuphelpers import *
|
||||
import json
|
||||
from cryptography.fernet import Fernet
|
||||
|
||||
uninstallkey = []
|
||||
variables = {
|
||||
'zabbix_servers': [ '127.0.0.1' ]
|
||||
}
|
||||
|
||||
# Read local variables file if available
|
||||
if isfile(makepath(programfiles32,'wapt','private','symetric.txt')) and isfile(makepath(programfiles32,'wapt','private','variables.txt')):
|
||||
print('Reading local encrypted variables file')
|
||||
f = Fernet(open(makepath(programfiles32,'wapt','private','symetric.txt'),'r').read())
|
||||
variables = json.loads(f.decrypt(open(makepath(programfiles32,'wapt','private','variables.txt'),'r').read()))
|
||||
|
||||
props = {
|
||||
'RMTCMD':0,
|
||||
'SERVER':','.join(variables['zabbix_servers'])
|
||||
}
|
||||
|
||||
def install():
|
||||
print('installing fws-zabbix-agent')
|
||||
install_msi_if_needed('zabbix_agent-4.0.1_x64.msi')
|
||||
version = control['version'].split('-',1)[0]
|
||||
print('Installing Zabbix Agent version ' + version)
|
||||
|
||||
if iswin64():
|
||||
install_msi_if_needed('zabbix_agent-%s_x64.msi' % version,killbefore=['zabbix_agentd.exe'],properties=props,remove_old_version=True)
|
||||
else:
|
||||
install_msi_if_needed('zabbix_agent-%s_x86.msi' % version,killbefore=['zabbix_agentd.exe'],properties=props,remove_old_version=True)
|
||||
|
||||
print('Opening port 10050 in the firewall')
|
||||
# Remove the previous rule if it existed. We don't mind the return code as the rule might not exist
|
||||
run_notfatal('netsh advfirewall firewall del rule name="Zabbix Agent"')
|
||||
# And add a new one
|
||||
run('netsh advfirewall firewall add rule name="Zabbix Agent" dir=in action=allow protocol=TCP localport=10050 enable=yes remoteip=%s' % (','.join(variables['zabbix_servers'])))
|
||||
|
||||
def uninstall():
|
||||
print('Removing firewall rule')
|
||||
run_notfatal('netsh advfirewall firewall del rule name="Zabbix Agent"')
|
Loading…
Reference in New Issue