📄 socket_server_base.cc
字号:
XLOG_FATAL("Return list empty"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ string sockid; try { XrlCmdError e = socket4_0_1_tcp_open_bind_connect( xa_inputs.get_string("creator"), xa_inputs.get_ipv4("local_addr"), xa_inputs.get_uint32("local_port"), xa_inputs.get_ipv4("remote_addr"), xa_inputs.get_uint32("remote_port"), xa_inputs.get_bool("is_blocking"), sockid); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/tcp_open_bind_connect", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } /* Marshall return values */ try { pxa_outputs->add("sockid", sockid); } catch (const XrlArgs::XrlAtomFound& ) { XLOG_FATAL("Duplicate atom name"); /* XXX Should never happen */ } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_udp_open_bind_connect(const XrlArgs& xa_inputs, XrlArgs* pxa_outputs){ if (xa_inputs.size() != 6) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(6), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/udp_open_bind_connect"); return XrlCmdError::BAD_ARGS(); } if (pxa_outputs == 0) { XLOG_FATAL("Return list empty"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ string sockid; try { XrlCmdError e = socket4_0_1_udp_open_bind_connect( xa_inputs.get_string("creator"), xa_inputs.get_ipv4("local_addr"), xa_inputs.get_uint32("local_port"), xa_inputs.get_ipv4("remote_addr"), xa_inputs.get_uint32("remote_port"), xa_inputs.get_bool("is_blocking"), sockid); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/udp_open_bind_connect", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } /* Marshall return values */ try { pxa_outputs->add("sockid", sockid); } catch (const XrlArgs::XrlAtomFound& ) { XLOG_FATAL("Duplicate atom name"); /* XXX Should never happen */ } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_udp_join_group(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 3) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(3), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/udp_join_group"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_udp_join_group( xa_inputs.get_string("sockid"), xa_inputs.get_ipv4("mcast_addr"), xa_inputs.get_ipv4("join_if_addr")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/udp_join_group", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_udp_leave_group(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 3) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(3), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/udp_leave_group"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_udp_leave_group( xa_inputs.get_string("sockid"), xa_inputs.get_ipv4("mcast_addr"), xa_inputs.get_ipv4("leave_if_addr")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/udp_leave_group", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_close(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 1) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(1), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/close"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_close( xa_inputs.get_string("sockid")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/close", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_tcp_listen(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 2) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(2), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/tcp_listen"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_tcp_listen( xa_inputs.get_string("sockid"), xa_inputs.get_uint32("backlog")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/tcp_listen", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_send(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 2) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(2), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/send"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_send( xa_inputs.get_string("sockid"), xa_inputs.get_binary("data")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/send", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_send_with_flags(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 5) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(5), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/send_with_flags"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_send_with_flags( xa_inputs.get_string("sockid"), xa_inputs.get_binary("data"), xa_inputs.get_bool("out_of_band"), xa_inputs.get_bool("end_of_record"), xa_inputs.get_bool("end_of_file")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/send_with_flags", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_send_to(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 4) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(4), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/send_to"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_send_to( xa_inputs.get_string("sockid"), xa_inputs.get_ipv4("remote_addr"), xa_inputs.get_uint32("remote_port"), xa_inputs.get_binary("data")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/send_to", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_send_to_with_flags(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 7) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(7), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/send_to_with_flags"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_send_to_with_flags( xa_inputs.get_string("sockid"), xa_inputs.get_ipv4("remote_addr"), xa_inputs.get_uint32("remote_port"), xa_inputs.get_binary("data"), xa_inputs.get_bool("out_of_band"), xa_inputs.get_bool("end_of_record"), xa_inputs.get_bool("end_of_file")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/send_to_with_flags", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_send_from_multicast_if(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 5) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(5), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/send_from_multicast_if"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_send_from_multicast_if( xa_inputs.get_string("sockid"), xa_inputs.get_ipv4("group_addr"), xa_inputs.get_uint32("group_port"), xa_inputs.get_ipv4("ifaddr"), xa_inputs.get_binary("data")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/send_from_multicast_if", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_set_socket_option(const XrlArgs& xa_inputs, XrlArgs* /* pxa_outputs */){ if (xa_inputs.size() != 3) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(3), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/set_socket_option"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ try { XrlCmdError e = socket4_0_1_set_socket_option( xa_inputs.get_string("sockid"), xa_inputs.get_string("optname"), xa_inputs.get_uint32("optval")); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s", "socket4/0.1/set_socket_option", e.str().c_str()); return e; } } catch (const XrlArgs::XrlAtomNotFound& e) { XLOG_ERROR("Argument not found"); return XrlCmdError::BAD_ARGS(); } return XrlCmdError::OKAY();}const XrlCmdErrorXrlSocketServerTargetBase::handle_socket4_0_1_get_socket_option(const XrlArgs& xa_inputs, XrlArgs* pxa_outputs){ if (xa_inputs.size() != 2) { XLOG_ERROR("Wrong number of arguments (%u != %u) handling %s", XORP_UINT_CAST(2), XORP_UINT_CAST(xa_inputs.size()), "socket4/0.1/get_socket_option"); return XrlCmdError::BAD_ARGS(); } if (pxa_outputs == 0) { XLOG_FATAL("Return list empty"); return XrlCmdError::BAD_ARGS(); } /* Return value declarations */ uint32_t optval; try { XrlCmdError e = socket4_0_1_get_socket_option( xa_inputs.get_string("sockid"), xa_inputs.get_string("optname"), optval); if (e != XrlCmdError::OKAY()) { XLOG_WARNING("Handling method for %s failed: %s",
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -