Source: ../../cli/cli_node.hh
|
|
|
|
// -*- c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t -*-
// Copyright (c) 2001,2002 International Computer Science Institute
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software")
// to deal in the Software without restriction, subject to the conditions
// listed in the XORP LICENSE file. These conditions include: you must
// preserve this copyright notice, and you cannot mention the copyright
// holders in advertising related to the Software without their permission.
// The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This
// notice is a summary of the XORP LICENSE file; the license in that file is
// legally binding.
// $XORP: xorp/cli/cli_node.hh,v 1.1.1.1 2002/12/11 23:55:52 hodson Exp $
#ifndef __CLI_CLI_NODE_HH__
#define __CLI_CLI_NODE_HH__
//
// CLI node definition.
//
#include <list>
#include "libxorp/selector.hh"
#include "libproto/proto_node.hh"
#include "cli_command.hh"
//
// Constants definitions
//
//
// Structures/classes, typedefs and macros
//
class EventLoop;
class CliClient;
class CliPipe;
class IPvXNet;
/**
* @short The class for the CLI node.
*
* There should one node per CLI instance. There should be
* one CLI instance per router.
*/
class CliNode : public ProtoNode<Vif> {
public:
/**
* Constructor for a given address family, module ID, and event loop.
*
* @param init_family the address family (AF_INET or AF_INET6 for
* IPv4 and IPv6 respectively). Note that this argument may disappear
* in the future, and a single Cli node would provide access for
* both IPv4 and IPv6.
* @param init_module_id the module ID (@ref x_module_id). Should be
* equal to X_MODULE_CLI.
* @param init_event_loop the event loop to use.
*/
CliNode(int init_family, x_module_id init_module_id,
EventLoop& init_event_loop);
/**
* Destructor
*/
virtual ~CliNode();
/**
* Start the node operation.
*
* @return XORP_OK on success, otherwise XORP_ERROR.
*/
int start();
/**
* Stop the node operation.
*
* @return XORP_OK on success, otherwise XORP_ERROR.
*/
int stop();
/**
* Set the CLI access port.
*
* The access port is the TCP port the CLI node listens to for
* network access (e.g., telnet xorp_host <port_number>).
*
* @param v the access port number (in host order).
*/
void set_cli_port(unsigned short v) { _cli_port = htons(v); }
/**
* Add a subnet address to the list of subnet addresses enabled for
* CLI access.
*
* This method can be called more than once to add a number of
* subnet addresses.
*
* @param ipvxnet the subnet address to add.
*/
void add_enable_cli_access_from_subnet(const IPvXNet& ipvxnet);
/**
* Delete a subnet address from the list of subnet addresses enabled for
* CLI access.
*
* @param ipvxnet the subnet address to delete.
* @return XORP_OK on success, otherwise XORP_ERROR (e.g., if the subnet
* address was not added before).
*/
int delete_enable_cli_access_from_subnet(const IPvXNet& ipvxnet);
/**
* Add a subnet address to the list of subnet addresses disabled for
* CLI access.
*
* This method can be called more than once to add a number of
* subnet addresses.
*
* @param ipvxnet the subnet address to add.
*/
void add_disable_cli_access_from_subnet(const IPvXNet& ipvxnet);
/**
* Delete a subnet address from the list of subnet addresses disabled for
* CLI access.
*
* @param ipvxnet the subnet address to delete.
* @return XORP_OK on success, otherwise XORP_ERROR (e.g., if the subnet
* address was not added before).
*/
int delete_disable_cli_access_from_subnet(const IPvXNet& ipvxnet);
/**
* Get the @ref CliCommand entry for the CLI root command.
*
* @return a pointer to the @ref CliCommand entry for the CLI root command.
*/
CliCommand *cli_command_root() { return (&_cli_command_root); }
/**
* Output a log message to a @ref CliClient object.
*
* @param obj the @ref CliClient object to apply this method to.
* @param msg a C-style string with the message to output.
* @return on success, the number of characters printed,
* otherwise %XORP_ERROR.
*/
static int xlog_output(void *obj, const char *msg);
/**
* Find a CLI client @ref CliClient for a given terminal name.
*
* @param term_name C-style string with the CLI terminal name
* to search for.
* @return the CLI client @ref CliClient with name of @ref term_name
* on success, otherwise NULL.
*/
CliClient *find_cli_by_term_name(const char *term_name) const;
/**
* Find a CLI client @ref CliClient for a given session ID.
*
* @param session_id the CLI session ID to search for.
* @return the CLI client @ref CliClient with session ID of @ref session_id
* on success, otherwise NULL.
*/
CliClient *find_cli_by_session_id(uint32_t session_id) const;
/**
* Get the list of CLI clients (see @ref CliClient).
*
* @return a reference to the list of pointers to CLI clients
* (see @ref CliClient).
*/
list<CliClient *>& client_list() { return (_client_list); }
/**
* Add a CLI command to the CLI manager.
*
* @param processor_name the name of the module that will process
* that command.
* @param command_name the name of the command to add.
* @param command_help the help for the command to add.
* @param is_command_cd if true, this is a command that allows
* "change directory" inside the CLI command-tree.
* @param command_cd_prompt if @ref is_command_cd is true,
* the string that will replace the CLI prompt after we
* "cd" to that level of the CLI command-tree.
* @param is_command_processor if true, this is a processing command
* that would be performed by @processor_name.
* @param fail true if failure has occured.
* @param reason contains failure reason if it occured.
*/
void add_cli_command(
// Input values,
const string& processor_name,
const string& command_name,
const string& command_help,
const bool& is_command_cd,
const string& command_cd_prompt,
const bool& is_command_processor,
// Output values,
bool& fail,
string& reason);
/**
* Process the response of a command processed by a remote node.
*
* @param processor_name the name of the module that has processed
* that command.
* @param cli_term_name the terminal name the command was entered from.
* @param cli_session_id the CLI session ID the command was entered from.
* @param command_output the command output to process.
*/
void recv_process_command_output(const string *processor_name,
const string *cli_term_name,
const uint32_t *cli_session_id,
const string *command_output);
//
// Protocol message and kernel signal send/recv: not used by the CLI.
//
/**
* UNUSED
*/
int proto_recv(const string& , // src_module_instance_name,
x_module_id , // src_module_id,
uint16_t , // vif_index,
const IPvX& , // src,
const IPvX& , // dst,
int , // ip_ttl,
int , // ip_tos,
bool , // router_alert_bool,
const uint8_t * , // rcvbuf,
size_t // rcvlen
) { assert (false); return (XORP_ERROR); }
/**
* UNUSED
*/
int proto_send(const string& , // dst_module_instance_name,
x_module_id , // dst_module_id,
uint16_t , // vif_index,
const IPvX& , // src,
const IPvX& , // dst,
int , // ip_ttl,
int , // ip_tos,
bool , // router_alert_bool,
const uint8_t * , // sndbuf,
size_t // sndlen
) { assert (false); return (XORP_ERROR); }
/**
* UNUSED
*/
int signal_message_recv(const string& , // src_module_instance_name,
x_module_id , // src_module_id,
int , // message_type,
uint16_t , // vif_index,
const IPvX& , // src,
const IPvX& , // dst,
const uint8_t * , // rcvbuf,
size_t // rcvlen
) { assert (false); return (XORP_ERROR); }
/**
* UNUSED
*/
int signal_message_send(const string& , // dst_module_instance_name,
x_module_id , // dst_module_id,
int , // message_type,
uint16_t , // vif_index,
const IPvX& , // src,
const IPvX& , // dst,
const uint8_t * , // sndbuf,
size_t // sndlen
) { assert (false); return (XORP_ERROR); }
typedef XorpCallback6<void,
const char*, // target
const string&, // server_name
const string&, // cli_term_name
uint32_t, // cli_session_id
const string&, // command_global_name
const string& // argv
>::RefPtr SenderProcessCallback;
/**
* Set a callback to send a CLI command to a processing module.
*
* @param v the @ref SenderProcessCallback callback to set.
*/
void set_send_process_command_callback(const SenderProcessCallback& v) {
_send_process_command_callback = v;
}
/**
* Add a CLI client (@ref CliClient) to the CLI with enabled stdio access.
*
* @return a pointer to the CLI client (@ref CliClient) with enabled
* stdio access on success, otherwise NULL.
*/
CliClient *enable_stdio_access();
typedef XorpCallback1<void,
CliClient* // CLI client to delete
>::RefPtr CliClientDeleteCallback;
/**
* Set the callback method that is invoked whenever a CliClient is deleted
*
* @param v the @ref CliClientDeleteCallback callback to set.
*/
void set_cli_client_delete_callback(const CliClientDeleteCallback& v) {
_cli_client_delete_callback = v;
}
private:
friend CliClient;
//
// Internal CLI commands
//
int add_internal_cli_commands();
int cli_show_log(const char *server_name,
const char *cli_term_name,
uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int cli_show_log_user(const char *server_name,
const char *cli_term_name,
uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int cli_set_log_output_cli(const char *server_name,
const char *cli_term_name,
uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int cli_set_log_output_file(const char *server_name,
const char *cli_term_name,
uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int cli_set_log_output_remove_cli(const char *server_name,
const char *cli_term_name,
uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int cli_set_log_output_remove_file(const char *server_name,
const char *cli_term_name,
uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int send_process_command(const char *server_name,
const char *cli_term_name,
const uint32_t cli_session_id,
const char *command_global_name,
const vector<string>& argv);
int sock_serv_open();
CliClient *add_connection(int client_socket);
int delete_connection(CliClient *cli_client);
static void accept_connection(int fd, SelectorMask mask, void *thunk);
bool is_allow_cli_access(const IPvX& ipvx) const;
int _cli_socket; // The CLI listening socket
unsigned short _cli_port; // The CLI port (network-order) to
// listen on for new connections.
list<CliClient *> _client_list; // The list with the CLI clients
uint32_t _next_session_id; // Used to assign unique session IDs.
CliCommand _cli_command_root; // The root of the CLI commands
SenderProcessCallback _send_process_command_callback;
// The callback pethod that is invoked whenever a CliClient is deleted
CliClientDeleteCallback _cli_client_delete_callback;
list<IPvXNet> _enable_cli_access_subnet_list;
list<IPvXNet> _disable_cli_access_subnet_list;
};
//
// Global variables
//
//
// Global functions prototypes
//
#endif // __CLI_CLI_NODE_HH__
Generated by: pavlin on possum.icir.org on Wed Dec 11 16:50:46 2002, using kdoc 2.0a54+XORP. |