forked from Padl3xx/Zabbix_msi_install_gpo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
install_agent2_template.ps1
79 lines (66 loc) · 3.44 KB
/
install_agent2_template.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
##This script is used to install and update zabbix agent version 2 via GPO
#
##Author: https://github.com/Padl3xx
#
##The script starts the GPO when the computer starts, it is applied to computers, not users.
##Create a new GPO, go to, Computer Configuration -> Policies -> Windows Settings -> Scripts -> Startup -> Powershell Scripts -> Add.
##Dont forget to link the GPO on specified OU :-)
##It should probably work if you run the installation directly from your computer, but I haven't tried that.
#
# Construct the FQDN (Fully Qualified Domain Name) of the local computer
$FQDN=(Get-WmiObject win32_computersystem).DNSHostName+"."+(Get-WmiObject win32_computersystem).Domain
#User-configurable variables
$ZabbixInstallationMSI = "\\yourdomain.com\NETLOGON\ZabbixAgent2\zabbix_agent2-6.0.17-windows-amd64-openssl.msi"
$ZabbixAgentVersion = "6.0.17"
$ZabbixServerIP = "8.8.8.8"
#$ZabbixInstallationFolder = "\\$FQDN\c$\Program Files\Zabbix Agent 2\"
#$ZabbixPluginFolder = "\\yourdomain.com\NETLOGON\ZabbixAgent2\zabbix_agent2.d\"
#$ZabbixScriptsFolder = "\\yourdomain.com\NETLOGON\ZabbixAgent2\scripts"
# Be careful what you change here
$ZabbixSoftwareName = "Zabbix Agent 2 (64-bit)"
$InstalledZabbixVersion = (Get-WmiObject -Class Win32_Product | Where-Object { $_.Name -eq $ZabbixSoftwareName }).Version
# Extract the major version from the installed version
$InstalledVersion = $InstalledZabbixVersion -replace "(\d+\.\d+\.\d+).*", '$1'
$Arguments = "SERVER=$ZabbixServerIP SERVERACTIVE=$ZabbixServerIP HOSTMETADATA=Windows HOSTNAME=$FQDN /qn"
if ($InstalledVersion -lt $ZabbixAgentVersion) {
# The installed version is different from the desired version, so perform the installation or update
if (Test-Path $ZabbixInstallationMSI) {
# The installation file is available, so start the installation process
Start-Process -FilePath "$ZabbixInstallationMSI" -ArgumentList "$Arguments" -Wait
#Copy-Item -Path @($ZabbixPluginFolder, $ZabbixScriptsFolder) -Destination $ZabbixInstallationFolder -Force -Recurse
} else {
# The installation file is not available, exit the script
exit
}
}
## Function to update plugin and scripts folders if changes are detected
#if (!(Test-Path -Path "$ZabbixInstallationFolder\zabbix_agent2.d" -PathType Container)) {
##if not exist, folder is created
# New-Item -ItemType Directory -Path "$ZabbixInstallationFolder\zabbix_agent2.d" -Force
#}
#
#if (!(Test-Path -Path "$ZabbixInstallationFolder\scripts" -PathType Container)) {
##if not exist, folder is created
# New-Item -ItemType Directory -Path "$ZabbixInstallationFolder\scripts" -Force
#}
#
## Function to synchronize files of specified folders
#function Sync-Folder {
# param(
# [string]$sourceFolder,
# [string]$destinationFolder
# )
#
# $sourceFiles = Get-ChildItem -Path $sourceFolder -File
# foreach ($file in $sourceFiles) {
# $destinationFile = Join-Path -Path $destinationFolder -ChildPath $file.Name
# if (!(Test-Path -Path $destinationFile -PathType Leaf)) {
# #sync
# Copy-Item -Path $file.FullName -Destination $destinationFolder
# }
# }
#}
#
## Sync files from given folders
#Sync-Folder -sourceFolder $ZabbixPluginFolder -destinationFolder "$ZabbixInstallationFolder\zabbix_agent2.d\"
#Sync-Folder -sourceFolder $ZabbixScriptsFolder -destinationFolder "$ZabbixInstallationFolder\scripts\"