The Python Client for PolyAPI, the IPaaS by Developers for Developers
Project description
PolyAPI Python Library
The PolyAPI Python Library lets you use and define PolyAPI functions using Python.
PolyAPI Quickstart
1. Install Libraries
First install the client.
We recommend the use of venv so you can have multiple projects each with separate credentials:
python -m venv myvenv
source myvenv/bin/activate
pip install polyapi-python
Replace myvenv
with whatever you'd like your venv to be named!
For more on Python virtual environments, we recommend this venv primer.
However, if you only need to use polyapi with a single project, you can do a basic install:
pip install polyapi-python
2. Generate Your Functions
Now you can run the following to generate your library
python -m polyapi generate
You will be prompted to enter the Poly server url you use and your Poly API key.
You can also provide the key and url as environment variables (useful for deployment):
POLY_API_KEY='your_key'
POLY_API_BASE_URL='your_server' # e.g. na1.polyapi.io
3. Test
That's it! Now open up a test file and you can run some code like so:
from polyapi import poly
print(poly.polyapi.function.api.list(my_server, my_api_key))
Add New Server Functions
To add a new server function, please follow the quickstart. Then you can add a server function like so:
python -m polyapi --context mycontext --description mydesc --server function add <function_name> foo.py
The code in foo.py
should contain a single defined function named the same as your <function_name>
variable.
So for example, if you want to add a function named bar
, your file foo.py
would look like this:
def bar():
return "Hello World"
See Server Function Logs
In order to see function logs, please first set logsEnabled
to true
in Canopy for the function.
https://na1.polyapi.io/canopy/polyui/collections/server-functions
Then in your code, get the poly logger and log with it like so:
logger = logging.getLogger("poly")
def bar():
logger.warning("I AM THE LOG")
return "Hello World"
Finally, click the "Show Logs" button to see your server function logs in Canopy!
Complex Types In Server Functions
You can define arbitrarily complex argument and return types using TypedDicts.
NOTE: you must use TypedDict
from typing_extensions
, not from the base typing
module.
from typing_extensions import TypedDict
class Foobar(TypedDict):
count: int
def bar(n: int) -> Foobar:
return Foobar(count=n)
Pypi
This library is hosted on Pypi. You can find the latest version on the pypi polyapi-python project.
Upgrade
To upgrade your library to the latest version, pass the upgrade flag.
pip install polyapi-python --upgrade
Pre-Release
To upgrade your library to the latest dev version, pass the --pre
flag.
pip install polyapi-python --pre --upgrade
Change Your API Key
If you need to change your API key or what server you are pointing to, you can run:
python -m polyapi setup
Unit Tests
To run this library's unit tests, please clone the repo then run:
python -m unittest discover
Support
If you run into any issues or want help getting started with this project, please contact support@polyapi.io
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 polyapi_python-0.3.1.dev17.tar.gz
.
File metadata
- Download URL: polyapi_python-0.3.1.dev17.tar.gz
- Upload date:
- Size: 40.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3507fa2d6a190843b06a5e96a4c87d9cc6ee8c31b582be1933705996aee3f336 |
|
MD5 | 4cb51c25fa1af6a878832d6ba157fb23 |
|
BLAKE2b-256 | b59adc750f96ae72509404b588156165126f879c5349b1c4c7330f7d38b739a8 |
Provenance
The following attestation bundles were made for polyapi_python-0.3.1.dev17.tar.gz
:
Publisher:
polyapi-update-python-package.yml
on polyapi/polyapi-python
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
polyapi_python-0.3.1.dev17.tar.gz
- Subject digest:
3507fa2d6a190843b06a5e96a4c87d9cc6ee8c31b582be1933705996aee3f336
- Sigstore transparency entry: 150916512
- Sigstore integration time:
- Predicate type:
File details
Details for the file polyapi_python-0.3.1.dev17-py3-none-any.whl
.
File metadata
- Download URL: polyapi_python-0.3.1.dev17-py3-none-any.whl
- Upload date:
- Size: 41.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b1b21e1e5c21e2de5f72d88e7bbf9dd512aba73d47c02540a5ab761081a0afd0 |
|
MD5 | 534129dc6f4f0fbbe987a537644dd569 |
|
BLAKE2b-256 | 04185b7e92a1b112dc73e06ff3acb4c6ab067328b0762df8b55e56fc70eee6e1 |
Provenance
The following attestation bundles were made for polyapi_python-0.3.1.dev17-py3-none-any.whl
:
Publisher:
polyapi-update-python-package.yml
on polyapi/polyapi-python
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
polyapi_python-0.3.1.dev17-py3-none-any.whl
- Subject digest:
b1b21e1e5c21e2de5f72d88e7bbf9dd512aba73d47c02540a5ab761081a0afd0
- Sigstore transparency entry: 150916513
- Sigstore integration time:
- Predicate type: