FastAPI webserver for loading and interaction with JIVAS agents.
Project description
JIVAS Web Server (jvserve)
jvserve is a FastAPI-based web server designed for loading and interacting with JIVAS agents. It is built on top of jac-cloud and provides a robust platform for managing jivas agent jobs, handling webhooks, and executing actions within the JIVAS ecosystem.
Installation
To install jvserve, use pip:
pip install jvserve
Usage
To use jvserve, you can start the server with the following command:
jac jvserve <path_to_your_jac_file>
For example:
jac jvserve main.jac
You can also start a file server to serve static files:
jac jvfileserve <directory>
For example:
jac jvfileserve ./static
Supported Arguments
- filename: Path to your JAC file.
- host: Host address to bind the server (default:
0.0.0.0). - port: Port number to bind the server (default:
8000). - loglevel: Logging level (default:
INFO). - workers: Number of worker processes (optional).
Example with all arguments:
jac jvserve main.jac --host 127.0.0.1 --port 8080 --loglevel DEBUG --workers 4
API Endpoints
- Interact with Agent:
/interact(POST) - Execute Webhook:
/webhook/{key}(GET, POST) - Execute Action Walker:
/action/walker(POST)
You can see all endpoints at the URL /docs.
🔰 Contributing
- 🐛 Report Issues: Submit bugs found or log feature requests for the
jvserveproject. - 💡 Submit Pull Requests: Review open PRs, and submit your own PRs.
Contributing Guidelines
- Fork the Repository: Start by forking the project repository to your GitHub account.
- Clone Locally: Clone the forked repository to your local machine using a git client.
git clone https://github.com/TrueSelph/jvserve
- Create a New Branch: Always work on a new branch, giving it a descriptive name.
git checkout -b new-feature-x
- Make Your Changes: Develop and test your changes locally.
- Commit Your Changes: Commit with a clear message describing your updates.
git commit -m 'Implemented new feature x.'
- Push to GitHub: Push the changes to your forked repository.
git push origin new-feature-x
- Submit a Pull Request: Create a PR against the original project repository. Clearly describe the changes and their motivations.
- Review: Once your PR is reviewed and approved, it will be merged into the main branch. Congratulations on your contribution!
🎗 License
This project is protected under the Apache License 2.0. See LICENSE for more information.
Additional Information
Since jvserve is a wrapper around jac-cloud, it supports all the primitives available in jac-cloud. You can find more information about jac-cloud primitives here.
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 jvserve-2.0.14.tar.gz.
File metadata
- Download URL: jvserve-2.0.14.tar.gz
- Upload date:
- Size: 24.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e9e14a3f3e3d06e5bb81646016905264b9f25919b49441aa89e62a4725a8c59c
|
|
| MD5 |
b47bbbf1927260792961def5b704c173
|
|
| BLAKE2b-256 |
e1094de54b0a8fe92bf0515c79e7469d6352b23ec1c4ed8a96a2078769957a10
|
File details
Details for the file jvserve-2.0.14-py3-none-any.whl.
File metadata
- Download URL: jvserve-2.0.14-py3-none-any.whl
- Upload date:
- Size: 21.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1a25303b83a9636d3b2a176b3c50fb56057bcda035aea9829ef6d0bcdbf50570
|
|
| MD5 |
4aad8e19d15794ee7f76bc67476e0b23
|
|
| BLAKE2b-256 |
f43801504410fffd63ae406a9218d993b1feafec7badb3ead786ac111e114876
|