aboutsummaryrefslogtreecommitdiffstats
path: root/src/osmo_server_vty.c
diff options
context:
space:
mode:
authorHolger Hans Peter Freyther <zecke@selfish.org>2011-05-31 22:52:41 +0200
committerHolger Hans Peter Freyther <zecke@selfish.org>2011-05-31 23:42:48 +0200
commit9f6127f592c979582a4d2d34627e09cfcd439778 (patch)
tree6c4ffb1d9b37d06177f9f5f00236996e8f40549d /src/osmo_server_vty.c
parent13619dd235969126d5129e5bf129d344ed2643e2 (diff)
osmo-pcap-server: Work on the generic VTY interface for the server
Work on being able to configure clients that are allowed to connect to the server.
Diffstat (limited to 'src/osmo_server_vty.c')
-rw-r--r--src/osmo_server_vty.c115
1 files changed, 115 insertions, 0 deletions
diff --git a/src/osmo_server_vty.c b/src/osmo_server_vty.c
index fcd4b09..5d7d23d 100644
--- a/src/osmo_server_vty.c
+++ b/src/osmo_server_vty.c
@@ -21,8 +21,123 @@
*/
#include <osmo-pcap/osmo_pcap_server.h>
+#include <osmo-pcap/common.h>
+#include <osmocom/core/talloc.h>
+
+
+#define SERVER_STR "Server settings\n"
+#define CLIENT_STR "Client\n"
+
+static struct cmd_node server_node = {
+ SERVER_NODE,
+ "%s(server)#",
+ 1,
+};
+
+static int config_write_server(struct vty *vty)
+{
+ struct osmo_pcap_conn *conn;
+
+ vty_out(vty, "server%s", VTY_NEWLINE);
+
+ if (pcap_server->base_path)
+ vty_out(vty, " base-path %s%s", pcap_server->base_path, VTY_NEWLINE);
+ if (pcap_server->addr)
+ vty_out(vty, " server ip %s%s", pcap_server->addr, VTY_NEWLINE);
+ if (pcap_server->port > 0)
+ vty_out(vty, "server port %d%s", pcap_server->port, VTY_NEWLINE);
+
+ llist_for_each_entry(conn, &pcap_server->conn, entry) {
+ vty_out(vty, " client %s %s%s",
+ conn->name, conn->remote_host, VTY_NEWLINE);
+ }
+
+ return CMD_SUCCESS;
+}
+
+DEFUN(cfg_server,
+ cfg_server_cmd,
+ "server",
+ "Enter the server configuration\n")
+{
+ vty->node = SERVER_NODE;
+ return CMD_SUCCESS;
+}
+
+DEFUN(cfg_server_base,
+ cfg_server_base_cmd,
+ "base-path PATH",
+ "Base path for log files\n" "Path\n")
+{
+ talloc_free(pcap_server->base_path);
+ pcap_server->base_path = talloc_strdup(pcap_server, argv[0]);
+ return CMD_SUCCESS;
+}
+
+DEFUN(cfg_server_ip,
+ cfg_server_ip_cmd,
+ "server ip A.B.C.D",
+ SERVER_STR "Listen\n" "IP Address\n")
+{
+ talloc_free(pcap_server->addr);
+ pcap_server->addr = talloc_strdup(pcap_server, argv[0]);
+ return CMD_SUCCESS;
+}
+
+DEFUN(cfg_server_port,
+ cfg_server_port_cmd,
+ "server port <1-65535>",
+ SERVER_STR "Port\n" "Port Number\n")
+{
+ pcap_server->port = atoi(argv[0]);
+ return CMD_SUCCESS;
+}
+
+DEFUN(cfg_server_client,
+ cfg_server_client_cmd,
+ "client NAME A.B.C.D",
+ CLIENT_STR "Remote name used in filenames\n" "IP of the remote\n")
+{
+ struct osmo_pcap_conn *conn;
+ conn = osmo_pcap_server_find(pcap_server, argv[0]);
+ if (!conn) {
+ vty_out(vty, "Failed to create a pcap server.\n");
+ return CMD_WARNING;
+ }
+
+ talloc_free(conn->remote_host);
+ conn->remote_host = talloc_strdup(pcap_server, argv[0]);
+
+ return CMD_SUCCESS;
+}
+
+DEFUN(cfg_server_no_client,
+ cfg_server_no_client_cmd,
+ "no client NAME",
+ NO_STR CLIENT_STR "The name\n")
+{
+ struct osmo_pcap_conn *conn;
+ conn = osmo_pcap_server_find(pcap_server, argv[0]);
+ if (!conn) {
+ vty_out(vty, "Failed to create a pcap server.\n");
+ return CMD_WARNING;
+ }
+
+ osmo_pcap_server_delete(conn);
+ return CMD_SUCCESS;
+}
void vty_server_init(struct osmo_pcap_server *server)
{
+ install_element(CONFIG_NODE, &cfg_server_cmd);
+ install_node(&server_node, config_write_server);
+ install_default(SERVER_NODE);
+
+ install_element(SERVER_NODE, &cfg_server_base_cmd);
+ install_element(SERVER_NODE, &cfg_server_ip_cmd);
+ install_element(SERVER_NODE, &cfg_server_port_cmd);
+
+ install_element(SERVER_NODE, &cfg_server_client_cmd);
+ install_element(SERVER_NODE, &cfg_server_no_client_cmd);
}