Modular toolbox
Project description
Clyjin
System configuration toolbox
Modules
Clyjin has set of builtin modules to work with, to call a module use:
python3 -m clyjin {module_name} {module_args}
modules.API
Module deploying web server to display OpenAPI (A.K.A Swagger) specification UI for set of paths to api entrypoints defined in given file.
Usage:
python3 -m clyjin api -f {path/to/file/with/api/paths.txt}
Structure of paths.txt
might be something like:
/home/user/project1/api/main.yml
/home/user/project2/api/main.yml
/home/user/project3/api/main.yml
All paths defined in paths.txt
are fetched, and if they hold correct OpenAPI
yaml spec, UI representation is built.
It is mandatory for now for API entrypoint to hold info.title
info inside
according entrypoint spec. This is required to build route to this file.
For example, main.yml
:
openapi: '3.0.2'
info:
title: MyProject
version: package
...
will produce OpenAPI specification on route /myproject
(or any cased route,
e.g. /MyPrOjEcT
since lower casing is performed before api names matching).
⚠️ WARNING
Accessing raw yaml files for main entrypoint and related dependencies is allowed across all filesystem of web-server's host (of course, where user launched the web-server has an access). Although, the validation for having exactly this api specified inpaths.txt
is done, this is not the best practice to have, because validation is checking and "pinging" requested target file.
Use on your own risk in public-faced servers.
Important notes
-
Unfortunately, folder structure inside directory with entrypoint specified is not allowed. This won't pass validation for referenced yaml files. I plan to fix this in future releases
-
And yes, only yaml formats supported for now
modules.Boot
[IN DEVELOPMENT] Flexible system configurations from apps installation to own settings applying.
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 clyjin-0.2.3.tar.gz
.
File metadata
- Download URL: clyjin-0.2.3.tar.gz
- Upload date:
- Size: 12.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.11.3 Linux/6.4.8-zen1-1-zen
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 074ba8f4967447d2060be1261a166fbc2fbe7bc32fe80dccac40c2acae9767af |
|
MD5 | 2de564fec2fd7e8f380fda9a8b5c70a8 |
|
BLAKE2b-256 | 085857c18eee052c88ee35378653171a0bb36468ddbd35df98c744fa4caf1d6a |
File details
Details for the file clyjin-0.2.3-py3-none-any.whl
.
File metadata
- Download URL: clyjin-0.2.3-py3-none-any.whl
- Upload date:
- Size: 18.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 CPython/3.11.3 Linux/6.4.8-zen1-1-zen
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2d76a66ba1818554859f859f1d3f9328741ff370280a3553cf459290ce6cf721 |
|
MD5 | 9c9ef16f5ebe63fbc79cf9b3b7b5b5d6 |
|
BLAKE2b-256 | e97b04fec0cf7d26912c1c481359c2350472ef40d8128311f08c26c5d0f077b5 |