Python SDK for interacting with the Evolve App Server
Project description
Evolve App Server Python Client
This library provides a wrapper to the Evolve App Server's API, allowing users of the Evolve SDK to authenticate with the Evolve App Server and upload studies.
Usage
from geojson import FeatureCollection
from zepben.eas import EasClient, StudyInput, StudyResultInput, GeoJsonOverlayInput, ResultSectionInput, SectionType, Mutation
eas_client = EasClient(
host="<host>",
port=1234,
access_token="<access_token>",
asynchronous=False,
)
eas_client.mutation(
Mutation.add_studies(
[
StudyInput(
name="<study name>",
description="<study description>",
tags=["<tag>", "<tag2>"],
results=[
StudyResultInput(
name="<result_name>",
geoJsonOverlay=GeoJsonOverlayInput(
data=FeatureCollection(...),
styles=["style1"]
),
sections=[
ResultSectionInput(
type=SectionType.TABLE,
name="<table name>",
description="<table description>",
columns=[
{"key": "<column 1 key>", "name": "<column 1 name>"},
{"key": "<column 2 key>", "name": "<column 2 name>"},
],
data=[
{"<column 1 key>": "<column 1 row 1 value>", "<column 2 key>": "<column 2 row 1 value>"},
{"<column 1 key>": "<column 1 row 2 value>", "<column 2 key>": "<column 2 row 2 value>"}
]
)
]
)
],
styles=[
{
"id": "style1",
# other Mapbox GL JS style properties
}
]
)
]
)
)
eas_client.close()
AsyncIO
The EasClient can operate in async mode if specified, like so:
from aiohttp import ClientSession
from geojson import FeatureCollection
from zepben.eas import EasClient, StudyInput, StudyResultInput, GeoJsonOverlayInput, ResultSectionInput, SectionType, Mutation
async def upload():
eas_client = EasClient(
host="<host>",
port=1234,
access_token="<access_token>",
asynchronous=True, # returns all methods as plain async methods
)
await eas_client.mutation(
Mutation.add_studies(
[
StudyInput(
name="<study name>",
description="<study description>",
tags=["<tag>", "<tag2>"],
results=[
StudyResultInput(
name="<result_name>",
geoJsonOverlay=GeoJsonOverlayInput(
data=FeatureCollection(...),
styles=["style1"]
),
sections=[
ResultSectionInput(
type=SectionType.TABLE,
name="<table name>",
description="<table description>",
columns=[
{"key": "<column 1 key>", "name": "<column 1 name>"},
{"key": "<column 2 key>", "name": "<column 2 name>"},
],
data=[
{"<column 1 key>": "<column 1 row 1 value>", "<column 2 key>": "<column 2 row 1 value>"},
{"<column 1 key>": "<column 1 row 2 value>", "<column 2 key>": "<column 2 row 2 value>"}
]
)
]
)
],
styles=[
{
"id": "style1",
# other Mapbox GL JS style properties
}
]
)
]
)
)
await eas_client.close()
I'm used to the old client, what do i do?
Migrating existing code
Most of the objects passed into requests are similar. The new EasClient is fully type hinted and self documenting.
For example.
from zepben.eas import EasClient, WorkPackageInput, HcExecutorConfigInput, FeederConfigsInput, FeederConfigInput
client = EasClient(host='host', port=1234)
client.get_work_package_cost_estimation(
WorkPackageInput(
feederConfigs=FeederConfigsInput(
configs=[
FeederConfigInput(
feeder='myFeeder',
years=[2024, 2025],
scenarios=['scenario1']
)
]
)
)
)
Hovering over any kwarg or looking at any class definition will show all possible parameters, and their expected types.
Enabling legacy convenience methods
Legacy convenience methods can be enabled by passing enable_legacy_methods to __init__ of EasClient. eg:
from zepben.eas import EasClient
client = EasClient(enable_legacy_methods=True)
This will enable all deprecated and opt_in methods on the class, they are disabled by default.
Development
To regenerate the graphql client you will need to install zepben.eas with eas-codegen optional dependencies:
pip install -e ".[eas-codegen]"
With these installed and EAS running locally on port 7654, you can then generate the client:
python ariadne-codegen.py
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 zepben_eas-1.0.0b2.tar.gz.
File metadata
- Download URL: zepben_eas-1.0.0b2.tar.gz
- Upload date:
- Size: 59.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.20
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
55d4c840ead27b5a3a0ee0356bbb2103bfff4dbb57f5456ff76b2b406f144c79
|
|
| MD5 |
38e71d29c732365f3bcfe1aa38727eeb
|
|
| BLAKE2b-256 |
7558bce43746bf7ba71b1ba8e48890193756e995ae79aa019c1c0acaf6296b17
|
File details
Details for the file zepben_eas-1.0.0b2-py3-none-any.whl.
File metadata
- Download URL: zepben_eas-1.0.0b2-py3-none-any.whl
- Upload date:
- Size: 57.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.20
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
08b6c9924e7469a401a7a37cf0de36d3026c56b0429820bddd49a37db2cb38f7
|
|
| MD5 |
3f0340c811c783359e7cc1d875e5f865
|
|
| BLAKE2b-256 |
7fbbe876c92d83ff34cb41aaf19dacee2bf0459d6da485e1e19456ead9253274
|