0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2025-01-07 01:21:54 +00:00

client does not work for yi sock

This commit is contained in:
Katerina Kubecova 2023-12-08 10:27:37 +01:00
parent 17b08668a1
commit b0f148b86c
4 changed files with 20 additions and 8 deletions

View File

@ -38,11 +38,13 @@
#define SERVER_READ_BUF_LEN 4096 #define SERVER_READ_BUF_LEN 4096
static char *opt_list = "s:vrl";
static char *opt_list = "s:vrlY";
static int verbose, restricted, once; static int verbose, restricted, once;
static char *init_cmd; static char *init_cmd;
static char *server_path = PATH_CONTROL_SOCKET; static char *server_path = PATH_CONTROL_SOCKET;
static char *server_path_yi = "bird-yang.ctl";
static int server_fd; static int server_fd;
static byte server_read_buf[SERVER_READ_BUF_LEN]; static byte server_read_buf[SERVER_READ_BUF_LEN];
static byte *server_read_pos = server_read_buf; static byte *server_read_pos = server_read_buf;
@ -51,6 +53,7 @@ int init = 1; /* During intial sequence */
int busy = 1; /* Executing BIRD command */ int busy = 1; /* Executing BIRD command */
int interactive; /* Whether stdin is terminal */ int interactive; /* Whether stdin is terminal */
int last_code; /* Last return code */ int last_code; /* Last return code */
int yi_mode; /* Convert to cbor and push to yi socket (and convert answer back) */
static int num_lines, skip_input; static int num_lines, skip_input;
int term_lns, term_cls; int term_lns, term_cls;
@ -61,7 +64,7 @@ int term_lns, term_cls;
static void static void
usage(char *name) usage(char *name)
{ {
fprintf(stderr, "Usage: %s [-s <control-socket>] [-v] [-r] [-l]\n", name); fprintf(stderr, "Usage: %s [-s <control-socket>] [-v] [-r] [-l] [-Y]\n", name);
exit(1); exit(1);
} }
@ -70,6 +73,7 @@ parse_args(int argc, char **argv)
{ {
int server_changed = 0; int server_changed = 0;
int c; int c;
yi_mode = 0;
while ((c = getopt(argc, argv, opt_list)) >= 0) while ((c = getopt(argc, argv, opt_list)) >= 0)
switch (c) switch (c)
@ -88,9 +92,17 @@ parse_args(int argc, char **argv)
if (!server_changed) if (!server_changed)
server_path = xbasename(server_path); server_path = xbasename(server_path);
break; break;
case 'Y':
yi_mode = 1;
if (!server_changed)
server_path = xbasename(server_path_yi);
break;
default: default:
usage(argv[0]); usage(argv[0]);
} }
yi_mode = 1;
server_path = server_path_yi; //TODO delete - only for testing purposes
fprintf(stderr, "Socket: %s \n", server_path_yi);
/* If some arguments are not options, we take it as commands */ /* If some arguments are not options, we take it as commands */
if (optind < argc) if (optind < argc)
@ -142,6 +154,8 @@ submit_server_command(char *cmd)
{ {
busy = 1; busy = 1;
num_lines = 2; num_lines = 2;
fprintf(stderr, "Socket: %s \n", server_path_yi);
fprintf(stderr, "cmd: %s \n", cmd);
server_send(cmd); server_send(cmd);
} }
@ -262,6 +276,7 @@ server_connect(void)
DIE("Unable to connect to server control socket (%s)", server_path); DIE("Unable to connect to server control socket (%s)", server_path);
if (fcntl(server_fd, F_SETFL, O_NONBLOCK) < 0) if (fcntl(server_fd, F_SETFL, O_NONBLOCK) < 0)
DIE("fcntl"); DIE("fcntl");
fprintf(stdout, "Socket: %s connected ok\n", server_path_yi);
} }

View File

@ -151,17 +151,14 @@ void write_item(struct cbor_writer *writer, int8_t major, u64 num)
{ {
major = major<<5; major = major<<5;
check_memory(writer, 10); check_memory(writer, 10);
log("writing %li %lx max for lower %lx ", num, num, ((u64)1<<(4*8))-1);
if (num > ((u64)1<<(4*8))-1) if (num > ((u64)1<<(4*8))-1)
{ // We need 8 bytes to encode the num { // We need 8 bytes to encode the num
log("loong num");
major += 0x1b; // reserving those bytes major += 0x1b; // reserving those bytes
writer->cbor[writer->pt] = major; writer->cbor[writer->pt] = major;
writer->pt++; writer->pt++;
for (int i = 7; i>=0; i--) for (int i = 7; i>=0; i--)
{ // write n-th byte of num { // write n-th byte of num
uint8_t to_write = (num>>(i*8)) & 0xff; uint8_t to_write = (num>>(i*8)) & 0xff;
log("%x", to_write);
writer->cbor[writer->pt] = to_write; writer->cbor[writer->pt] = to_write;
writer->pt++; writer->pt++;
} }
@ -175,7 +172,6 @@ void write_item(struct cbor_writer *writer, int8_t major, u64 num)
for (int i = 3; i>=0; i--) for (int i = 3; i>=0; i--)
{ // write n-th byte of num { // write n-th byte of num
uint8_t to_write = (num>>(i*8)) & 0xff; uint8_t to_write = (num>>(i*8)) & 0xff;
log("%x", to_write);
writer->cbor[writer->pt] = to_write; writer->cbor[writer->pt] = to_write;
writer->pt++; writer->pt++;
} }

View File

@ -54,13 +54,13 @@ void cbor_add_net(struct cbor_writer *writer, const net_addr *N) {
switch (n->n.type) switch (n->n.type)
{ {
case NET_IP4: case NET_IP4:
cbor_add_ipv4_prefix(writer, n->ip4.prefix, n->ip4.pxlen); cbor_add_ipv4_prefix(writer, n->ip4.prefix.addr, n->ip4.pxlen);
return; return;
case NET_IP6: case NET_IP6:
cbor_add_ipv6_prefix(writer, n->ip6.prefix, n->ip6.pxlen); cbor_add_ipv6_prefix(writer, n->ip6.prefix, n->ip6.pxlen);
return; return;
case NET_VPN4: case NET_VPN4:
cbor_add_ipv4_prefix(writer, n->vpn4.prefix, n->vpn4.pxlen); cbor_add_ipv4_prefix(writer, n->vpn4.prefix.addr, n->vpn4.pxlen);
return; return;
case NET_VPN6: case NET_VPN6:
cbor_add_ipv6_prefix(writer, n->vpn6.prefix, n->vpn6.pxlen); cbor_add_ipv6_prefix(writer, n->vpn6.prefix, n->vpn6.pxlen);

View File

@ -489,6 +489,7 @@ yi_rx(sock *s, uint size)
{ {
/* zpracuj data délky len začínající na s->rbuf */ /* zpracuj data délky len začínající na s->rbuf */
/* zapiš výsledek do s->tbuf */ /* zapiš výsledek do s->tbuf */
log("in yi rx!");
log("size tbuf %ui", s->tbsize); log("size tbuf %ui", s->tbsize);
uint tx_len = yi_process(size, s->rbuf, s->tbuf, s->tbsize); uint tx_len = yi_process(size, s->rbuf, s->tbuf, s->tbsize);
sk_send(s, tx_len); sk_send(s, tx_len);