PrtgAPI is a C#/PowerShell library that abstracts away the complexity of interfacing with the PRTG HTTP API.
PrtgAPI implements a collection of types, methods and cmdlets that help create and execute the API requests required to interface with PRTG. Upon executing a request, PrtgAPI will deserialize the result into an object (Sensor, Device, Probe, etc) containing type safe properties appropriate for the given data type.
Useful things you can do with PrtgAPI:
- Generate reports based on custom queries
- Monitor missing sensors (such as Veeam Backups) and missing devices (from your domain)
- Create and modify sensors, devices and groups - creating from scratch or cloning from existing ones
- Generate complex sensor factory definitions
- Deploy notification triggers to individual sensors for specific clients
- Maintain standard naming/alerting/object settings across your environment
- Pause/resume items from external systems (such as pre/post event scripts and scheduled tasks)
- Batch do anything!
For information on features that are currently in the pipeline, check out the Roadmap.
PrtgAPI also provides a secondary, optional module PrtgAPI.CustomSensors which provides a collection of wrapper functions for generating output in PRTG EXE/Script Advanced custom sensors. For more information, see PrtgAPI.CustomSensors.
Install-Package PrtgAPI
PrtgAPI is available on both nuget.org and PowerShell Gallery. Both packages are completely identical, however the nuget.org package also has corresponding symbols on symbolsource.org (for use with Visual Studio). In order to install PrtgAPI from the PowerShell Gallery you must be running PowerShell 5+.
If you have both the nuget.org and PowerShell Gallery package sources installed on your machine, you will need to specify the source you wish to install from, e.g.
Install-Package PrtgAPI -Source PSGallery
- Download the latest build
- Right click PrtgAPI.zip -> Properties
- On the General tab, under Security select Unblock
- Unzip the file
- Add a reference to PrtgAPI.dll to your project, or import the PrtgAPI module into PowerShell via
Import-Module C:\path\to\PrtgAPI
. Alternatively, you can run the included PrtgAPI.cmd file to open a prompt and import the PrtgAPI module for you.
For details on compiling PrtgAPI please see the wiki
For detailed usage instructions please see the wiki.
The following provides a general overview of some of the capabilities of PrtgAPI. For more info on each section, click the appropriate link to be taken to the corresponding wiki page.
All actions in PrtgAPI revolve around a core class: PrtgClient
var client = new PrtgClient("prtg.mycoolsite.com", "username", "password");
When a PrtgClient
is created, it will immediately attempt to retrieve your account's passhash (an alternative to using a password) from your PRTG Server. For added security, your PassHash is then used for all future PRTG Requests made during the life of your program.
For further security, you are able to pass your passhash to PrtgClient
instead of using your password. Simply extract your passhash from your client
object's PassHash
property, then tell the PrtgClient
constructor to use the passhash instead.
var client = new PrtgClient("prtg.mycoolsite.com", "username", "1234567890", AuthMode.PassHash);
Sensors, Devices, Groups, Probes and Channels can all be retrieved using their corresponding Get
methods
var devices = client.GetDevices();
Each object type contains a variety of overloads for filtering objects based on a specified set of criteria.
//List all sensors in a "down" or "down acknowledged" state.
var downSensors = client.GetSensors(Status.Down, Status.DownAcknowledged).Select(s => s.Name).ToList();
//List all devices under probes whose name contains "chicago"
var chicagoProbeDevices = client.GetDevices(Property.Probe, FilterOperator.Contains, "chicago");
//List all sensors under the Device with Object ID 2000.
var childSensors = client.GetSensors(Property.ParentId, 2000);
//Get all channels of all WMI CPU Load sensors
var sensors = client.GetSensors(Property.Tags, "wmicpuloadsensor");
var channels = sensors.Select(s => client.GetChannels(s.Id));
//Get all Ping sensors for devices whose name contains "dc" on the Perth Office probe.
var filters = new []
{
new SearchFilter(Property.Type, "ping"),
new SearchFilter(Property.Device, FilterOperator.Contains, "dc"),
new SearchFilter(Property.Probe, "Perth Office")
};
var perthDCPingSensors = client.GetSensors(filters);
PrtgAPI can manipulate objects in a variety of ways, including pausing, acknowledging and resuming, reorganizing objects as well as retrieving and modifying object properties.
//Acknowledge all down sensors for 10 minutes
var sensors = client.GetSensors(Status.Down);
foreach (var sensor in sensors)
{
client.AcknowledgeSensor(sensor.Id, 10, "Go away!");
}
//Standardize all "Ping" sensors to using the name "Ping", without the whole word capitalized
var sensors = client.GetSensors(Property.Name, "ping");
foreach (var sensor in sensors)
{
client.RenameObject(sensor.Id, "Ping");
}
//Set the upper error limit on the "Total" channel of all WMI CPU Load sensors to 90%
var sensors = client.GetSensors(Property.Tags, "wmicpuloadsensor");
var channels = sensors.SelectMany(s => client.GetChannels(s.Id, "Total"));
foreach (var channel in channels)
{
client.SetObjectProperty(channel.SensorId, channel.Id, ChannelProperty.UpperErrorLimit, 90);
}
Many operations will let you specify multiple Object IDs at once, allowing you to potentially modify thousands of objects in a single request
//Acknowledge all down sensors indefinitely via a single request.
var sensors = client.GetSensors(Status.Down);
client.AcknowledgeSensor(sensors.Select(s => s.Id).ToArray());
Objects can be cloned or created from scratch, notification triggers can be retrieved, added and modified, historical logs and data can be perused, and much much more. For a comprehensive overview of the functionality of PrtgAPI and detailed usage instructions, please see the wiki
To connect to your PRTG server, simply run
Connect-PrtgServer prtg.mycoolsite.com
You will then be prompted to enter your PRTG username and password. Your PassHash
can also be used instead of specifying your password.
If you are scripting against PrtgAPI, you can use the included New-Credential
cmdlet to bypass the authentication prompt.
Connect-PrtgServer prtg.mycoolsite.com (New-Credential prtgadmin supersecretpassword)
To avoid entering your username and password every time you use PrtgAPI, you can define GoPrtg connections in your $Profile
to automatically connect for you.
If Connect-PrtgServer
is executed outside of a script or the PowerShell ISE, PrtgAPI will by default display advanced progress details whenever two cmdlets are chained together. This can be overridden in a variety of ways.
PrtgAPI supports a wide variety of operations, each of which taking pipeline input from each other where applicable
Add-NotificationTrigger
Add-Device
Add-Group
Add-Sensor
Acknowledge-Sensor
Backup-PrtgConfig
Clear-PrtgCache
Clone-Object
Connect-GoPrtgServer
Connect-PrtgServer
Disable-PrtgProgress
Disconnect-PrtgServer
Edit-NotificationTriggerProperty
Enable-PrtgProgress
Get-Channel
Get-Device
Get-DeviceTemplate
Get-GoPrtgServer
Get-Group
Get-ModificationHistory
Get-NotificationAction
Get-NotificationTrigger
Get-Object
Get-ObjectLog
Get-ObjectProperty
Get-Probe
Get-PrtgClient
Get-PrtgSchedule
Get-PrtgStatus
Get-Sensor
Get-SensorFactorySource
Get-SensorHistory
Get-SensorTarget
Get-SensorTotals
Get-SensorType
Install-GoPrtgServer
Load-PrtgConfigFile
Move-Object
New-Credential
New-NotificationTriggerParameters
New-SearchFilter # Alias: flt
New-SensorFactoryDefinition
New-DeviceParameters
New-GroupParameters
New-SensorParameters
Open-PrtgObject
Pause-Object
Refresh-Object
Remove-NotificationTrigger
Remove-Object
Rename-Object
Restart-Probe
Restart-PrtgCore
Resume-Object
Set-ChannelProperty
Set-GoPrtgAlias
Set-ObjectPosition
Set-ObjectProperty
Set-PrtgClient
Set-NotificationTrigger
Simulate-ErrorStatus
Sort-PrtgObject
Start-AutoDiscovery
Uninstall-GoPrtgServer
Update-GoPrtgCredential
All cmdlets include complete Get-Help
documentation, including a cmdlet overview, parameter descriptions and example usages. For an overview of a cmdlet see Get-Help <cmdlet>
or Get-Help <cmdlet> -Full
for complete documentation.
Get all ping sensors
C:\> Get-Sensor ping # pipe to Format-List to view all properties!
Name Id Device Group Probe Status
---- -- ------ ----- ----- ------
PING 2010 dc1 Servers Local Probe Up
Ping 2011 dc2 Servers Local Probe Down
Ping 2012 exch1 Servers Remote Probe DownAcknowledged
Get all devices whose names contain "dc"
C:\> Get-Device *dc*
Name Id Status Host Group Probe
---- -- ------ ---- ----- -----
dc1 2001 Up 10.0.0.1 Servers Local Probe
dc2 2002 Down dc-2 Servers Local Probe
Get the channels of a sensor
C:\> Get-Sensor | Select -First 1 | Get-Channel
Name SensorId Id LastValue LimitsEnabled UpperErrorLimit LowerErrorLimit ErrorLimitMessage
---- -------- -- --------- ------------- --------------- --------------- -----------------
Total 3001 0 0.32 % True 95 PANIC!! PANIC!!!
Processor 1 3001 1 <1 % False
Inner objects know how to receive a variety of objects via the pipeline. As such it is not necessary to include every intermediate object type
Get-Probe | Get-Sensor
Delete all sensors whose device name contains "banana"
Get-Device *banana* | Get-Sensor | Remove-Object
Objects can be opened in your web browser for viewing in the PRTG Web UI
Get-Sensor -Count 2 | Open-PrtgObject
Properties/settings of objects can be retrieved and modified via the Get-ObjectProperty
and Set-ObjectProperty
cmdlets respectively. Properties will automatically set the values of any properties they depend on to be activated
# Retrieve all settings of sensor with ID 1001
Get-Sensor -Id 1001 | Get-ObjectProperty
# Set the scanning interval of the device with ID 2002. Will also set InheritInterval to $false
Get-Device -Id 2002 | Set-ObjectProperty Interval 00:00:30
Acknowledge all down sensors
# Sensors can be paused -Forever, -Until a given date, or for a specified -Duration (in minutes) with
# an optional -Message
Get-Sensor -Status Down | Acknowledge-Sensor -Until (Get-Date).AddDays(1) -Message "Hi Mom!"
Cmdlets can be chained together, in order from outer object to inner object (i.e. Probe -> Group -> Group -> Device -> Sensor -> Channel)
$sensors = Get-Probe | Select -Last 1 | Get-Group | Select -Last 2 | Get-Device | Select -First 1 | Get-Sensor
$sensors | Get-Channel perc* | Set-ChannelProperty UpperErrorLimit 100
Objects can be cloned or created from scratch, notification triggers can be retrieved, added and modified, sensor factories can be generated, and much much more. For full usage instructions on PrtgAPI please see the wiki
- Custom Deserialization
- Cmdlet Based Event Handlers
- Inter-Cmdlet Progress
- Securely Storing Credentials
- Test Startup/Shutdown
- Test Server State Restoration
- Mock WriteProgress
- Test Logging
- PowerShell Property Binding
- Dynamic PowerShell Formats
- Hybrid IQueryable / IEnumerable requests