mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2024-12-22 09:41:54 +00:00
Maria's CLI tools and YANG/CBOR/JSON/XML experiments TMP commit
This commit is contained in:
parent
fc8e454fb6
commit
3ad8aa4eed
7
yang/JSON_CBOR.env
Normal file
7
yang/JSON_CBOR.env
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
pushd $YDIR
|
||||||
|
python3 -m venv venv
|
||||||
|
. venv/bin/activate
|
||||||
|
pip3 install yangson cbor
|
||||||
|
popd
|
||||||
|
|
||||||
|
export PYTHONPATH="/home/maria/yang/yangson:$PYTHONPATH"
|
@ -1,20 +1,72 @@
|
|||||||
from yangson import DataModel
|
from yangson import DataModel
|
||||||
|
from yangson.exceptions import InstanceValueError
|
||||||
|
from xml.etree.ElementTree import ElementTree
|
||||||
|
|
||||||
|
import ipaddress
|
||||||
|
|
||||||
import cbor
|
import cbor
|
||||||
import json
|
import json
|
||||||
|
from xml.etree.ElementTree import ElementTree
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
class IPv6ClassTag(cbor.ClassTag):
|
||||||
|
def __init__(self, tag_number=54, class_type=ipaddress.IPv6Address):
|
||||||
|
super().__init__(tag_number, class_type, lambda ip: ip.packed, lambda data: ipaddress.IPv6Address(data))
|
||||||
|
|
||||||
|
cbor_transcoder = cbor.TagMapper([
|
||||||
|
IPv6ClassTag(),
|
||||||
|
])
|
||||||
|
|
||||||
class Message:
|
class Message:
|
||||||
def __init__(self, filename, _type):
|
def __init__(self, filename, _type):
|
||||||
self.filename = filename
|
self.filename = filename
|
||||||
with open(self.filename, "rb") as sf:
|
with open(self.filename, "rb") as sf:
|
||||||
self.raw = { "json": json, "cbor": cbor }[_type].load(sf)
|
if _type == "json":
|
||||||
|
self.raw = json.load(sf)
|
||||||
|
elif _type == "cbor":
|
||||||
|
self.raw = cbor_transcoder.load(sf)
|
||||||
|
elif _type == "xml":
|
||||||
|
self.xml = ElementTree()
|
||||||
|
self.xml.parse(sf)
|
||||||
|
else:
|
||||||
|
raise Exception()
|
||||||
|
|
||||||
cwd = os.getcwd()
|
cwd = os.getcwd()
|
||||||
os.chdir(os.path.dirname(sys.modules[__name__].__file__))
|
os.chdir(os.path.dirname(sys.modules[__name__].__file__))
|
||||||
self.dm = DataModel.from_file('yang-library.json')
|
# self.dm = DataModel.from_file('yang-library.json', [".", "/usr/share/yang/modules/libyang/"])
|
||||||
|
self.dm = DataModel.from_file('yang-library.json', ["."])
|
||||||
|
print(self.dm, type(self.dm))
|
||||||
|
at = self.dm.get_schema_node("test_ip:message/address").type
|
||||||
|
ft = self.dm.get_schema_node("test_ip:message/foo").type
|
||||||
|
print(at, type(at), at.types)
|
||||||
|
print(ft, type(ft))
|
||||||
os.chdir(cwd)
|
os.chdir(cwd)
|
||||||
self.data = self.dm.from_raw(self.raw)
|
if _type == "xml":
|
||||||
|
self.data = self.dm.from_xml(self.xml.getroot())
|
||||||
|
else:
|
||||||
|
self.data = self.dm.from_raw(self.raw)
|
||||||
|
print(self.data, type(self.data))
|
||||||
|
t = self.data["test_ip:message"]["address"]
|
||||||
|
print(t, type(t))
|
||||||
self.data.validate()
|
self.data.validate()
|
||||||
|
|
||||||
|
def unnodify(cls, what):
|
||||||
|
print("unnodify", what, type(what))
|
||||||
|
try:
|
||||||
|
return { i: cls.unnodify(what[i]) for i in what }
|
||||||
|
except InstanceValueError as e:
|
||||||
|
if str(e).endswith(" is a scalar instance"):
|
||||||
|
return what.value
|
||||||
|
raise e
|
||||||
|
|
||||||
|
def dump_cbor(self, file, **kwargs):
|
||||||
|
cbor_transcoder.dump(self.unnodify(self.data), file, **kwargs)
|
||||||
|
|
||||||
|
def dump_json(self, file, **kwargs):
|
||||||
|
json.dump(self.data.raw_value(), file, **kwargs)
|
||||||
|
|
||||||
|
def dump_xml(self, file):
|
||||||
|
et = ElementTree(self.data.to_xml())
|
||||||
|
et.write(file, encoding="unicode")
|
||||||
|
@ -1,9 +1,4 @@
|
|||||||
YDIR=$(dirname $0)
|
YDIR=$(dirname $0)
|
||||||
|
. "$YDIR"/JSON_CBOR.env
|
||||||
pushd $YDIR
|
|
||||||
python3 -m venv venv
|
|
||||||
. venv/bin/activate
|
|
||||||
pip3 install yangson cbor
|
|
||||||
popd
|
|
||||||
|
|
||||||
python3 $YDIR/cbor-json-yang.py "$@"
|
python3 $YDIR/cbor-json-yang.py "$@"
|
||||||
|
@ -8,6 +8,6 @@ import JSON_CBOR
|
|||||||
|
|
||||||
msg = JSON_CBOR.Message(sys.argv[1], "cbor")
|
msg = JSON_CBOR.Message(sys.argv[1], "cbor")
|
||||||
with open(sys.argv[2], "w") as of:
|
with open(sys.argv[2], "w") as of:
|
||||||
json.dump(msg.raw, of, indent=2)
|
msg.dump_json(of, indent=2)
|
||||||
|
|
||||||
print("OK")
|
print("OK")
|
||||||
|
4
yang/cbor-xml-yang
Executable file
4
yang/cbor-xml-yang
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
YDIR=$(dirname $0)
|
||||||
|
. "$YDIR"/JSON_CBOR.env
|
||||||
|
|
||||||
|
python3 $YDIR/cbor-xml-yang.py "$@"
|
13
yang/cbor-xml-yang.py
Normal file
13
yang/cbor-xml-yang.py
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import cbor
|
||||||
|
#import json
|
||||||
|
import sys
|
||||||
|
|
||||||
|
import JSON_CBOR
|
||||||
|
|
||||||
|
#print(sys.argv[1])
|
||||||
|
|
||||||
|
msg = JSON_CBOR.Message(sys.argv[1], "cbor")
|
||||||
|
with open(sys.argv[2], "w") as of:
|
||||||
|
msg.dump_xml(of)
|
||||||
|
|
||||||
|
print("OK")
|
7
yang/cbor.yang
Normal file
7
yang/cbor.yang
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
module cbor {
|
||||||
|
prefix "cbor";
|
||||||
|
extension tag {
|
||||||
|
description "Use this tag while encoding to cbor";
|
||||||
|
argument "number";
|
||||||
|
}
|
||||||
|
}
|
474
yang/ietf-inet-types@2024-01-04.yang
Normal file
474
yang/ietf-inet-types@2024-01-04.yang
Normal file
@ -0,0 +1,474 @@
|
|||||||
|
module ietf-inet-types {
|
||||||
|
|
||||||
|
namespace "urn:ietf:params:xml:ns:yang:ietf-inet-types";
|
||||||
|
prefix "inet";
|
||||||
|
|
||||||
|
organization
|
||||||
|
"IETF NETMOD (NETCONF Data Modeling Language) Working Group";
|
||||||
|
|
||||||
|
contact
|
||||||
|
"WG Web: <http://tools.ietf.org/wg/netmod/>
|
||||||
|
WG List: <mailto:netmod@ietf.org>
|
||||||
|
|
||||||
|
WG Chair: David Kessens
|
||||||
|
<mailto:david.kessens@nsn.com>
|
||||||
|
|
||||||
|
WG Chair: Juergen Schoenwaelder
|
||||||
|
<mailto:j.schoenwaelder@jacobs-university.de>
|
||||||
|
|
||||||
|
Editor: Juergen Schoenwaelder
|
||||||
|
<mailto:j.schoenwaelder@jacobs-university.de>";
|
||||||
|
|
||||||
|
description
|
||||||
|
"This module contains a collection of generally useful derived
|
||||||
|
YANG data types for Internet addresses and related things.
|
||||||
|
|
||||||
|
Copyright (c) 2013 IETF Trust and the persons identified as
|
||||||
|
authors of the code. All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or
|
||||||
|
without modification, is permitted pursuant to, and subject
|
||||||
|
to the license terms contained in, the Simplified BSD License
|
||||||
|
set forth in Section 4.c of the IETF Trust's Legal Provisions
|
||||||
|
Relating to IETF Documents
|
||||||
|
(http://trustee.ietf.org/license-info).
|
||||||
|
|
||||||
|
This version of this YANG module is part of RFC 6991; see
|
||||||
|
the RFC itself for full legal notices.";
|
||||||
|
|
||||||
|
revision 2024-01-04 {
|
||||||
|
description
|
||||||
|
"This revision adds CBOR encoding tags";
|
||||||
|
reference
|
||||||
|
"Not even a draft";
|
||||||
|
}
|
||||||
|
|
||||||
|
revision 2013-07-15 {
|
||||||
|
description
|
||||||
|
"This revision adds the following new data types:
|
||||||
|
- ip-address-no-zone
|
||||||
|
- ipv4-address-no-zone
|
||||||
|
- ipv6-address-no-zone";
|
||||||
|
reference
|
||||||
|
"RFC 6991: Common YANG Data Types";
|
||||||
|
}
|
||||||
|
|
||||||
|
revision 2010-09-24 {
|
||||||
|
description
|
||||||
|
"Initial revision.";
|
||||||
|
reference
|
||||||
|
"RFC 6021: Common YANG Data Types";
|
||||||
|
}
|
||||||
|
|
||||||
|
import cbor {
|
||||||
|
prefix "cbor";
|
||||||
|
}
|
||||||
|
|
||||||
|
/*** collection of types related to protocol fields ***/
|
||||||
|
|
||||||
|
typedef ip-version {
|
||||||
|
type enumeration {
|
||||||
|
enum unknown {
|
||||||
|
value "0";
|
||||||
|
description
|
||||||
|
"An unknown or unspecified version of the Internet
|
||||||
|
protocol.";
|
||||||
|
}
|
||||||
|
enum ipv4 {
|
||||||
|
value "1";
|
||||||
|
description
|
||||||
|
"The IPv4 protocol as defined in RFC 791.";
|
||||||
|
}
|
||||||
|
enum ipv6 {
|
||||||
|
value "2";
|
||||||
|
description
|
||||||
|
"The IPv6 protocol as defined in RFC 2460.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"This value represents the version of the IP protocol.
|
||||||
|
|
||||||
|
In the value set and its semantics, this type is equivalent
|
||||||
|
to the InetVersion textual convention of the SMIv2.";
|
||||||
|
reference
|
||||||
|
"RFC 791: Internet Protocol
|
||||||
|
RFC 2460: Internet Protocol, Version 6 (IPv6) Specification
|
||||||
|
RFC 4001: Textual Conventions for Internet Network Addresses";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef dscp {
|
||||||
|
type uint8 {
|
||||||
|
range "0..63";
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The dscp type represents a Differentiated Services Code Point
|
||||||
|
that may be used for marking packets in a traffic stream.
|
||||||
|
In the value set and its semantics, this type is equivalent
|
||||||
|
to the Dscp textual convention of the SMIv2.";
|
||||||
|
reference
|
||||||
|
"RFC 3289: Management Information Base for the Differentiated
|
||||||
|
Services Architecture
|
||||||
|
RFC 2474: Definition of the Differentiated Services Field
|
||||||
|
(DS Field) in the IPv4 and IPv6 Headers
|
||||||
|
RFC 2780: IANA Allocation Guidelines For Values In
|
||||||
|
the Internet Protocol and Related Headers";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv6-flow-label {
|
||||||
|
type uint32 {
|
||||||
|
range "0..1048575";
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The ipv6-flow-label type represents the flow identifier or Flow
|
||||||
|
Label in an IPv6 packet header that may be used to
|
||||||
|
discriminate traffic flows.
|
||||||
|
|
||||||
|
In the value set and its semantics, this type is equivalent
|
||||||
|
to the IPv6FlowLabel textual convention of the SMIv2.";
|
||||||
|
reference
|
||||||
|
"RFC 3595: Textual Conventions for IPv6 Flow Label
|
||||||
|
RFC 2460: Internet Protocol, Version 6 (IPv6) Specification";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef port-number {
|
||||||
|
type uint16 {
|
||||||
|
range "0..65535";
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The port-number type represents a 16-bit port number of an
|
||||||
|
Internet transport-layer protocol such as UDP, TCP, DCCP, or
|
||||||
|
SCTP. Port numbers are assigned by IANA. A current list of
|
||||||
|
all assignments is available from <http://www.iana.org/>.
|
||||||
|
|
||||||
|
Note that the port number value zero is reserved by IANA. In
|
||||||
|
situations where the value zero does not make sense, it can
|
||||||
|
be excluded by subtyping the port-number type.
|
||||||
|
In the value set and its semantics, this type is equivalent
|
||||||
|
to the InetPortNumber textual convention of the SMIv2.";
|
||||||
|
reference
|
||||||
|
"RFC 768: User Datagram Protocol
|
||||||
|
RFC 793: Transmission Control Protocol
|
||||||
|
RFC 4960: Stream Control Transmission Protocol
|
||||||
|
RFC 4340: Datagram Congestion Control Protocol (DCCP)
|
||||||
|
RFC 4001: Textual Conventions for Internet Network Addresses";
|
||||||
|
}
|
||||||
|
|
||||||
|
/*** collection of types related to autonomous systems ***/
|
||||||
|
|
||||||
|
typedef as-number {
|
||||||
|
type uint32;
|
||||||
|
description
|
||||||
|
"The as-number type represents autonomous system numbers
|
||||||
|
which identify an Autonomous System (AS). An AS is a set
|
||||||
|
of routers under a single technical administration, using
|
||||||
|
an interior gateway protocol and common metrics to route
|
||||||
|
packets within the AS, and using an exterior gateway
|
||||||
|
protocol to route packets to other ASes. IANA maintains
|
||||||
|
the AS number space and has delegated large parts to the
|
||||||
|
regional registries.
|
||||||
|
|
||||||
|
Autonomous system numbers were originally limited to 16
|
||||||
|
bits. BGP extensions have enlarged the autonomous system
|
||||||
|
number space to 32 bits. This type therefore uses an uint32
|
||||||
|
base type without a range restriction in order to support
|
||||||
|
a larger autonomous system number space.
|
||||||
|
|
||||||
|
In the value set and its semantics, this type is equivalent
|
||||||
|
to the InetAutonomousSystemNumber textual convention of
|
||||||
|
the SMIv2.";
|
||||||
|
reference
|
||||||
|
"RFC 1930: Guidelines for creation, selection, and registration
|
||||||
|
of an Autonomous System (AS)
|
||||||
|
RFC 4271: A Border Gateway Protocol 4 (BGP-4)
|
||||||
|
RFC 4001: Textual Conventions for Internet Network Addresses
|
||||||
|
RFC 6793: BGP Support for Four-Octet Autonomous System (AS)
|
||||||
|
Number Space";
|
||||||
|
}
|
||||||
|
|
||||||
|
/*** collection of types related to IP addresses and hostnames ***/
|
||||||
|
|
||||||
|
typedef ip-address {
|
||||||
|
type union {
|
||||||
|
type inet:ipv4-address;
|
||||||
|
type inet:ipv6-address;
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The ip-address type represents an IP address and is IP
|
||||||
|
version neutral. The format of the textual representation
|
||||||
|
implies the IP version. This type supports scoped addresses
|
||||||
|
by allowing zone identifiers in the address format.";
|
||||||
|
reference
|
||||||
|
"RFC 4007: IPv6 Scoped Address Architecture";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv4-address {
|
||||||
|
type string {
|
||||||
|
pattern
|
||||||
|
'(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
|
||||||
|
+ '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
|
||||||
|
+ '(%[\p{N}\p{L}]+)?';
|
||||||
|
}
|
||||||
|
cbor:tag "52";
|
||||||
|
description
|
||||||
|
"The ipv4-address type represents an IPv4 address in
|
||||||
|
dotted-quad notation. The IPv4 address may include a zone
|
||||||
|
index, separated by a % sign.
|
||||||
|
|
||||||
|
The zone index is used to disambiguate identical address
|
||||||
|
values. For link-local addresses, the zone index will
|
||||||
|
typically be the interface index number or the name of an
|
||||||
|
interface. If the zone index is not present, the default
|
||||||
|
zone of the device will be used.
|
||||||
|
|
||||||
|
The canonical format for the zone index is the numerical
|
||||||
|
format";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv6-address {
|
||||||
|
type string {
|
||||||
|
pattern '((:|[0-9a-fA-F]{0,4}):)([0-9a-fA-F]{0,4}:){0,5}'
|
||||||
|
+ '((([0-9a-fA-F]{0,4}:)?(:|[0-9a-fA-F]{0,4}))|'
|
||||||
|
+ '(((25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])\.){3}'
|
||||||
|
+ '(25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])))'
|
||||||
|
+ '(%[\p{N}\p{L}]+)?';
|
||||||
|
pattern '(([^:]+:){6}(([^:]+:[^:]+)|(.*\..*)))|'
|
||||||
|
+ '((([^:]+:)*[^:]+)?::(([^:]+:)*[^:]+)?)'
|
||||||
|
+ '(%.+)?';
|
||||||
|
}
|
||||||
|
cbor:tag "54";
|
||||||
|
description
|
||||||
|
"The ipv6-address type represents an IPv6 address in full,
|
||||||
|
mixed, shortened, and shortened-mixed notation. The IPv6
|
||||||
|
address may include a zone index, separated by a % sign.
|
||||||
|
|
||||||
|
The zone index is used to disambiguate identical address
|
||||||
|
values. For link-local addresses, the zone index will
|
||||||
|
typically be the interface index number or the name of an
|
||||||
|
interface. If the zone index is not present, the default
|
||||||
|
zone of the device will be used.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
The canonical format of IPv6 addresses uses the textual
|
||||||
|
representation defined in Section 4 of RFC 5952. The
|
||||||
|
canonical format for the zone index is the numerical
|
||||||
|
format as described in Section 11.2 of RFC 4007.";
|
||||||
|
reference
|
||||||
|
"RFC 4291: IP Version 6 Addressing Architecture
|
||||||
|
RFC 4007: IPv6 Scoped Address Architecture
|
||||||
|
RFC 5952: A Recommendation for IPv6 Address Text
|
||||||
|
Representation";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ip-address-no-zone {
|
||||||
|
type union {
|
||||||
|
type inet:ipv4-address-no-zone;
|
||||||
|
type inet:ipv6-address-no-zone;
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The ip-address-no-zone type represents an IP address and is
|
||||||
|
IP version neutral. The format of the textual representation
|
||||||
|
implies the IP version. This type does not support scoped
|
||||||
|
addresses since it does not allow zone identifiers in the
|
||||||
|
address format.";
|
||||||
|
reference
|
||||||
|
"RFC 4007: IPv6 Scoped Address Architecture";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv4-address-no-zone {
|
||||||
|
type inet:ipv4-address {
|
||||||
|
pattern '[0-9\.]*';
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"An IPv4 address without a zone index. This type, derived from
|
||||||
|
ipv4-address, may be used in situations where the zone is
|
||||||
|
known from the context and hence no zone index is needed.";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv6-address-no-zone {
|
||||||
|
type inet:ipv6-address {
|
||||||
|
pattern '[0-9a-fA-F:\.]*';
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"An IPv6 address without a zone index. This type, derived from
|
||||||
|
ipv6-address, may be used in situations where the zone is
|
||||||
|
known from the context and hence no zone index is needed.";
|
||||||
|
reference
|
||||||
|
"RFC 4291: IP Version 6 Addressing Architecture
|
||||||
|
RFC 4007: IPv6 Scoped Address Architecture
|
||||||
|
RFC 5952: A Recommendation for IPv6 Address Text
|
||||||
|
Representation";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ip-prefix {
|
||||||
|
type union {
|
||||||
|
type inet:ipv4-prefix;
|
||||||
|
type inet:ipv6-prefix;
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The ip-prefix type represents an IP prefix and is IP
|
||||||
|
version neutral. The format of the textual representations
|
||||||
|
implies the IP version.";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv4-prefix {
|
||||||
|
type string {
|
||||||
|
pattern
|
||||||
|
'(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
|
||||||
|
+ '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
|
||||||
|
+ '/(([0-9])|([1-2][0-9])|(3[0-2]))';
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The ipv4-prefix type represents an IPv4 address prefix.
|
||||||
|
The prefix length is given by the number following the
|
||||||
|
slash character and must be less than or equal to 32.
|
||||||
|
|
||||||
|
A prefix length value of n corresponds to an IP address
|
||||||
|
mask that has n contiguous 1-bits from the most
|
||||||
|
significant bit (MSB) and all other bits set to 0.
|
||||||
|
|
||||||
|
The canonical format of an IPv4 prefix has all bits of
|
||||||
|
the IPv4 address set to zero that are not part of the
|
||||||
|
IPv4 prefix.";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef ipv6-prefix {
|
||||||
|
type string {
|
||||||
|
pattern '((:|[0-9a-fA-F]{0,4}):)([0-9a-fA-F]{0,4}:){0,5}'
|
||||||
|
+ '((([0-9a-fA-F]{0,4}:)?(:|[0-9a-fA-F]{0,4}))|'
|
||||||
|
+ '(((25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])\.){3}'
|
||||||
|
+ '(25[0-5]|2[0-4][0-9]|[01]?[0-9]?[0-9])))'
|
||||||
|
+ '(/(([0-9])|([0-9]{2})|(1[0-1][0-9])|(12[0-8])))';
|
||||||
|
pattern '(([^:]+:){6}(([^:]+:[^:]+)|(.*\..*)))|'
|
||||||
|
+ '((([^:]+:)*[^:]+)?::(([^:]+:)*[^:]+)?)'
|
||||||
|
+ '(/.+)';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
description
|
||||||
|
"The ipv6-prefix type represents an IPv6 address prefix.
|
||||||
|
The prefix length is given by the number following the
|
||||||
|
slash character and must be less than or equal to 128.
|
||||||
|
|
||||||
|
A prefix length value of n corresponds to an IP address
|
||||||
|
mask that has n contiguous 1-bits from the most
|
||||||
|
significant bit (MSB) and all other bits set to 0.
|
||||||
|
|
||||||
|
The IPv6 address should have all bits that do not belong
|
||||||
|
to the prefix set to zero.
|
||||||
|
|
||||||
|
The canonical format of an IPv6 prefix has all bits of
|
||||||
|
the IPv6 address set to zero that are not part of the
|
||||||
|
IPv6 prefix. Furthermore, the IPv6 address is represented
|
||||||
|
as defined in Section 4 of RFC 5952.";
|
||||||
|
reference
|
||||||
|
"RFC 5952: A Recommendation for IPv6 Address Text
|
||||||
|
Representation";
|
||||||
|
}
|
||||||
|
|
||||||
|
/*** collection of domain name and URI types ***/
|
||||||
|
|
||||||
|
typedef domain-name {
|
||||||
|
type string {
|
||||||
|
pattern
|
||||||
|
'((([a-zA-Z0-9_]([a-zA-Z0-9\-_]){0,61})?[a-zA-Z0-9]\.)*'
|
||||||
|
+ '([a-zA-Z0-9_]([a-zA-Z0-9\-_]){0,61})?[a-zA-Z0-9]\.?)'
|
||||||
|
+ '|\.';
|
||||||
|
length "1..253";
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The domain-name type represents a DNS domain name. The
|
||||||
|
name SHOULD be fully qualified whenever possible.
|
||||||
|
|
||||||
|
Internet domain names are only loosely specified. Section
|
||||||
|
3.5 of RFC 1034 recommends a syntax (modified in Section
|
||||||
|
2.1 of RFC 1123). The pattern above is intended to allow
|
||||||
|
for current practice in domain name use, and some possible
|
||||||
|
future expansion. It is designed to hold various types of
|
||||||
|
domain names, including names used for A or AAAA records
|
||||||
|
(host names) and other records, such as SRV records. Note
|
||||||
|
that Internet host names have a stricter syntax (described
|
||||||
|
in RFC 952) than the DNS recommendations in RFCs 1034 and
|
||||||
|
1123, and that systems that want to store host names in
|
||||||
|
schema nodes using the domain-name type are recommended to
|
||||||
|
adhere to this stricter standard to ensure interoperability.
|
||||||
|
|
||||||
|
The encoding of DNS names in the DNS protocol is limited
|
||||||
|
to 255 characters. Since the encoding consists of labels
|
||||||
|
prefixed by a length bytes and there is a trailing NULL
|
||||||
|
byte, only 253 characters can appear in the textual dotted
|
||||||
|
notation.
|
||||||
|
|
||||||
|
The description clause of schema nodes using the domain-name
|
||||||
|
type MUST describe when and how these names are resolved to
|
||||||
|
IP addresses. Note that the resolution of a domain-name value
|
||||||
|
may require to query multiple DNS records (e.g., A for IPv4
|
||||||
|
and AAAA for IPv6). The order of the resolution process and
|
||||||
|
which DNS record takes precedence can either be defined
|
||||||
|
explicitly or may depend on the configuration of the
|
||||||
|
resolver.
|
||||||
|
|
||||||
|
Domain-name values use the US-ASCII encoding. Their canonical
|
||||||
|
format uses lowercase US-ASCII characters. Internationalized
|
||||||
|
domain names MUST be A-labels as per RFC 5890.";
|
||||||
|
reference
|
||||||
|
"RFC 952: DoD Internet Host Table Specification
|
||||||
|
RFC 1034: Domain Names - Concepts and Facilities
|
||||||
|
RFC 1123: Requirements for Internet Hosts -- Application
|
||||||
|
and Support
|
||||||
|
RFC 2782: A DNS RR for specifying the location of services
|
||||||
|
(DNS SRV)
|
||||||
|
RFC 5890: Internationalized Domain Names in Applications
|
||||||
|
(IDNA): Definitions and Document Framework";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef host {
|
||||||
|
type union {
|
||||||
|
type inet:ip-address;
|
||||||
|
type inet:domain-name;
|
||||||
|
}
|
||||||
|
description
|
||||||
|
"The host type represents either an IP address or a DNS
|
||||||
|
domain name.";
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef uri {
|
||||||
|
type string;
|
||||||
|
description
|
||||||
|
"The uri type represents a Uniform Resource Identifier
|
||||||
|
(URI) as defined by STD 66.
|
||||||
|
|
||||||
|
Objects using the uri type MUST be in US-ASCII encoding,
|
||||||
|
and MUST be normalized as described by RFC 3986 Sections
|
||||||
|
6.2.1, 6.2.2.1, and 6.2.2.2. All unnecessary
|
||||||
|
percent-encoding is removed, and all case-insensitive
|
||||||
|
characters are set to lowercase except for hexadecimal
|
||||||
|
digits, which are normalized to uppercase as described in
|
||||||
|
Section 6.2.2.1.
|
||||||
|
|
||||||
|
The purpose of this normalization is to help provide
|
||||||
|
unique URIs. Note that this normalization is not
|
||||||
|
sufficient to provide uniqueness. Two URIs that are
|
||||||
|
textually distinct after this normalization may still be
|
||||||
|
equivalent.
|
||||||
|
|
||||||
|
Objects using the uri type may restrict the schemes that
|
||||||
|
they permit. For example, 'data:' and 'urn:' schemes
|
||||||
|
might not be appropriate.
|
||||||
|
|
||||||
|
A zero-length URI is not a valid URI. This can be used to
|
||||||
|
express 'URI absent' where required.
|
||||||
|
|
||||||
|
In the value set and its semantics, this type is equivalent
|
||||||
|
to the Uri SMIv2 textual convention defined in RFC 5017.";
|
||||||
|
reference
|
||||||
|
"RFC 3986: Uniform Resource Identifier (URI): Generic Syntax
|
||||||
|
RFC 3305: Report from the Joint W3C/IETF URI Planning Interest
|
||||||
|
Group: Uniform Resource Identifiers (URIs), URLs,
|
||||||
|
and Uniform Resource Names (URNs): Clarifications
|
||||||
|
and Recommendations
|
||||||
|
RFC 5017: MIB Textual Conventions for Uniform Resource
|
||||||
|
Identifiers (URIs)";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,9 +1,4 @@
|
|||||||
YDIR=$(dirname $0)
|
YDIR=$(dirname $0)
|
||||||
|
. "$YDIR"/JSON_CBOR.env
|
||||||
pushd $YDIR
|
|
||||||
python3 -m venv venv
|
|
||||||
. venv/bin/activate
|
|
||||||
pip3 install yangson cbor
|
|
||||||
popd
|
|
||||||
|
|
||||||
python3 $YDIR/json-cbor-yang.py "$@"
|
python3 $YDIR/json-cbor-yang.py "$@"
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
import cbor
|
|
||||||
import json
|
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
import JSON_CBOR
|
import JSON_CBOR
|
||||||
@ -8,6 +6,6 @@ import JSON_CBOR
|
|||||||
|
|
||||||
msg = JSON_CBOR.Message(sys.argv[1], "json")
|
msg = JSON_CBOR.Message(sys.argv[1], "json")
|
||||||
with open(sys.argv[2], "wb") as of:
|
with open(sys.argv[2], "wb") as of:
|
||||||
cbor.dump(msg.raw, of)
|
msg.dump_cbor(of)
|
||||||
|
|
||||||
print("OK")
|
print("OK")
|
||||||
|
BIN
yang/test_ip.cbor
Normal file
BIN
yang/test_ip.cbor
Normal file
Binary file not shown.
6
yang/test_ip.json
Normal file
6
yang/test_ip.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"test_ip:message": {
|
||||||
|
"address": "2001:db8::dead:beef",
|
||||||
|
"foo": 42
|
||||||
|
}
|
||||||
|
}
|
1
yang/test_ip.xml
Normal file
1
yang/test_ip.xml
Normal file
@ -0,0 +1 @@
|
|||||||
|
<content-data xmlns="urn:ietf:params:xml:ns:yang:ietf-yang-instance-data"><message xmlns="https://bird.nic.cz/yang/v2.15/cli-debug"><address>2001:db8::dead:beef</address><foo>42</foo></message></content-data>
|
21
yang/test_ip.yang
Normal file
21
yang/test_ip.yang
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
module test_ip {
|
||||||
|
|
||||||
|
namespace "https://bird.nic.cz/yang/v2.15/cli-debug";
|
||||||
|
|
||||||
|
prefix "test_ip";
|
||||||
|
|
||||||
|
description "testing IP address formatting";
|
||||||
|
|
||||||
|
import ietf-inet-types {
|
||||||
|
prefix "inet";
|
||||||
|
}
|
||||||
|
|
||||||
|
container message {
|
||||||
|
leaf address {
|
||||||
|
type inet:ip-address;
|
||||||
|
}
|
||||||
|
leaf foo {
|
||||||
|
type int8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
4
yang/xml-cbor-yang
Executable file
4
yang/xml-cbor-yang
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
YDIR=$(dirname $0)
|
||||||
|
. "$YDIR"/JSON_CBOR.env
|
||||||
|
|
||||||
|
python3 $YDIR/xml-cbor-yang.py "$@"
|
11
yang/xml-cbor-yang.py
Normal file
11
yang/xml-cbor-yang.py
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import sys
|
||||||
|
|
||||||
|
import JSON_CBOR
|
||||||
|
|
||||||
|
#print(sys.argv[1])
|
||||||
|
|
||||||
|
msg = JSON_CBOR.Message(sys.argv[1], "xml")
|
||||||
|
with open(sys.argv[2], "wb") as of:
|
||||||
|
msg.dump_cbor(of)
|
||||||
|
|
||||||
|
print("OK")
|
@ -2,6 +2,18 @@
|
|||||||
"ietf-yang-library:modules-state": {
|
"ietf-yang-library:modules-state": {
|
||||||
"module-set-id": "12345678abcdef1cefd14622032c432fa598540e",
|
"module-set-id": "12345678abcdef1cefd14622032c432fa598540e",
|
||||||
"module": [
|
"module": [
|
||||||
|
{
|
||||||
|
"name": "cbor",
|
||||||
|
"revision": "",
|
||||||
|
"namespace": "tmp",
|
||||||
|
"conformance-type": "import"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "ietf-inet-types",
|
||||||
|
"revision": "2024-01-04",
|
||||||
|
"namespace": "urn:ietf:params:xml:ns:yang:ietf-inet-types",
|
||||||
|
"conformance-type": "import"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "show_memory",
|
"name": "show_memory",
|
||||||
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
||||||
@ -14,12 +26,6 @@
|
|||||||
"revision": "",
|
"revision": "",
|
||||||
"conformance-type": "implement"
|
"conformance-type": "implement"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "show_symbols",
|
|
||||||
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
|
||||||
"revision": "",
|
|
||||||
"conformance-type": "implement"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "show_ospf",
|
"name": "show_ospf",
|
||||||
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
||||||
@ -37,6 +43,12 @@
|
|||||||
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
||||||
"revision": "",
|
"revision": "",
|
||||||
"conformance-type": "implement"
|
"conformance-type": "implement"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "test_ip",
|
||||||
|
"namespace": "https://bird.nic.cz/yang/v2.15/cli-debug",
|
||||||
|
"revision": "",
|
||||||
|
"conformance-type": "implement"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user