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 .
Project Setup
This guide provides step-by-step instructions for setting up the Janus Controller environment.
Prerequisites
- Docker
- Docker Compose
Setup Instructions
-
Copy Configuration Files:
sudo mkdir -p /etc/janus sudo cp janus/config/* /etc/janus/ cp janus.conf.example janus.conf <-- edit as needed cd ../scripts docker compose -f local-dev-compose.yml up -d- Set the Portainer user and password in the janus.conf file.
-
Create the db.json File and Set Permissions:
sudo touch /etc/janus/db.json sudo chown 1000:1000 /etc/janus/db.json -
Create a Docker Volume:
docker volume create portainer_data -
Update and Run Docker Compose:
- Navigate to the /scripts directory in the cloned repository:
cd /path/to/janus/scripts- Edit the local-dev-compose.yml file to update the controller���s volume path to the location of the code on your local machine.
volumes: - /path/to/local/janus:/opt/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.
-
Run the Docker Compose file:
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.
-
Access Portainer:
- Open a web browser and navigate to https://localhost:<port#> (replace <port#> with the actual port number specified in the janus.conf file).
- Log in using the credentials you set earlier.
Adding Kubernetes config
-
Bind mount your K8s
configfile 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.pyfile 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
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file janus_dtnaas-0.3rc1.post15.tar.gz.
File metadata
- Download URL: janus_dtnaas-0.3rc1.post15.tar.gz
- Upload date:
- Size: 81.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
681276dbfffea21cc3e6812e714dd145c240516d7cbbfa0d08a52c0df3a71b8f
|
|
| MD5 |
7175f42c0179b9905cd42950ee2eec1d
|
|
| BLAKE2b-256 |
5764ebee7956c9150952a08165c3ec7890cb1bff4161fefdb88bb8fef0116aec
|
File details
Details for the file janus_dtnaas-0.3rc1.post15-py3-none-any.whl.
File metadata
- Download URL: janus_dtnaas-0.3rc1.post15-py3-none-any.whl
- Upload date:
- Size: 97.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
62d1525eb40d0ffc1773b313d59eca32317c3b0d4cec82262e947648cabd6c72
|
|
| MD5 |
e0f529e60fa4567077776075e7acfa9c
|
|
| BLAKE2b-256 |
01800d8eca5706f54c6e4d879de8922918b2ada994e8a8fc2b5fd49459596554
|