diff options
Diffstat (limited to 'ext/snmp/php_snmp.h')
-rw-r--r-- | ext/snmp/php_snmp.h | 54 |
1 files changed, 52 insertions, 2 deletions
diff --git a/ext/snmp/php_snmp.h b/ext/snmp/php_snmp.h index 6b7f06d9b..bc851bc63 100644 --- a/ext/snmp/php_snmp.h +++ b/ext/snmp/php_snmp.h @@ -17,6 +17,7 @@ | Steven Lawrance <slawrance@technologist.com> | | Harrie Hazewinkel <harrie@lisanza.net> | | Johann Hanne <jonny@nurfuerspam.de> | + | Boris Lytockin <lytboris@gmail.com> | +----------------------------------------------------------------------+ */ @@ -25,6 +26,8 @@ #ifndef PHP_SNMP_H #define PHP_SNMP_H +#define PHP_SNMP_VERSION "0.1" + #if HAVE_SNMP #ifndef DLEXPORT @@ -38,6 +41,9 @@ extern zend_module_entry snmp_module_entry; #include "TSRM.h" #endif +#include <net-snmp/net-snmp-config.h> +#include <net-snmp/net-snmp-includes.h> + PHP_MINIT_FUNCTION(snmp); PHP_MSHUTDOWN_FUNCTION(snmp); PHP_MINFO_FUNCTION(snmp); @@ -46,11 +52,11 @@ PHP_FUNCTION(snmpget); PHP_FUNCTION(snmpgetnext); PHP_FUNCTION(snmpwalk); PHP_FUNCTION(snmprealwalk); +PHP_FUNCTION(snmpset); PHP_FUNCTION(snmp_get_quick_print); PHP_FUNCTION(snmp_set_quick_print); PHP_FUNCTION(snmp_set_enum_print); PHP_FUNCTION(snmp_set_oid_output_format); -PHP_FUNCTION(snmpset); PHP_FUNCTION(snmp2_get); PHP_FUNCTION(snmp2_getnext); @@ -69,9 +75,50 @@ PHP_FUNCTION(snmp_get_valueretrieval); PHP_FUNCTION(snmp_read_mib); +PHP_METHOD(SNMP, setSecurity); +PHP_METHOD(SNMP, close); +PHP_METHOD(SNMP, get); +PHP_METHOD(SNMP, getnext); +PHP_METHOD(SNMP, walk); +PHP_METHOD(SNMP, set); +PHP_METHOD(SNMP, getErrno); +PHP_METHOD(SNMP, getError); + +typedef struct _php_snmp_object { + zend_object zo; + struct snmp_session *session; + int max_oids; + int valueretrieval; + int quick_print; + int enum_print; + int oid_output_format; + int snmp_errno; + int oid_increasing_check; + int exceptions_enabled; + char snmp_errstr[256]; +} php_snmp_object; + + +typedef int (*php_snmp_read_t)(php_snmp_object *snmp_object, zval **retval TSRMLS_DC); +typedef int (*php_snmp_write_t)(php_snmp_object *snmp_object, zval *newval TSRMLS_DC); + +typedef struct _ptp_snmp_prop_handler { + const char *name; + size_t name_length; + php_snmp_read_t read_func; + php_snmp_write_t write_func; +} php_snmp_prop_handler; + +typedef struct _snmpobjarg { + char *oid; + char type; + char *value; + oid name[MAX_OID_LEN]; + size_t name_length; +} snmpobjarg; ZEND_BEGIN_MODULE_GLOBALS(snmp) - int valueretrieval; + int valueretrieval; ZEND_END_MODULE_GLOBALS(snmp) #ifdef ZTS @@ -80,6 +127,9 @@ ZEND_END_MODULE_GLOBALS(snmp) #define SNMP_G(v) (snmp_globals.v) #endif +#define REGISTER_SNMP_CLASS_CONST_LONG(const_name, value) \ + zend_declare_class_constant_long(php_snmp_ce, const_name, sizeof(const_name)-1, (long)value TSRMLS_CC); + #else #define snmp_module_ptr NULL |