Skip to main content

Janus DTNaaS Controller

Project description

Janus Controller

A container (Portainer Docker) controller with profiles for common Data Transfer Node (DTN) capabilities. Support DTN-as-a-Service deployments.

Build Instructions

python -m build

Upload to PyPi using

twine upload dist/*

Install Instructions

git clone https://github.com/esnet/janus.git
cd janus
pip3 install -e .

Development quick-start

Without installing any of the dependencies locally, you can use an existing Docker compose stack to run the controller and supporting services. From within the clone Janus repository:

cd janus/config
cp janus.conf.example janus.conf   <-- edit as needed

cd ../scripts
docker compose -f local-dev-compose.yml up -d

This will start the Janus controller in a development context along with supporting container images. The janus/config directory along with the relative source tree will be mounted inside the container.

volumes:
 - ./..:/opt/janus
 - ./../janus/config:/etc/janus

Edits to the source code will invoke a controller reload. Additional configuration files can be placed in the config/ subdirectory as needed, for example a kubecfg.

Adding Kubernetes config

Bind mount your K8s config file into the $HOME of the Janus controller container. For example:

volumes:
  - ./../janus/config/nrp.config:/home/janus/.kube/config

Then, when you access the Janus Web interface Endpoints view, the controller should list the resources queried from all the contexts in your K8s config.

Configuring container registry authentication

The Janus controller supports authentication to private container registries using tokens passed via the X-Registry-Auth HTTP header. The tokens are in the form of a base64 encoded dictionary containing the following attributes:

{ "username": "",
  "password": "",
  "serveraddress": ""
}

As an example, Harbor registries allow for the creation of robot accounts with secret keys. Using one of these robot accounts, a valid token for Janus/Portainer can be created as follows:

echo '{"username": "robot+dtnaas+deployer", "password": "SECRET_KEY", "serveraddress": "wharf.es.net"}' | base64 -w 0

For a single authenticated registry, this token can be passed as an environment variable when launching the controller process. In a Janus controller Docker compose file, include the following:

   ...
   environment:
      - REGISTRY_AUTH=<TOKEN>
   ...

Within the Janus settings.py file is where the registry auth dictionary is maintained to map registry servers to authentication tokens. Additional registries with their associated auth tokens may be defined as needed.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

janus_dtnaas-0.3rc1.post13.tar.gz (69.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

janus_dtnaas-0.3rc1.post13-py3-none-any.whl (78.3 kB view details)

Uploaded Python 3

File details

Details for the file janus_dtnaas-0.3rc1.post13.tar.gz.

File metadata

  • Download URL: janus_dtnaas-0.3rc1.post13.tar.gz
  • Upload date:
  • Size: 69.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.9.6 requests/2.31.0 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.66.1 CPython/3.11.2

File hashes

Hashes for janus_dtnaas-0.3rc1.post13.tar.gz
Algorithm Hash digest
SHA256 b55ec0fe388d610b32c9b8a2803b22bb2f6c13c9bf5275e262f41352991fd0e4
MD5 8514db1134c2ed66747c27b448ca06bb
BLAKE2b-256 7958a571780fd14ab3d8893631fba5acca1d0da6cd938ac1ca57051e5de94b82

See more details on using hashes here.

File details

Details for the file janus_dtnaas-0.3rc1.post13-py3-none-any.whl.

File metadata

  • Download URL: janus_dtnaas-0.3rc1.post13-py3-none-any.whl
  • Upload date:
  • Size: 78.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.9.6 requests/2.31.0 setuptools/52.0.0 requests-toolbelt/0.9.1 tqdm/4.66.1 CPython/3.11.2

File hashes

Hashes for janus_dtnaas-0.3rc1.post13-py3-none-any.whl
Algorithm Hash digest
SHA256 ba0b2cb1b2ce68f215b6ba0ecf595c2e710a88a7e1a14e4171b84d9e7c98c63b
MD5 7ba67547803751f011b1ba3d4fa79868
BLAKE2b-256 346f3675a04afcfbc76933efd55bbc284e808269380192da0ba5f27862213e0f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page