A Python client to easily interact with the FAO SWS REST APIs
Project description
SWS API Client
This library provides the user with a set of useful tools to easily interact with the FAO SWS (Statistical Working System) REST APIs.
Deploy
python3 -m build
twine upload dist/*
Installation
The module is available on Pypi:
python -m pip install sws_api_client
The library requires Python 3.11+.
Usage
To use the package the user needs to create an instance of the SwsApiClient class, provide it with the necessary parameters and execute the methods to query the specific endpoints.
Instantiate the client locally
There are three methods to instantiate the client:
1. Pass the sws_endpoint and the access_token to the constructor
from sws_api_client import SwsApiClient
sws_client = SwsApiClient(sws_endpoint="<sws_endpoint>", access_token="<access_token>")
2. Pass to sws_endpoint and the access_token as named arguments
We need to execute the script from command line passing --sws_endpoint and --access_token as arguments:
python script.py --sws_endpoint <endpoint> --access_token <test_access_token>
And instantiate the client in our script with the class method from_args:
from sws_api_client import SwsApiClient
sws_client = SwsApiClient.from_args()
3. Create a conf file where to store the arguments
We need to create a conf file (default name: "conf_sws_api_client.json") with the following structure:
{
"sws_endpoint": "https://sws.dev.fao.org",
"sws_token": "XXX",
"current_task_id": "XXX",
"current_execution_id": "XXX",
"authclient": {
"clientId": "XXX",
"clientSecret": "XXX",
"tokenEndpoint": "https://fao-dev.auth.eu-west-1.amazoncognito.com/oauth2/token",
"scope": "sws/user"
}
}
And instantiate the client in our script with the class method auto:
from sws_api_client import SwsApiClient
sws_client = SwsApiClient.auto()
Behind the scene it will automatically detect the fact that you are in debug mode and it will instanciate the client using the from_conf method
Instantiate the client in a SWS plugin
When working withing a SWS plugin instantiate the client as:
from sws_api_client import SwsApiClient
sws_client = SwsApiClient.auto()
Behind the scene it will automatically detect the fact that you are in a SWS plugin and it will instanciate the client using the from_env method
Perform requests
To perform requests you just need to call the available methods using the SwsApiClient object, as an example:
datasets = Datasets(sws_client)
dataset = datasets.get_dataset_info('aproduction')
logger.info(f"Dataset info: {dataset}")
more complete examples can be found in the example folder:
cp example/conf_sws_api_client.json.example example/conf_sws_api_client.json
# edit the file with your credentials
python3 -m venv example/.venv
source example/.venv/bin/activate
pip install -r example/requirements
python example/dataset_example.py
If you need to perform a test request not in debug mode, you can use the following command:
AWS_PROFILE=fao-dev DEBUG_MODE=FALSE SWS_USER_CREDENTIALS_SECRET_NAME=dev/sws/user_client SWS_TOKEN=YOUR_TOKEN SWS_ENDPOINT=https://sws.dev.fao.org python3 dataset_example.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 sws_api_client-1.0.11b0.tar.gz.
File metadata
- Download URL: sws_api_client-1.0.11b0.tar.gz
- Upload date:
- Size: 15.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
154b104c17424e0d6aed2600fd6089b6c53272f099b9d55ffdec17df78d1c250
|
|
| MD5 |
098a4d325d5f90505cb2205db7024d28
|
|
| BLAKE2b-256 |
d6c29c91348205956294149603526514b84286051beacb941950c6f92d5a6746
|
File details
Details for the file sws_api_client-1.0.11b0-py3-none-any.whl.
File metadata
- Download URL: sws_api_client-1.0.11b0-py3-none-any.whl
- Upload date:
- Size: 17.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
779f37da9bb2e9340766630cc917044c29be70b346c086dd732c4b83674550c6
|
|
| MD5 |
d5489453a20e2bf56c9bc9491b3f9dbb
|
|
| BLAKE2b-256 |
ada54efb42649632a84650d534a1db8ed7c62d489eb588707c84f59cc4cae61a
|