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

cbor ip addresses stored with 52/54 tag, but without yang changes

This commit is contained in:
Katerina Kubecova 2023-12-07 10:28:44 +01:00
parent 78750e197f
commit c200b7972b
5 changed files with 120 additions and 35 deletions

View File

@ -67,6 +67,59 @@ void cbor_add_int(struct cbor_writer *writer, int64_t item)
} }
} }
void cbor_add_ipv4(struct cbor_writer *writer, u32 addr)
{
write_item(writer, 6, 52); // 6 is TAG, 52 is tag number for ipv4
write_item(writer, 2, 4); // bytestring of length 4
for (int i = 3; i>=0; i--)
{
writer->cbor[writer->pt] = (addr>>(i*8)) & 0xff;
writer->pt++;
}
}
void cbor_add_ipv6(struct cbor_writer *writer, u64 addr)
{
write_item(writer, 6, 54); // 6 is TAG, 54 is tag number for ipv6
write_item(writer, 2, 8); // bytestring of length 8
for (int i = 7; i>=0; i--)
{
writer->cbor[writer->pt] = (addr>>(i*8)) & 0xff;
writer->pt++;
}
}
void cbor_add_ipv4_prefix(struct cbor_writer *writer, u32 addr, int prefix)
{
write_item(writer, 6, 52); // 6 is TAG, 52 is tag number for ipv4
cbor_open_block_with_length(writer, 2);
cbor_add_int(writer, prefix);
write_item(writer, 2, 4); // bytestring of length 4
for (int i = 3; i>=0; i--)
{
writer->cbor[writer->pt] = (addr>>(i*8)) & 0xff;
writer->pt++;
}
}
void cbor_add_ipv6_prefix(struct cbor_writer *writer, struct ip6_addr addr, int prefix)
{
write_item(writer, 6, 54); // 6 is TAG, 54 is tag number for ipv6
cbor_open_block_with_length(writer, 2);
cbor_add_int(writer, prefix);
write_item(writer, 2, 8); // bytestring of length 4
for (int j = 0; j < 4; j++)
{
for (int i = 3; i>=0; i--)
{
writer->cbor[writer->pt] = (addr.addr[j]>>(i*8)) & 0xff;
writer->pt++;
}
}
}
void cbor_add_uint(struct cbor_writer *writer, u64 item) void cbor_add_uint(struct cbor_writer *writer, u64 item)
{ {
write_item(writer, 0, item); write_item(writer, 0, item);

View File

@ -85,7 +85,7 @@ cmd_show_status_cbor(byte *tbuf, uint capacity, struct linpool *lp)
cbor_string_string(w, "version", BIRD_VERSION); cbor_string_string(w, "version", BIRD_VERSION);
cbor_add_string(w, "body"); cbor_add_string(w, "body");
cbor_open_block(w); cbor_open_block(w);
cbor_string_int(w, "router_id", config->router_id); cbor_string_ipv4(w, "router_id", config->router_id);
cbor_string_string(w, "hostname", config->hostname); cbor_string_string(w, "hostname", config->hostname);
cbor_string_int(w, "server_time", preprocess_time(current_time())); cbor_string_int(w, "server_time", preprocess_time(current_time()));
cbor_string_int(w, "last_reboot", preprocess_time(boot_time)); cbor_string_int(w, "last_reboot", preprocess_time(boot_time));

View File

@ -19,6 +19,16 @@ void cbor_string_uint(struct cbor_writer *writer, char *key, u64 value) {
cbor_add_uint(writer, value); cbor_add_uint(writer, value);
} }
void cbor_string_ipv4(struct cbor_writer *writer, char *key, u32 value) {
cbor_add_string(writer, key);
cbor_add_ipv4(writer, value);
}
void cbor_string_ipv6(struct cbor_writer *writer, char *key, u64 value) {
cbor_add_string(writer, key);
cbor_add_ipv6(writer, value);
}
void cbor_named_block_two_ints(struct cbor_writer *writer, char *key, char *name1, int val1, char *name2, int val2) { void cbor_named_block_two_ints(struct cbor_writer *writer, char *key, char *name1, int val1, char *name2, int val2) {
cbor_add_string(writer, key); cbor_add_string(writer, key);
cbor_open_block_with_length(writer, 2); cbor_open_block_with_length(writer, 2);
@ -37,3 +47,25 @@ void cbor_write_to_file(struct cbor_writer *writer, char *filename) {
fclose(write_ptr); fclose(write_ptr);
} }
void cbor_add_net(struct cbor_writer *writer, const net_addr *N) {
// Original switch comes from lib/net.c and contains more cases.
net_addr_union *n = (void *) N;
switch (n->n.type)
{
case NET_IP4:
cbor_add_ipv4_prefix(writer, n->ip4.prefix, n->ip4.pxlen);
return;
case NET_IP6:
cbor_add_ipv6_prefix(writer, n->ip6.prefix, n->ip6.pxlen);
return;
case NET_VPN4:
cbor_add_ipv4_prefix(writer, n->vpn4.prefix, n->vpn4.pxlen);
return;
case NET_VPN6:
cbor_add_ipv6_prefix(writer, n->vpn6.prefix, n->vpn6.pxlen);
return;
default:
bug("net type unsupported by cbor (yet).");
}
}

View File

@ -24,7 +24,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
cbor_add_string(w, "lsa_router"); cbor_add_string(w, "lsa_router");
cbor_open_block(w); cbor_open_block(w);
cbor_string_int(w, "router", he->lsa.rt); cbor_string_ipv4(w, "router", he->lsa.rt);
show_lsa_distance_cbor(w, he); show_lsa_distance_cbor(w, he);
cbor_add_string(w, "vlink"); cbor_add_string(w, "vlink");
@ -35,7 +35,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
if (rtl.type == LSART_VLNK) if (rtl.type == LSART_VLNK)
{ {
cbor_open_block_with_length(w, 2); cbor_open_block_with_length(w, 2);
cbor_string_int(w, "vlink", rtl.id); cbor_string_ipv4(w, "vlink", rtl.id);
cbor_string_int(w, "metric", rtl.metric); cbor_string_int(w, "metric", rtl.metric);
} }
} }
@ -49,7 +49,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
if (rtl.type == LSART_PTP) if (rtl.type == LSART_PTP)
{ {
cbor_open_block_with_length(w, 2); cbor_open_block_with_length(w, 2);
cbor_string_int(w, "router", rtl.id); cbor_string_ipv4(w, "router", rtl.id);
cbor_string_int(w, "metric", rtl.metric); cbor_string_int(w, "metric", rtl.metric);
} }
} }
@ -75,7 +75,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
cbor_open_block_with_length(w, 4); cbor_open_block_with_length(w, 4);
cbor_string_int(w, "dummy_yang_id", dummy_id); cbor_string_int(w, "dummy_yang_id", dummy_id);
cbor_string_int(w, "network", net_lsa->id & net_ln->optx); cbor_string_ipv4(w, "network", net_lsa->id & net_ln->optx);
cbor_string_int(w, "len", u32_masklen(net_ln->optx)); cbor_string_int(w, "len", u32_masklen(net_ln->optx));
cbor_string_int(w, "metric", rtl.metric); cbor_string_int(w, "metric", rtl.metric);
} }
@ -83,7 +83,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
{ {
cbor_open_block_with_length(w, 3); cbor_open_block_with_length(w, 3);
cbor_string_int(w, "dummy_yang_id", dummy_id); cbor_string_int(w, "dummy_yang_id", dummy_id);
cbor_string_int(w, "network", rtl.id); cbor_string_ipv4(w, "network", rtl.id);
cbor_string_int(w, "metric", rtl.metric); cbor_string_int(w, "metric", rtl.metric);
} }
} }
@ -91,7 +91,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
{ {
cbor_open_block_with_length(w, 4); cbor_open_block_with_length(w, 4);
cbor_string_int(w, "dummy_yang_id", dummy_id); cbor_string_int(w, "dummy_yang_id", dummy_id);
cbor_string_int(w, "network", rtl.id); cbor_string_ipv4(w, "network", rtl.id);
cbor_string_int(w, "nif", rtl.nif); cbor_string_int(w, "nif", rtl.nif);
cbor_string_int(w, "metric", rtl.metric); cbor_string_int(w, "metric", rtl.metric);
} }
@ -110,7 +110,7 @@ show_lsa_router_cbor(struct cbor_writer *w, struct ospf_proto *p, struct top_has
if (rtl.type == LSART_STUB) if (rtl.type == LSART_STUB)
{ {
cbor_open_block_with_length(w, 3); cbor_open_block_with_length(w, 3);
cbor_string_int(w, "stubnet", rtl.id); cbor_string_ipv4(w, "stubnet", rtl.id);
cbor_string_int(w, "len", u32_masklen(rtl.data)); cbor_string_int(w, "len", u32_masklen(rtl.data));
cbor_string_int(w, "metric", rtl.metric); cbor_string_int(w, "metric", rtl.metric);
} }
@ -133,15 +133,15 @@ show_lsa_network_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf
{ {
cbor_add_string(w, "ospf2"); cbor_add_string(w, "ospf2");
cbor_open_block_with_length(w, 3); cbor_open_block_with_length(w, 3);
cbor_string_int(w, "network", lsa->id & ln->optx); cbor_string_ipv4(w, "network", lsa->id & ln->optx);
cbor_string_int(w, "optx", u32_masklen(ln->optx)); cbor_string_int(w, "optx", u32_masklen(ln->optx));
cbor_string_int(w, "dr", lsa->rt); cbor_string_ipv4(w, "dr", lsa->rt);
} }
else else
{ {
cbor_add_string(w, "ospf"); cbor_add_string(w, "ospf");
cbor_open_block_with_length(w, 2); cbor_open_block_with_length(w, 2);
cbor_string_int(w, "network", lsa->rt); cbor_string_ipv4(w, "network", lsa->rt);
cbor_string_int(w, "lsa_id", lsa->id); cbor_string_int(w, "lsa_id", lsa->id);
} }
@ -152,7 +152,7 @@ show_lsa_network_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf
for (i = 0; i < lsa_net_count(lsa); i++) for (i = 0; i < lsa_net_count(lsa); i++)
{ {
cbor_open_block_with_length(w, 1); cbor_open_block_with_length(w, 1);
cbor_string_int(w, "router", ln->routers[i]); cbor_string_ipv4(w, "router", ln->routers[i]);
} }
cbor_close_block_or_list(w); cbor_close_block_or_list(w);
@ -161,7 +161,6 @@ show_lsa_network_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf
static inline void static inline void
show_lsa_sum_net_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf2, int af) show_lsa_sum_net_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf2, int af)
{ {
char str[IPA_MAX_TEXT_LENGTH + 8] = "";
net_addr net; net_addr net;
u8 pxopts; u8 pxopts;
u32 metric; u32 metric;
@ -169,8 +168,8 @@ show_lsa_sum_net_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf
lsa_parse_sum_net(he, ospf2, af, &net, &pxopts, &metric); lsa_parse_sum_net(he, ospf2, af, &net, &pxopts, &metric);
cbor_add_string(w, "lsa_sum_net"); cbor_add_string(w, "lsa_sum_net");
cbor_open_block_with_length(w, 2); cbor_open_block_with_length(w, 2);
bsprintf(str, "%N", &net); cbor_add_string(w, "net");
cbor_string_string(w, "net", str); cbor_add_net(w, &net);
cbor_string_int(w, "metric", metric); cbor_string_int(w, "metric", metric);
} }
@ -185,7 +184,7 @@ show_lsa_sum_rt_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf2
cbor_add_string(w, "lsa_sum_rt"); cbor_add_string(w, "lsa_sum_rt");
cbor_open_block_with_length(w, 2); cbor_open_block_with_length(w, 2);
cbor_string_int(w, "router", dst_rid); cbor_string_ipv4(w, "router", dst_rid);
cbor_string_int(w, "metric", metric); cbor_string_int(w, "metric", metric);
} }
@ -193,7 +192,6 @@ static inline void
show_lsa_external_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf2, int af) show_lsa_external_cbor(struct cbor_writer *w, struct top_hash_entry *he, int ospf2, int af)
{ {
struct ospf_lsa_ext_local rt; struct ospf_lsa_ext_local rt;
char str[IPA_MAX_TEXT_LENGTH + 8] = "";
cbor_add_string(w, "lsa_external"); cbor_add_string(w, "lsa_external");
cbor_open_block(w); cbor_open_block(w);
@ -204,8 +202,7 @@ show_lsa_external_cbor(struct cbor_writer *w, struct top_hash_entry *he, int osp
if (rt.fbit) if (rt.fbit)
{ {
bsprintf(str, "%N", rt.fwaddr); cbor_string_ipv4(w, "via", rt.fwaddr.addr[0]);
cbor_string_string(w, "via", str);
} }
if (rt.tag) if (rt.tag)
@ -217,9 +214,8 @@ show_lsa_external_cbor(struct cbor_writer *w, struct top_hash_entry *he, int osp
} else { } else {
cbor_string_string(w, "lsa_type", "external"); cbor_string_string(w, "lsa_type", "external");
} }
cbor_add_string(w, "rt_net");
bsprintf(str, "%N", rt.net); cbor_add_net(w, &rt.net);
cbor_string_string(w, "rt_net", str);
if(rt.ebit) if(rt.ebit)
{ {
@ -262,7 +258,6 @@ show_lsa_prefix_cbor(struct cbor_writer *w, struct top_hash_entry *he, struct to
cbor_add_string(w, "prefixes"); cbor_add_string(w, "prefixes");
cbor_open_list(w); cbor_open_list(w);
char str[IPA_MAX_TEXT_LENGTH + 8] = "";
for (i = 0; i < px->pxcount; i++) for (i = 0; i < px->pxcount; i++)
{ {
net_addr net; net_addr net;
@ -275,13 +270,13 @@ show_lsa_prefix_cbor(struct cbor_writer *w, struct top_hash_entry *he, struct to
if (px->ref_type == LSA_T_RT) if (px->ref_type == LSA_T_RT)
{ {
bsprintf(str, "%N", &net); cbor_add_string(w, "stubnet");
cbor_string_string(w, "stubnet", str); cbor_add_net(w, &net);
cbor_string_int(w, "metric", metric); cbor_string_int(w, "metric", metric);
} }
else{ else{
bsprintf(str, "%N", &net); cbor_add_string(w, "stubnet");
cbor_string_string(w, "stubnet", str); cbor_add_net(w, &net);
} }
cbor_close_block_or_list(w); cbor_close_block_or_list(w);
} }
@ -521,7 +516,7 @@ ospf_sh_state_cbor(struct cbor_writer *w, struct proto *P, int verbose, int reac
if (he->domain != last_area) if (he->domain != last_area)
{ {
cbor_string_int(w, "area", he->domain); cbor_string_ipv4(w, "area", he->domain);
last_area = he->domain; last_area = he->domain;
ix = 0; ix = 0;
} }
@ -605,7 +600,7 @@ ospf_sh_state_cbor(struct cbor_writer *w, struct proto *P, int verbose, int reac
if (he->lsa.rt != last_rt) if (he->lsa.rt != last_rt)
{ {
cbor_string_int(w, "router", he->lsa.rt); cbor_string_ipv4(w, "router", he->lsa.rt);
last_rt = he->lsa.rt; last_rt = he->lsa.rt;
} }

View File

@ -9,8 +9,13 @@ import datetime
class Command: class Command:
num = -1 num = -1
def addr_to_str(self, addr): def addr_to_str(self, addr):
return socket.inet_ntoa(struct.pack('!L', addr)) return '.'.join(str(c) for c in addr.value)
def prefix_to_str(self, addr):
str_addr = '.'.join(str(c) for c in addr.value[1])
str_addr = str_addr + "/" +addr.value[0]
return str_addr
def print_answer(self, answer): def print_answer(self, answer):
print(answer) print(answer)
@ -103,21 +108,21 @@ class Ospf(Command):
print(f"\t\trouter {self.addr_to_str(router['router'])}") print(f"\t\trouter {self.addr_to_str(router['router'])}")
def print_lsa_sum_net(self, area): def print_lsa_sum_net(self, area):
print(f"\t\txnetwork {area['net']} metric {area['metric']}") print(f"\t\txnetwork {self.prefix_to_str(area['net'])} metric {area['metric']}")
def print_lsa_sum_rt(self, area): def print_lsa_sum_rt(self, area):
print(f"\t\txrouter {self.addr_to_str(area['router'])} metric {area['metric']}") print(f"\t\txrouter {self.addr_to_str(area['router'])} metric {area['metric']}")
def print_lsa_external(self, area): def print_lsa_external(self, area):
if('lsa_type_num' in area.keys()): if('lsa_type_num' in area.keys()):
print(f"\t\t{area['lsa_type']} {self.addr_to_str(area['rt_net'])} metric{area[lsa_type_num]} {area['metric']}%s%s") print(f"\t\t{area['lsa_type']} {self.prefix_to_str(area['rt_net'])} metric{area[lsa_type_num]} {area['metric']}%s%s")
else: else:
print(f"\t\t{area['lsa_type']} {self.addr_to_str(area['rt_net'])} metric {area['metric']}{area['via']}{area['tag']}") print(f"\t\t{area['lsa_type']} {self.prefix_to_str(area['rt_net'])} metric {area['metric']}{area['via']}{area['tag']}")
def print_lsa_prefix(self, area): def print_lsa_prefix(self, area):
for prefix in area['prefixes']: for prefix in area['prefixes']:
if 'metric' in prefix.keys(): if 'metric' in prefix.keys():
print(f"\t\tstubnet {self.addr_to_str(prefix['stubnet'])} metric {prefix['metric']}") print(f"\t\tstubnet {self.prefix_to_str(prefix['stubnet'])} metric {prefix['metric']}")
def print_answer(self, answer): def print_answer(self, answer):
print() print()