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

📄 usmdhuserkeytable_interface.c

📁 snmp的源代码,已经在我的ubuntu下编译通过
💻 C
📖 第 1 页 / 共 4 页
字号:
        rowreq_ctx->column_set_flags |= FLAG_USMDHUSERAUTHKEYCHANGE;        rc = usmDHUserAuthKeyChange_set(rowreq_ctx,                                        (char *) var->val.string,                                        var->val_len);        break;        /*         * usmDHUserOwnAuthKeyChange(2)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSEROWNAUTHKEYCHANGE:        rowreq_ctx->column_set_flags |= FLAG_USMDHUSEROWNAUTHKEYCHANGE;        rc = usmDHUserOwnAuthKeyChange_set(rowreq_ctx,                                           (char *) var->val.string,                                           var->val_len);        break;        /*         * usmDHUserPrivKeyChange(3)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSERPRIVKEYCHANGE:        rowreq_ctx->column_set_flags |= FLAG_USMDHUSERPRIVKEYCHANGE;        rc = usmDHUserPrivKeyChange_set(rowreq_ctx,                                        (char *) var->val.string,                                        var->val_len);        break;        /*         * usmDHUserOwnPrivKeyChange(4)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSEROWNPRIVKEYCHANGE:        rowreq_ctx->column_set_flags |= FLAG_USMDHUSEROWNPRIVKEYCHANGE;        rc = usmDHUserOwnPrivKeyChange_set(rowreq_ctx,                                           (char *) var->val.string,                                           var->val_len);        break;    default:        snmp_log(LOG_ERR,                 "unknown column %d in _usmDHUserKeyTable_set_column\n",                 column);        break;    }    return rc;}                               /* _usmDHUserKeyTable_set_column */int_mfd_usmDHUserKeyTable_set_values(netsnmp_mib_handler *handler,                                  netsnmp_handler_registration *reginfo,                                  netsnmp_agent_request_info *agtreq_info,                                  netsnmp_request_info *requests){    usmDHUserKeyTable_rowreq_ctx *rowreq_ctx =        netsnmp_container_table_row_extract(requests);    netsnmp_table_request_info *tri;    int             rc = SNMP_ERR_NOERROR;    DEBUGMSGTL(("internal:usmDHUserKeyTable:_mfd_usmDHUserKeyTable_set_values", "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    rowreq_ctx->column_set_flags = 0;    for (; requests; requests = requests->next) {        /*         * set column data         */        tri = netsnmp_extract_table_info(requests);        if (NULL == tri)            continue;        rc = _usmDHUserKeyTable_set_column(rowreq_ctx,                                           requests->requestvb,                                           tri->colnum);        if (MFD_SUCCESS != rc) {            DEBUGMSGTL(("verbose:usmDHUserKeyTable:mfd", "error %d from "                        "usmDHUserKeyTable_set_column\n", rc));            netsnmp_set_request_error(agtreq_info, requests,                                      SNMP_VALIDATE_ERR(rc));        }    }                           /* for results */    return SNMP_ERR_NOERROR;}                               /* _mfd_usmDHUserKeyTable_set_values *//*---------------------------------------------------------------------- * * SET: commit * *---------------------------------------------------------------------*//** * @internal * commit the values */int_mfd_usmDHUserKeyTable_commit(netsnmp_mib_handler *handler,                              netsnmp_handler_registration *reginfo,                              netsnmp_agent_request_info *agtreq_info,                              netsnmp_request_info *requests){    int             rc;    usmDHUserKeyTable_rowreq_ctx *rowreq_ctx =        netsnmp_container_table_row_extract(requests);    DEBUGMSGTL(("internal:usmDHUserKeyTable:_mfd_usmDHUserKeyTable_commit",                "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    rc = usmDHUserKeyTable_commit(rowreq_ctx);    if (MFD_SUCCESS != rc) {        DEBUGMSGTL(("verbose:usmDHUserKeyTable:mfd", "error %d from "                    "usmDHUserKeyTable_commit\n", rc));        netsnmp_request_set_error_all(requests, SNMP_VALIDATE_ERR(rc));    }    return SNMP_ERR_NOERROR;}int_mfd_usmDHUserKeyTable_undo_commit(netsnmp_mib_handler *handler,                                   netsnmp_handler_registration *reginfo,                                   netsnmp_agent_request_info *agtreq_info,                                   netsnmp_request_info *requests){    int             rc;    usmDHUserKeyTable_rowreq_ctx *rowreq_ctx =        netsnmp_container_table_row_extract(requests);    DEBUGMSGTL(("internal:usmDHUserKeyTable:_mfd_usmDHUserKeyTable_undo_commit", "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    rc = usmDHUserKeyTable_undo_commit(rowreq_ctx);    if (MFD_SUCCESS != rc) {        /*         * nothing we can do about it but log it         */        DEBUGMSGTL(("verbose:usmDHUserKeyTable:mfd", "error %d from "                    "usmDHUserKeyTable_undo_commit\n", rc));    }    return SNMP_ERR_NOERROR;}                               /* _mfd_usmDHUserKeyTable_commit *//*---------------------------------------------------------------------- * * SET: Undo * *---------------------------------------------------------------------*//** * @internal * undo the value for a particular column */NETSNMP_STATIC_INLINE int_usmDHUserKeyTable_undo_column(usmDHUserKeyTable_rowreq_ctx * rowreq_ctx,                               netsnmp_variable_list * var, int column){    int             rc = SNMPERR_SUCCESS;    DEBUGMSGTL(("internal:usmDHUserKeyTable:_usmDHUserKeyTable_undo_column", "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    switch (column) {        /*         * usmDHUserAuthKeyChange(1)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSERAUTHKEYCHANGE:        rc = usmDHUserAuthKeyChange_undo(rowreq_ctx);        break;        /*         * usmDHUserOwnAuthKeyChange(2)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSEROWNAUTHKEYCHANGE:        rc = usmDHUserOwnAuthKeyChange_undo(rowreq_ctx);        break;        /*         * usmDHUserPrivKeyChange(3)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSERPRIVKEYCHANGE:        rc = usmDHUserPrivKeyChange_undo(rowreq_ctx);        break;        /*         * usmDHUserOwnPrivKeyChange(4)/DHKeyChange/ASN_OCTET_STR/char(char)//L/A/W/e/r/d/h          */    case COLUMN_USMDHUSEROWNPRIVKEYCHANGE:        rc = usmDHUserOwnPrivKeyChange_undo(rowreq_ctx);        break;    default:        snmp_log(LOG_ERR,                 "unknown column %d in _usmDHUserKeyTable_undo_column\n",                 column);        break;    }    return rc;}                               /* _usmDHUserKeyTable_undo_column */int_mfd_usmDHUserKeyTable_undo_values(netsnmp_mib_handler *handler,                                   netsnmp_handler_registration *reginfo,                                   netsnmp_agent_request_info *agtreq_info,                                   netsnmp_request_info *requests){    int             rc;    usmDHUserKeyTable_rowreq_ctx *rowreq_ctx =        netsnmp_container_table_row_extract(requests);    netsnmp_table_request_info *tri;    DEBUGMSGTL(("internal:usmDHUserKeyTable:_mfd_usmDHUserKeyTable_undo_values", "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    for (; requests; requests = requests->next) {        /*         * set column data         */        tri = netsnmp_extract_table_info(requests);        if (NULL == tri)            continue;        rc = _usmDHUserKeyTable_undo_column(rowreq_ctx,                                            requests->requestvb,                                            tri->colnum);        if (MFD_SUCCESS != rc) {            /*             * nothing we can do about it but log it             */            DEBUGMSGTL(("verbose:usmDHUserKeyTable:mfd", "error %d from "                        "usmDHUserKeyTable_undo_column\n", rc));        }    }                           /* for results */    return SNMP_ERR_NOERROR;}                               /* _mfd_usmDHUserKeyTable_undo_values *//*---------------------------------------------------------------------- * * SET: irreversible commit * *---------------------------------------------------------------------*//** * @internal * commit irreversible actions */int_mfd_usmDHUserKeyTable_irreversible_commit(netsnmp_mib_handler *handler, netsnmp_handler_registration                                           *reginfo, netsnmp_agent_request_info                                           *agtreq_info,                                           netsnmp_request_info *requests){    int             rc;    usmDHUserKeyTable_rowreq_ctx *rowreq_ctx =        netsnmp_container_table_row_extract(requests);    DEBUGMSGTL(("internal:usmDHUserKeyTable:_mfd_usmDHUserKeyTable_irreversible:commit", "called\n"));    netsnmp_assert(NULL != rowreq_ctx);    rc = usmDHUserKeyTable_irreversible_commit(rowreq_ctx);    if (MFD_SUCCESS != rc) {        netsnmp_request_set_error_all(requests, SNMP_ERR_COMMITFAILED);        DEBUGMSGTL(("verbose:usmDHUserKeyTable:mfd", "error %d from "                    "usmDHUserKeyTable_irreversible_commit\n", rc));    }    return SNMP_ERR_NOERROR;}                               /* _mfd_usmDHUserKeyTable_irreversible_commit *//*********************************************************************** * * DATA ACCESS * ***********************************************************************//** * @internal */static int_cache_load(netsnmp_cache * cache, void *vmagic){    DEBUGMSGTL(("internal:usmDHUserKeyTable:_cache_load", "called\n"));    if ((NULL == cache) || (NULL == cache->magic)) {        snmp_log(LOG_ERR,                 "invalid cache for usmDHUserKeyTable_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 usmDHUserKeyTable_cache_load((netsnmp_container *) cache->                                        magic);}                               /* _cache_load *//** * @internal */static void_cache_item_free(usmDHUserKeyTable_rowreq_ctx * rowreq_ctx, void *context){    DEBUGMSGTL(("internal:usmDHUserKeyTable:_cache_item_free",                "called\n"));    if (NULL == rowreq_ctx)        return;    usmDHUserKeyTable_release_rowreq_ctx(rowreq_ctx);}                               /* _cache_item_free *//** * @internal */static void_cache_free(netsnmp_cache * cache, void *magic){    netsnmp_container *container;    DEBUGMSGTL(("internal:usmDHUserKeyTable:_cache_free", "called\n"));    if ((NULL == cache) || (NULL == cache->magic)) {        snmp_log(LOG_ERR,                 "invalid cache in usmDHUserKeyTable_cache_free\n");        return;    }    container = (netsnmp_container *) cache->magic;    /*     * call user code     */    usmDHUserKeyTable_cache_free(container);    /*     * free all items. inefficient, but easy.     */    CONTAINER_CLEAR(container,                    (netsnmp_container_obj_func *) _cache_item_free, NULL);}                               /* _cache_free *//** * @internal * initialize the iterator container with functions or wrappers */void_usmDHUserKeyTable_container_init(usmDHUserKeyTable_interface_ctx * if_ctx){    DEBUGMSGTL(("internal:usmDHUserKeyTable:_usmDHUserKeyTable_container_init", "called\n"));    /*     * set up the cache     */    if_ctx->cache = netsnmp_cache_create(30,    /* timeout in seconds */                                         _cache_load, _cache_free,                                         usmDHUserKeyTable_oid,                                         usmDHUserKeyTable_oid_size);    if (NULL == if_ctx->cache) {        snmp_log(LOG_ERR, "error creating cache for usmDHUserKeyTable\n");        return;    }    if_ctx->cache->flags = NETSNMP_CACHE_DONT_INVALIDATE_ON_SET;    usmDHUserKeyTable_container_init(&if_ctx->container, if_ctx->cache);    if (NULL == if_ctx->container)        if_ctx->container =            netsnmp_container_find("usmDHUserKeyTable:table_container");    if (NULL == if_ctx->container) {        snmp_log(LOG_ERR, "error creating container in "                 "usmDHUserKeyTable_container_init\n");        return;    }    if_ctx->cache->magic = (void *) if_ctx->container;}                               /* _usmDHUserKeyTable_container_init */

⌨️ 快捷键说明

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