Run and manage ReadyAPI apps from the command line with ReadyAPI CLI. ๐
Project description
ReadyAPI CLI
Source Code: https://github.com/readyapi/readyapi-cli
Run and manage ReadyAPI apps from the command line with ReadyAPI CLI. ๐
Description
ReadyAPI CLI is a command line program readyapi
that you can use to serve your ReadyAPI app, manage your ReadyAPI project, and more.
When you install ReadyAPI (e.g. with pip install "readyapi[standard]"
), it includes a package called readyapi-cli
, this package provides the readyapi
command in the terminal.
To run your ReadyAPI app for development, you can use the readyapi dev
command:
$ readyapi dev main.py
INFO Using path main.py
INFO Resolved absolute path /home/user/code/awesomeapp/main.py
INFO Searching for package file structure from directories with __init__.py files
INFO Importing from /home/user/code/awesomeapp
โญโ Python module file โโฎ
โ โ
โ ๐ main.py โ
โ โ
โฐโโโโโโโโโโโโโโโโโโโโโโโฏ
INFO Importing module main
INFO Found importable ReadyAPI app
โญโ Importable ReadyAPI app โโฎ
โ โ
โ from main import app โ
โ โ
โฐโโโโโโโโโโโโโโโโโโโโโโโโโโ-โฏ
INFO Using import string main:app
โญโโโโโโโโโโ ReadyAPI CLI - Development mode โโโโโโโโโโโฎ
โ โ
โ Serving at: http://127.0.0.1:8000 โ
โ โ
โ API docs: http://127.0.0.1:8000/docs โ
โ โ
โ Running in development mode, for production use: โ
โ โ
โ readyapi run โ
โ โ
โฐโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฏ
INFO: Will watch for changes in these directories: ['/home/user/code/awesomeapp']
INFO: Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)
INFO: Started reloader process [56345] using WatchFiles
INFO: Started server process [56352]
INFO: Waiting for application startup.
INFO: Application startup complete.
That command line program called readyapi
is ReadyAPI CLI.
ReadyAPI CLI takes the path to your Python program and automatically detects the variable with the ReadyAPI (commonly named app
) and how to import it, and then serves it.
For production you would use readyapi run
instead. ๐
Internally, ReadyAPI CLI uses Uvicorn, a high-performance, production-ready, ASGI server. ๐
readyapi dev
When you run readyapi dev
, it will run on development mode.
By default, it will have auto-reload enabled, so it will automatically reload the server when you make changes to your code. This is resource intensive and could be less stable than without it, you should only use it for development.
By default it will listen on the IP address 127.0.0.1
, which is the IP for your machine to communicate with itself alone (localhost
).
readyapi run
When you run readyapi run
, it will run on production mode by default.
It will have auto-reload disabled by default.
It will listen on the IP address 0.0.0.0
, which means all the available IP addresses, this way it will be publicly accessible to anyone that can communicate with the machine. This is how you would normally run it in production, for example, in a container.
In most cases you would (and should) have a "termination proxy" handling HTTPS for you on top, this will depend on how you deploy your application, your provider might do this for you, or you might need to set it up yourself. You can learn more about it in the ReadyAPI Deployment documentation.
License
This project is licensed under the terms of the MIT license.
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 readyapi_cli_slim-0.0.6.tar.gz
.
File metadata
- Download URL: readyapi_cli_slim-0.0.6.tar.gz
- Upload date:
- Size: 15.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6c9d5ff401b7cafa9c8043703e63992508444338e1766c1fc0edd47bdbae90b4 |
|
MD5 | c5066c27de2ae49b99559c7eff9d568d |
|
BLAKE2b-256 | 15024c5263a920fb35e2b2fb56969ed25302fd347c5e2ecf1f523109624aa89f |
File details
Details for the file readyapi_cli_slim-0.0.6-py3-none-any.whl
.
File metadata
- Download URL: readyapi_cli_slim-0.0.6-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7ab58295ccf8eca6b5bc21b9ab59c567c251005b5c1da52cea068dd96893315 |
|
MD5 | 8f96a604d0ea92e47923e1be087ec0d7 |
|
BLAKE2b-256 | f825351cc431977af5601ae8d9fa1cea11aa5c52b4adfd8e38da80da575985c9 |