Skip to main content

The PolyAPI Python Client

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"

Complex Types In Server Functions

You can define arbitrarily complex argument and return types using pydantic models.

from pydantic import BaseModel


class Foobar(BaseModel):
    count: int


def myfunc(n: int) -> Foobar:
    return Foobar(count=n)

Here are the docs on Pydantic models.

Upgrade

To upgrade your library to the latest version, pass the upgrade flag.:

pip install polyapi-python --upgrade

Unit Tests

To run this library's unit tests, please clone the repo then run:

python -m unittest discover

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

polyapi-python-0.0.13.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

polyapi_python-0.0.13-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file polyapi-python-0.0.13.tar.gz.

File metadata

  • Download URL: polyapi-python-0.0.13.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for polyapi-python-0.0.13.tar.gz
Algorithm Hash digest
SHA256 708c59270dbd835c1a0bd613f58d7ba307551a28c4b00fe882a61ddf384d730d
MD5 11b7fde3f239b2e8d00748739d58a433
BLAKE2b-256 04d0c91f750f04301edb55bd9a4afcb2ef82a36f7b587853f1271c99be2c83bb

See more details on using hashes here.

File details

Details for the file polyapi_python-0.0.13-py3-none-any.whl.

File metadata

File hashes

Hashes for polyapi_python-0.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 bdfcb49f72f8b48d74057b263b91e651b997a9718131178b5a1651d7b95135f8
MD5 0fb2077918e336d57925b65e0ddb8768
BLAKE2b-256 d9c8450b75901298d86f9b40661b017b1c3705e5007aaae2efedb7cc79371d08

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page