⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ipaddressprefixtable_interface.c

📁 开发snmp的开发包有两个开放的SNMP开发库
💻 C
📖 第 1 页 / 共 3 页
字号:
 * @internal * Retrieve the value for a particular column */NETSNMP_STATIC_INLINE int_ipAddressPrefixTable_get_column(ipAddressPrefixTable_rowreq_ctx *                                 rowreq_ctx, netsnmp_variable_list * var,                                 int column){    int             rc = SNMPERR_SUCCESS;    DEBUGMSGTL(("internal:ipAddressPrefixTable:_mfd_ipAddressPrefixTable_get_column", "called for %d\n", column));    netsnmp_assert(NULL != rowreq_ctx);    switch (column) {        /*         * ipAddressPrefixOrigin(5)/IpAddressPrefixOriginTC/ASN_INTEGER/long(u_long)//l/A/w/E/r/d/h          */    case COLUMN_IPADDRESSPREFIXORIGIN:        var->val_len = sizeof(u_long);        var->type = ASN_INTEGER;        rc = ipAddressPrefixOrigin_get(rowreq_ctx,                                       (u_long *) var->val.string);        break;        /*         * ipAddressPrefixOnLinkFlag(6)/TruthValue/ASN_INTEGER/long(u_long)//l/A/w/E/r/d/h          */    case COLUMN_IPADDRESSPREFIXONLINKFLAG:        var->val_len = sizeof(u_long);        var->type = ASN_INTEGER;        rc = ipAddressPrefixOnLinkFlag_get(rowreq_ctx,                                           (u_long *) var->val.string);        break;        /*         * ipAddressPrefixAutonomousFlag(7)/TruthValue/ASN_INTEGER/long(u_long)//l/A/w/E/r/d/h          */    case COLUMN_IPADDRESSPREFIXAUTONOMOUSFLAG:        var->val_len = sizeof(u_long);        var->type = ASN_INTEGER;        rc = ipAddressPrefixAutonomousFlag_get(rowreq_ctx,                                               (u_long *) var->val.string);        break;        /*         * ipAddressPrefixAdvPreferredLifetime(8)/UNSIGNED32/ASN_UNSIGNED/u_long(u_long)//l/A/w/e/r/d/h          */    case COLUMN_IPADDRESSPREFIXADVPREFERREDLIFETIME:        var->val_len = sizeof(u_long);        var->type = ASN_UNSIGNED;        rc = ipAddressPrefixAdvPreferredLifetime_get(rowreq_ctx,                                                     (u_long *) var->val.                                                     string);        break;        /*         * ipAddressPrefixAdvValidLifetime(9)/UNSIGNED32/ASN_UNSIGNED/u_long(u_long)//l/A/w/e/r/d/h          */    case COLUMN_IPADDRESSPREFIXADVVALIDLIFETIME:        var->val_len = sizeof(u_long);        var->type = ASN_UNSIGNED;        rc = ipAddressPrefixAdvValidLifetime_get(rowreq_ctx,                                                 (u_long *) var->val.                                                 string);        break;    default:        snmp_log(LOG_ERR,                 "unknown column %d in _ipAddressPrefixTable_get_column\n",                 column);        break;    }    return rc;}                               /* _ipAddressPrefixTable_get_column */int_mfd_ipAddressPrefixTable_get_values(netsnmp_mib_handler *handler,                                     netsnmp_handler_registration *reginfo,                                     netsnmp_agent_request_info                                     *agtreq_info,                                     netsnmp_request_info *requests){    ipAddressPrefixTable_rowreq_ctx *rowreq_ctx =        netsnmp_container_table_row_extract(requests);    netsnmp_table_request_info *tri;    u_char         *old_string;    void            (*dataFreeHook) (void *);    int             rc;    DEBUGMSGTL(("internal:ipAddressPrefixTable:_mfd_ipAddressPrefixTable_get_values", "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    for (; requests; requests = requests->next) {        /*         * save old pointer, so we can free it if replaced         */        old_string = requests->requestvb->val.string;        dataFreeHook = requests->requestvb->dataFreeHook;        if (NULL == requests->requestvb->val.string) {            requests->requestvb->val.string = requests->requestvb->buf;            requests->requestvb->val_len =                sizeof(requests->requestvb->buf);        } else if (requests->requestvb->buf ==                   requests->requestvb->val.string) {            if (requests->requestvb->val_len !=                sizeof(requests->requestvb->buf))                requests->requestvb->val_len =                    sizeof(requests->requestvb->buf);        }        /*         * get column data         */        tri = netsnmp_extract_table_info(requests);        if (NULL == tri)            continue;        rc = _ipAddressPrefixTable_get_column(rowreq_ctx,                                              requests->requestvb,                                              tri->colnum);        if (rc) {            if (MFD_SKIP == rc) {                requests->requestvb->type = SNMP_NOSUCHINSTANCE;                rc = SNMP_ERR_NOERROR;            }        } else if (NULL == requests->requestvb->val.string) {            snmp_log(LOG_ERR, "NULL varbind data pointer!\n");            rc = SNMP_ERR_GENERR;        }        if (rc)            netsnmp_request_set_error(requests, SNMP_VALIDATE_ERR(rc));        /*         * if the buffer wasn't used previously for the old data (i.e. it         * was allcoated memory)  and the get routine replaced the pointer,         * we need to free the previous pointer.         */        if (old_string && (old_string != requests->requestvb->buf) &&            (requests->requestvb->val.string != old_string)) {            if (dataFreeHook)                (*dataFreeHook) (old_string);            else                free(old_string);        }    }                           /* for results */    return SNMP_ERR_NOERROR;}                               /* _mfd_ipAddressPrefixTable_get_values *//*********************************************************************** * * SET processing * ***********************************************************************//* * SET PROCESSING NOT APPLICABLE (per MIB or user setting) *//*********************************************************************** * * DATA ACCESS * ***********************************************************************/static void     _container_free(netsnmp_container *container);/** * @internal */static int_cache_load(netsnmp_cache * cache, void *vmagic){    DEBUGMSGTL(("internal:ipAddressPrefixTable:_cache_load", "called\n"));    if ((NULL == cache) || (NULL == cache->magic)) {        snmp_log(LOG_ERR,                 "invalid cache for ipAddressPrefixTable_cache_load\n");        return -1;    }    /** should only be called for an invalid or expired cache */    netsnmp_assert((0 == cache->valid) || (1 == cache->expired));    /*     * call user code     */    return ipAddressPrefixTable_container_load((netsnmp_container *)                                               cache->magic);}                               /* _cache_load *//** * @internal */static void_cache_free(netsnmp_cache * cache, void *magic){    netsnmp_container *container;    DEBUGMSGTL(("internal:ipAddressPrefixTable:_cache_free", "called\n"));    if ((NULL == cache) || (NULL == cache->magic)) {        snmp_log(LOG_ERR,                 "invalid cache in ipAddressPrefixTable_cache_free\n");        return;    }    container = (netsnmp_container *) cache->magic;    _container_free(container);}                               /* _cache_free *//** * @internal */static void_container_item_free(ipAddressPrefixTable_rowreq_ctx * rowreq_ctx,                     void *context){    DEBUGMSGTL(("internal:ipAddressPrefixTable:_container_item_free",                "called\n"));    if (NULL == rowreq_ctx)        return;    ipAddressPrefixTable_release_rowreq_ctx(rowreq_ctx);}                               /* _container_item_free *//** * @internal */static void_container_free(netsnmp_container *container){    DEBUGMSGTL(("internal:ipAddressPrefixTable:_container_free",                "called\n"));    if (NULL == container) {        snmp_log(LOG_ERR,                 "invalid container in ipAddressPrefixTable_container_free\n");        return;    }    /*     * call user code     */    ipAddressPrefixTable_container_free(container);    /*     * free all items. inefficient, but easy.     */    CONTAINER_CLEAR(container,                    (netsnmp_container_obj_func *) _container_item_free,                    NULL);}                               /* _container_free *//** * @internal * initialize the container with functions or wrappers */void_ipAddressPrefixTable_container_init(ipAddressPrefixTable_interface_ctx *                                     if_ctx){    DEBUGMSGTL(("internal:ipAddressPrefixTable:_ipAddressPrefixTable_container_init", "called\n"));    /*     * cache init     */    if_ctx->cache = netsnmp_cache_create(30,    /* timeout in seconds */                                         _cache_load, _cache_free,                                         ipAddressPrefixTable_oid,                                         ipAddressPrefixTable_oid_size);    if (NULL == if_ctx->cache) {        snmp_log(LOG_ERR,                 "error creating cache for ipAddressPrefixTable\n");        return;    }    if_ctx->cache->flags = NETSNMP_CACHE_DONT_INVALIDATE_ON_SET;    ipAddressPrefixTable_container_init(&if_ctx->container, if_ctx->cache);    if (NULL == if_ctx->container)        if_ctx->container =            netsnmp_container_find("ipAddressPrefixTable:table_container");    if (NULL == if_ctx->container) {        snmp_log(LOG_ERR, "error creating container in "                 "ipAddressPrefixTable_container_init\n");        return;    }    if (NULL != if_ctx->cache)        if_ctx->cache->magic = (void *) if_ctx->container;}                               /* _ipAddressPrefixTable_container_init *//** * @internal * shutdown the container with functions or wrappers */void_ipAddressPrefixTable_container_shutdown(ipAddressPrefixTable_interface_ctx                                         * if_ctx){    DEBUGMSGTL(("internal:ipAddressPrefixTable:_ipAddressPrefixTable_container_shutdown", "called\n"));    ipAddressPrefixTable_container_shutdown(if_ctx->container);    _container_free(if_ctx->container);}                               /* _ipAddressPrefixTable_container_shutdown */ipAddressPrefixTable_rowreq_ctx *ipAddressPrefixTable_row_find_by_mib_index(ipAddressPrefixTable_mib_index *                                           mib_idx){    ipAddressPrefixTable_rowreq_ctx *rowreq_ctx;    oid             oid_tmp[MAX_OID_LEN];    netsnmp_index   oid_idx;    int             rc;    /*     * set up storage for OID     */    oid_idx.oids = oid_tmp;    oid_idx.len = sizeof(oid_tmp) / sizeof(oid);    /*     * convert     */    rc = ipAddressPrefixTable_index_to_oid(&oid_idx, mib_idx);    if (MFD_SUCCESS != rc)        return NULL;    rowreq_ctx =        CONTAINER_FIND(ipAddressPrefixTable_if_ctx.container, &oid_idx);    return rowreq_ctx;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -