Topology and request description data model in JSON
Reason this release was yanked:
This was a test.
Project description
Table of Contents
How to Contribute
- Ensure you're able to run the existing code in your own development environment.
- Create a descriptive GitHub issue that outlines what feature you plan to contribute.
- Clone the repository, and start from the most recent version of the develop branch.
- Name your branch using the Github issue number as a prefix along with a brief name that corresponds to your feature (e.g.,
8-how-to-contribute
). - Once satisfied with your completed and tested work, submit a pull request against the develop branch so that your code can be reviewed by the team.
Notes:
- Do not create a pull request against the master branch. The master branch is considered the production branch and must always remain stable. The master branch is periodically updated from the contents of the develop branch at the conclusion of a development cycle.
- Do not put any content (css, js, images, etc.) in the main
static
directory, instead create a directory namedstatic
in your app that can be imported into the mainstatic
directory using themanage.py collectstatic
call. - Use clear and concise naming conventions for apps, classes, functions, variables, etc. Ideally others will be able to reuse your work, and the more clear and concise your code is, the easier it is to reuse it.
- Include easy to understand documentation and complete unit/functional tests for each new feature being introduced to the project. (pytest is the recommended framework to use for testing).
AW-SDX Data Model
System
Each domain, proxied by the customized SDX-LC who communicates between the SDX-controller and the domain (1) provisioning system (eg, Kytos) and (2) monitoring system (BAPM).
Topology Models
In the whole SDX system, two types of topology models are needed:
Domain substrate description model
It's used by the intra-domain prvisioning system.
Domain declaration/advertisement model
Based on the information from the domain provisioning system, tt's abstracted/generated/passed by the SDX-LC to the SDX-controller for inter-domain topology assembly to support (a) inter-domain path computation; and (b) inter-domain path monitoring and reconfiguration. It would consist of three types of information: (1) Topology abstraction; (2) network resources available for inter-domain connections and their QoS metrics (eg, bw, latency, packet loss, vlan ranges, etc); (3) switching capability (eg, vlan, Q-in-Q, etc).
There is a service attribute in the topology object, which is an object that describes domain service meta information like owner, provisiong system, and security features.
Domain topology and state update
Topology update:
On the events of addition, removal, and/or maintenance of ports, nodes, links, an updated domain topology with version and timestamp needs to be sent to the LC and subsequently the SDX controller. A new topology object is supposed to be generated and passed on to the SDX controller.
Topology link state update
This set of updates mainly come from the domain monitoring system which is supposed to stream periodical measurement information on the links, like bandwidth, latency, and packet loss. A new link object is supposed to generated and pass on to the SDX controller.
Topology description schemas
There are defined in the schema subfolder. Some attributes of each objects are requied (Can be found in the API definition) while some are optional. Two attributes are worth of mentioning: (1) In the service object, there is a vender attribute for the domain to list device vendors that are NOT in its domain, (2) in the topology, link, node, and port objects, there is an private attibute for the domain to list attributes that need to kept private.:wq
Usage
Running tests
Run tests with:
python -m pip install -r test-requirements.txt
python -m unittest
If you want to run some specific tests:
python -m unittest -v tests.test_topology_handler
python -m unittest -v tests.test_topology_validator
Install
pip install -r requirements.txt
pip install -e .
Accompanying AW-SDX Projects
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file sdxdatamodel-0.0.1.tar.gz
.
File metadata
- Download URL: sdxdatamodel-0.0.1.tar.gz
- Upload date:
- Size: 128.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.28.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ea2f371c1b63413103d7216d77910be9afaad9ce5185aab845880e8573a2ec09 |
|
MD5 | c0a4fc26ca3a3da1545c54f7a4ec0896 |
|
BLAKE2b-256 | 237c395b757b47a08a51a47aedec5a2cf11ff950fc9ebead70b78708aa00d64f |
File details
Details for the file sdxdatamodel-0.0.1-py3-none-any.whl
.
File metadata
- Download URL: sdxdatamodel-0.0.1-py3-none-any.whl
- Upload date:
- Size: 38.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.28.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5b8a3335ae9a28e6f2c867cab0ffc33cdf6287b6daa861b8c6d696515ea61916 |
|
MD5 | fbdcb2d7425e4182d84e229ffe7ff75a |
|
BLAKE2b-256 | 3e75fdba5489ac644f08443acfa6f60f6195d752fb5c809973cbf8c7106a9f8b |