#include <snmp/snmp.h>short build_authentication(AuthHeader auth_ptr, PDU pdu_ptr);
void free_authentication(AuthHeader auth_ptr);
AuthHeader make_authentication(OctetString community_ptr);
AuthHeader parse_authentication(unsigned char packet, long packet_len);
#include <snmp/snmp.h> #include <snmp/snmpuser.h>
void print_packet_out(unsigned char packet, long length);
free_authentication frees all memory associated with a trivial authentication header data structure, including the actual SNMP packet that build_authentication creates and the octet string associated with make_authentication. The PDU structure pointed to by the pdu_ptr passed to make-authentication is not touched.
make_authentication is used to create a library format authentication header data structure for use by build_authentication. This particular implementation of the library creates an authentication header based on the trivial authentication put forth by RFC 1098, which calls for a community octet string usually based on text. The header and the octet string associated with the header are freed when free_authentication is called with the authentication pointer. community_ptr is usually made by make_octet_from_text(3snmp).
parse_authentication is used to create a library format
authentication header data structure from an incoming SNMP
packet (identified by packet, and of length packet_len).
If parsing errors occur, a message is output to standard error and the
routine returns NULL. Otherwise, the community_ptr
part of the structure should be checked for authentication and the pointer
passed on to
parse_pdu(3snmp)
for further ASN.1 parsing. It should be noted that the state of
the authentication header created during the building phase after a call
to build_authentication is nearly symmetrical to the state of
the authentication header after this call on the parsing side.
print_packet_out prints out the contents of a buffer, in hex at 20 bytes per line. It is called with a pointer to the buffer to be displayed and the number of buffer bytes to be displayed. This call is frequently used in debugging code to display the actual SNMP message that has been received; this allows hand parsing of the message. It is generally unsuitable for a production user interface.