diff options
Diffstat (limited to 'src/plugins/ietf')
-rw-r--r-- | src/plugins/ietf/ietf_interface.c | 101 | ||||
-rw-r--r-- | src/plugins/ietf/ietf_nat.c | 57 |
2 files changed, 86 insertions, 72 deletions
diff --git a/src/plugins/ietf/ietf_interface.c b/src/plugins/ietf/ietf_interface.c index 0f8c37e..4d13d13 100644 --- a/src/plugins/ietf/ietf_interface.c +++ b/src/plugins/ietf/ietf_interface.c @@ -16,8 +16,7 @@ #include <stdio.h> #include <sys/socket.h> -#include "../sc_model.h" -#include "../sys_util.h" +#include <sc_plugins.h> #include <scvpp/interface.h> #include <scvpp/ip.h> @@ -339,51 +338,55 @@ nothing_todo: return rc; } -const xpath_t ietf_interfaces_xpaths[IETF_INTERFACES_SIZE] = { - { - .xpath = "/ietf-interfaces:interfaces/interface", - .method = XPATH, - .datastore = SR_DS_RUNNING, - .cb.scb = ietf_interface_change_cb, - .private_ctx = NULL, - .priority = 0, - .opts = SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED - }, - { - .xpath = "/ietf-interfaces:interfaces/interface/enabled", - .method = XPATH, - .datastore = SR_DS_RUNNING, - .cb.scb = ietf_interface_enable_disable_cb, - .private_ctx = NULL, - .priority = 100, - .opts = SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED - }, - { - .xpath = "/ietf-interfaces:interfaces/interface/ietf-ip:ipv4/address", - .method = XPATH, - .datastore = SR_DS_RUNNING, - .cb.scb = ietf_interface_ipv46_address_change_cb, - .private_ctx = NULL, - .priority = 99, - .opts = SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED - }, - { - .xpath = "/ietf-interfaces:interfaces/interface/ietf-ip:ipv6/address", - .method = XPATH, - .datastore = SR_DS_RUNNING, - .cb.scb = ietf_interface_ipv46_address_change_cb, - .private_ctx = NULL, - .priority = 98, - .opts = SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED - }, - { - .xpath = "/ietf-interfaces:interfaces-state", - .method = GETITEM, - .datastore = SR_DS_RUNNING, - .cb.gcb = ietf_interface_state_cb, - .private_ctx = NULL, - .priority = 98, - //.opts = SR_SUBSCR_DEFAULT, - .opts = SR_SUBSCR_CTX_REUSE + +int +ietf_interface_init(sc_plugin_main_t *pm) +{ + int rc = SR_ERR_OK; + SRP_LOG_DBG_MSG("Initializing ietf-interface plugin."); + + rc = sr_subtree_change_subscribe(pm->session, "/ietf-interfaces:interfaces/interface", + ietf_interface_change_cb, NULL, 0, SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED, &pm->subscription); + if (SR_ERR_OK != rc) { + goto error; + } + + rc = sr_subtree_change_subscribe(pm->session, "/ietf-interfaces:interfaces/interface/enabled", + ietf_interface_enable_disable_cb, NULL, 100, SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED, &pm->subscription); + if (SR_ERR_OK != rc) { + goto error; + } + + rc = sr_subtree_change_subscribe(pm->session, "/ietf-interfaces:interfaces/interface/ietf-ip:ipv4/address", + ietf_interface_ipv46_address_change_cb, NULL, 99, SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED, &pm->subscription); + if (SR_ERR_OK != rc) { + goto error; + } + + rc = sr_subtree_change_subscribe(pm->session, "/ietf-interfaces:interfaces/interface/ietf-ip:ipv6/address", + ietf_interface_ipv46_address_change_cb, NULL, 98, SR_SUBSCR_CTX_REUSE | SR_SUBSCR_EV_ENABLED, &pm->subscription); + if (SR_ERR_OK != rc) { + goto error; + } + + rc = sr_dp_get_items_subscribe(pm->session, "/ietf-interfaces:interfaces-state", + ietf_interface_state_cb, NULL, SR_SUBSCR_CTX_REUSE, &pm->subscription); + if (SR_ERR_OK != rc) { + goto error; } -}; + + SRP_LOG_DBG_MSG("ietf-interface plugin initialized successfully."); + return SR_ERR_OK; + +error: + SRP_LOG_ERR("Error by initialization of ietf-interface plugin. Error : %d", rc); + return rc; +} + +void +ietf_interface_exit(__attribute__((unused)) sc_plugin_main_t *pm) +{ +} + +SC_INIT_FUNCTION(ietf_interface_init); +SC_EXIT_FUNCTION(ietf_interface_exit); diff --git a/src/plugins/ietf/ietf_nat.c b/src/plugins/ietf/ietf_nat.c index 3b82f28..287fa02 100644 --- a/src/plugins/ietf/ietf_nat.c +++ b/src/plugins/ietf/ietf_nat.c @@ -18,7 +18,7 @@ #include <scvpp/interface.h> #include <scvpp/nat.h> -#include "../sc_model.h" +#include <sc_plugins.h> #include <assert.h> #include <string.h> @@ -29,8 +29,6 @@ #include <netinet/in.h> #include <arpa/inet.h> -#include "../sys_util.h" - /** * @brief Wrapper struct for VAPI address range payload. */ @@ -490,23 +488,36 @@ error: return rc; } -const xpath_t ietf_nat_xpaths[IETF_NAT_SIZE] = { - { - .xpath = "/ietf-nat:nat/instances/instance/policy/external-ip-address-pool", - .method = XPATH, - .datastore = SR_DS_RUNNING, - .cb.scb = instances_instance_policy_external_ip_address_pool_cb, - .private_ctx = NULL, - .priority = 0, - .opts = SR_SUBSCR_CTX_REUSE - }, - { - .xpath = "/ietf-nat:nat/instances/instance/mapping-table/mapping-entry", - .method = XPATH, - .datastore = SR_DS_RUNNING, - .cb.scb = instances_instance_mapping_table_mapping_entry_cb, - .private_ctx = NULL, - .priority = 0, - .opts = SR_SUBSCR_CTX_REUSE - }, -}; +int +ietf_nat_init(sc_plugin_main_t *pm) +{ + int rc = SR_ERR_OK; + SRP_LOG_DBG_MSG("Initializing ietf-nat plugin."); + + rc = sr_subtree_change_subscribe(pm->session, "/ietf-nat:nat/instances/instance/policy/external-ip-address-pool", + instances_instance_policy_external_ip_address_pool_cb, NULL, 0, SR_SUBSCR_CTX_REUSE, &pm->subscription); + if (rc != SR_ERR_OK) { + goto error; + } + + rc = sr_subtree_change_subscribe(pm->session, "/ietf-nat:nat/instances/instance/mapping-table/mapping-entry", + instances_instance_mapping_table_mapping_entry_cb, NULL, 0, SR_SUBSCR_CTX_REUSE, &pm->subscription); + if (rc != SR_ERR_OK) { + goto error; + } + + SRP_LOG_DBG_MSG("ietf-nat plugin initialized successfully."); + return SR_ERR_OK; + +error: + SRP_LOG_ERR("Error by initialization of ietf-nat plugin. Error : %d", rc); + return rc; +} + +void +ietf_nat_exit(__attribute__((unused)) sc_plugin_main_t *pm) +{ +} + +SC_INIT_FUNCTION(ietf_nat_init); +SC_EXIT_FUNCTION(ietf_nat_exit); |