Source: ../../xrl/interfaces/socket4_user_xif.hh
|
|
|
|
/*
* Copyright (c) 2001-2009 XORP, Inc.
* See the XORP LICENSE.lgpl file for licensing, conditions, and warranties
* on use.
*
* DO NOT EDIT THIS FILE - IT IS PROGRAMMATICALLY GENERATED
*
* Generated by 'clnt-gen'.
*
* $XORP: xorp/xrl/interfaces/socket4_user_xif.hh,v 1.19 2009/01/05 18:31:13 jtc Exp $
*/
#ifndef __XRL_INTERFACES_SOCKET4_USER_XIF_HH__
#define __XRL_INTERFACES_SOCKET4_USER_XIF_HH__
#undef XORP_LIBRARY_NAME
#define XORP_LIBRARY_NAME "XifSocket4User"
#include "libxorp/xlog.h"
#include "libxorp/callback.hh"
#include "libxipc/xrl.hh"
#include "libxipc/xrl_error.hh"
#include "libxipc/xrl_sender.hh"
class XrlSocket4UserV0p1Client {
public:
XrlSocket4UserV0p1Client(XrlSender* s) : _sender(s) {}
virtual ~XrlSocket4UserV0p1Client() {}
typedef XorpCallback1<void, const XrlError&>::RefPtr RecvEventCB;
/**
* Send Xrl intended to:
*
* Method invoked by target implementing socket4/0.1 when a packet arrives
* from an IPv4 source.
*
* @param dst_xrl_target_name the Xrl target name of the destination.
*
* @param sockid the identifier associated with socket where the event
* occurred.
*
* @param if_name the interface name the packet arrived on, if known. If
* unknown, then it is an empty string.
*
* @param vif_name the vif name the packet arrived on, if known. If
* unknown, then it is an empty string.
*
* @param src_host the originating host.
*
* @param src_port the originating IP port.
*
* @param data the data received.
*/
bool send_recv_event(
const char* dst_xrl_target_name,
const string& sockid,
const string& if_name,
const string& vif_name,
const IPv4& src_host,
const uint32_t& src_port,
const vector<uint8_t>& data,
const RecvEventCB& cb
);
typedef XorpCallback2<void, const XrlError&, const bool*>::RefPtr InboundConnectEventCB;
/**
* Send Xrl intended to:
*
* Method invoked by target implementing socket4/0.1 when a connection
* request is received from an IPv4 source. It applies only to TCP
* sockets.
*
* @param dst_xrl_target_name the Xrl target name of the destination.
*
* @param sockid the identifier associated with socket where the event
* occurred.
*
* @param src_host the connecting host.
*
* @param src_port the connecting IP port.
*
* @param new_sockid the identifier associated with the new socket that
* has been created to handle the new connection.
*/
bool send_inbound_connect_event(
const char* dst_xrl_target_name,
const string& sockid,
const IPv4& src_host,
const uint32_t& src_port,
const string& new_sockid,
const InboundConnectEventCB& cb
);
typedef XorpCallback1<void, const XrlError&>::RefPtr OutgoingConnectEventCB;
/**
* Send Xrl intended to:
*
* Method invoked by target implementing socket4/0.1 when an outgoing
* connection request originated by the local host is completed. It
* applies only to TCP sockets. Note that if the connection failed, the
* error_event will be dispatched instead.
*
* @param dst_xrl_target_name the Xrl target name of the destination.
*
* @param sockid the identifier associated with socket where the event
* occurred.
*/
bool send_outgoing_connect_event(
const char* dst_xrl_target_name,
const string& sockid,
const OutgoingConnectEventCB& cb
);
typedef XorpCallback1<void, const XrlError&>::RefPtr ErrorEventCB;
/**
* Send Xrl intended to:
*
* Method invoked by target implementing socket4/0.1 when an error occurs.
*
* @param dst_xrl_target_name the Xrl target name of the destination.
*
* @param sockid the identifier associated with socket where the event
* occurred.
*
* @param error a textual description of the error.
*
* @param fatal indication of whether socket is shutdown because of error.
*/
bool send_error_event(
const char* dst_xrl_target_name,
const string& sockid,
const string& error,
const bool& fatal,
const ErrorEventCB& cb
);
typedef XorpCallback1<void, const XrlError&>::RefPtr DisconnectEventCB;
/**
* Send Xrl intended to:
*
* Method invoked by target implementing socket4/0.1 when the peer has
* closed the connection. It applies only to TCP sockets. Note that the
* socket itself is left open and must be explicitly closed.
*
* @param dst_xrl_target_name the Xrl target name of the destination.
*
* @param sockid the identifier associated with socket where the event
* occurred.
*/
bool send_disconnect_event(
const char* dst_xrl_target_name,
const string& sockid,
const DisconnectEventCB& cb
);
protected:
XrlSender* _sender;
private:
void unmarshall_recv_event(
const XrlError& e,
XrlArgs* a,
RecvEventCB cb
);
void unmarshall_inbound_connect_event(
const XrlError& e,
XrlArgs* a,
InboundConnectEventCB cb
);
void unmarshall_outgoing_connect_event(
const XrlError& e,
XrlArgs* a,
OutgoingConnectEventCB cb
);
void unmarshall_error_event(
const XrlError& e,
XrlArgs* a,
ErrorEventCB cb
);
void unmarshall_disconnect_event(
const XrlError& e,
XrlArgs* a,
DisconnectEventCB cb
);
};
#endif /* __XRL_INTERFACES_SOCKET4_USER_XIF_HH__ */
Generated by: pavlin on kobe.xorp.net on Wed Jan 7 19:10:48 2009, using kdoc 2.0a54+XORP.