pandorafms/pandora_server/extras/pandoraPlugintools/README.md

86 lines
2.1 KiB
Markdown
Raw Normal View History

2023-07-26 15:28:44 +02:00
# Python: module plugintools for PandoraFMS Developers
pandoraPluginTools is a library that aims to help the creation of scripts and their integration in Pandora FMS.
2023-07-26 15:28:44 +02:00
[PluginTools Reference Documentation](https://pandorafms.com/guides/public/books/plugintools)
The package includes the following modules. Each one has different functions that facilitate and automate the data integration in Pandora FMS:
**general**
Module containing general purpose functions, useful in the creation of plugins for PandoraFMS
**threads**
Module containing threading purpose functions, useful to run parallel functions.
2023-07-26 15:28:44 +02:00
**agents**
Module that contains functions oriented to the creation of Pandora FMS agents
2023-07-26 15:28:44 +02:00
**modules**
Module that contains functions oriented to the creation of Pandora FMS modules.
2023-07-26 15:28:44 +02:00
**transfer**
Module containing functions oriented to file transfer and data sending to Pandora FMS server
2023-07-26 15:28:44 +02:00
**discovery**
Module containing functions oriented to the creation of Pandora FMS discovery plugins
2023-07-26 15:28:44 +02:00
**http**
Module containing functions oriented to HTTP API calls
2023-07-26 15:28:44 +02:00
## Example
``` python
import pandoraPluginTools as ppt
## Define agent
server_name = "WIN-SERV"
2023-07-28 09:52:16 +02:00
agent=ppt.init_agent({
"agent_name" : ppt.generate_md5(server_name),
"agent_alias" : server_name,
"description" : "Default Windows server"
})
2023-07-26 15:28:44 +02:00
## Define modules
modules=[]
data = 10
modules.append({
"name" : "CPU usage",
"type" : "generic_data",
"value": data,
2023-07-28 10:00:40 +02:00
"desc" : "Percentage of CPU utilization",
2023-07-26 15:28:44 +02:00
"unit" : "%"
})
2023-07-28 09:59:28 +02:00
## Generate and transfer XML
xml_content = ppt.print_agent(agent, modules)
xml_file = ppt.write_xml(xml_content, agent["agent_name"])
2023-07-26 15:28:44 +02:00
ppt.transfer_xml(
2023-07-28 09:59:28 +02:00
xml_file,
2023-07-26 15:28:44 +02:00
transfer_mode="tentacle",
tentacle_address="192.168.1.20",
tentacle_port="41121",
temporal="/tmp"
)
```
The package has the following dependencies:
- Hashlib
- datetime.datetime
- hashlib
- json
- os
- print_agent
- print_log_module
- print_module
- queue.Queue
- requests.auth.HTTPBasicAuth
- requests.auth.HTTPDigestAuth
- requests.sessions.Session
- requests_ntlm.HttpNtlmAuth
- shutil
- subprocess.Popen
- sys
- threading.Thread