object script.execute(object parameters)
Aquest mètode permet executar un script a un equip o esdeveniment; excepte per scripts de tipus URL, que aquests no són pas executables.
Aquest mètode és disponible per a qualsevol mena d'usuaris. Els permisos per cridar al mètode es poden revocar a la configuració de rols d'usuaris. Per a més informació, veieu Rols d'usuari.
(object)
Paràmetres que contenen l'ID de l'script a executar i l'ID de l'equip o l'ID de l'esdeveniment.
Paràmetre | Tipus | Descripció |
---|---|---|
scriptid | ID | ID de l'script a executar. Comportament de la propietat: - obligatori |
hostid | ID | ID de l'equip on executar l'script. Comportament de la propietat: - obligatori si no s'ha definit eventid |
eventid | ID | ID de l'esdeveniment on executar l'script. Comportament de la propietat: - obligatori si no s'ha definit pas hostid |
manualinput | string | Valor entrat per l'usuari per on executar l'script, subsituïnt la macro {MANUALINPUT}. |
(object)
Retorna el resultat de l'execució de l'script.
Propietat | Tipus | Descripció |
---|---|---|
response | string | Indica si l'script s'ha executat correctament. Valor possible: success . |
value | string | Sortida de l'script. |
debug | object | Conté un objecte de depuració si s'executa un script webhook. Per a altres tipus d'script, conté un objecte buit. |
Executa un script webhook que envia una petició HTTP a un servei extern.
{
"jsonrpc": "2.0",
"method": "script.execute",
"params": {
"scriptid": "4",
"hostid": "30079"
},
"id": 1
}
Resposta:
{
"jsonrpc": "2.0",
"result": {
"response": "success",
"value": "{\"status\":\"sent\",\"timestamp\":\"1611235391\"}",
"debug": {
"logs": [
{
"level": 3,
"ms": 480,
"message": "[Webhook Script] HTTP status: 200."
}
],
"ms": 495
}
},
"id": 1
}
Executar un script "ping" sobre un equip.
{
"jsonrpc": "2.0",
"method": "script.execute",
"params": {
"scriptid": "1",
"hostid": "30079"
},
"id": 1
}
Resposta:
{
"jsonrpc": "2.0",
"result": {
"response": "success",
"value": "PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.\n64 bytes from 127.0.0.1: icmp_req=1 ttl=64 time=0.074 ms\n64 bytes from 127.0.0.1: icmp_req=2 ttl=64 time=0.030 ms\n64 bytes from 127.0.0.1: icmp_req=3 ttl=64 time=0.030 ms\n\n--- 127.0.0.1 ping statistics ---\n3 packets transmitted, 3 received, 0% packet loss, time 1998ms\nrtt min/avg/max/mdev = 0.030/0.044/0.074/0.022 ms\n",
"debug": []
},
"id": 1
}
Executa un script "ping" amb l'ordre "ping -c {MANUALINPUT} {HOST.CONN}; caes $? in [01]) true;; *) false;; esac" a un equip.
{
"jsonrpc": "2.0",
"method": "script.execute",
"params": {
"scriptid": "7",
"hostid": "30079",
"manualinput": "2"
},
"id": 1
}
Resposta:
{
"jsonrpc": "2.0",
"result": {
"response": "success",
"value": "PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.\n64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.051 ms\n64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.025 ms\n\n--- 127.0.0.1 ping statistics ---\n2 packets transmitted, 2 received, 0% packet loss, time 1021ms\nrtt min/avg/max/mdev = 0.025/0.038/0.051/0.013 ms",
"debug": []
},
"id": 1
}
CScript::execute() in ui/include/classes/api/services/CScript.php.