(PHP >= 5.2.0)
snmp2_set — Set the value of an SNMP object
$host
, string $community
, string $object_id
, string $type
, string $value
[, string $timeout
= 1000000
[, string $retries
= 5
]] )
snmp2_set() is used to set the value of an SNMP object
specified by the object_id
.
host
The hostname of the SNMP agent (server).
community
The write community.
object_id
The SNMP object id.
type
O MIB define o tipo de cada id de objeto. Pode ser um caractere da lista abaixo.
= | Lista de MIBs id |
i | INTEGER |
u | INTEGER |
s | STRING |
x | HEX STRING |
d | DECIMAL STRING |
n | NULLOBJ |
o | OBJID |
t | TIMETICKS |
a | IPADDRESS |
b | BITS |
Se OPAQUE_SPECIAL_TYPES
foi definido durante a compilação da biblioteca SNMP, os seguintes também são válidos:
U | unsigned int64 |
I | signed int64 |
F | float |
D | double |
A maioria dos tipos tem correspondentes óbvios com tipos ASN.1. 's', 'x', 'd' e 'b' são modos diferentes de especificar um valor OCTET STRING e 'u' também é utilizado para manipular valores Gauge32.
Se MIB-Files foi carregado na árvore MIB com "snmp_read_mib" ou por especificá-lo na configuração do libsnmp, '=' pode ser utilizado
como parâmetro type
para todos os identificadores de objeto que podem ser lidos automaticamente do MIB.
Note que há duas maneiras de configurar o tipo BITS, assim: "SYNTAX BITS {telnet(0), ftp(1), http(2), icmp(3), snmp(4), ssh(5), https(6)}":
Veja a seção de exemplo para mais detalhes.
value
The new value.
timeout
The number of microseconds until the first timeout.
retries
The number of times to retry if timeouts occur.
Retorna TRUE
em caso de sucesso ou FALSE
em caso de falha.
If the SNMP host rejects the data type, an E_WARNING message like "Warning: Error in packet. Reason: (badValue) The value given has the wrong type or length." is shown. If an unknown or invalid OID is specified the warning probably reads "Could not add variable".
Exemplo #1 Using snmp2_set()
<?php
snmp2_set("localhost", "public", "IF-MIB::ifAlias.3", "s", "foo");
?>
Exemplo #2 Using snmp2_set() for setting BITS SNMP object id
<?php
snmp2_set("localhost", "public", 'FOO-MIB::bar.42', 'b', '0 1 2 3 4');
// or
snmp2_set("localhost", "public", 'FOO-MIB::bar.42', 'x', 'F0');
?>