Skip to main content

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

sws_api_client-1.0.12b0.tar.gz (15.6 kB view details)

Uploaded Source

Built Distribution

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

sws_api_client-1.0.12b0-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

Details for the file sws_api_client-1.0.12b0.tar.gz.

File metadata

  • Download URL: sws_api_client-1.0.12b0.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

Hashes for sws_api_client-1.0.12b0.tar.gz
Algorithm Hash digest
SHA256 4f4755d11347b7f59bbce4b67fd2a00c2675d2400291e8a69c88b80a05d5aed4
MD5 b8ca6ac1f45d2a50124247bd6564e585
BLAKE2b-256 75b6f3c35c5f58f7377b87850806fcf813a97de1cf5c4bbbcbd62d5b910300bc

See more details on using hashes here.

File details

Details for the file sws_api_client-1.0.12b0-py3-none-any.whl.

File metadata

File hashes

Hashes for sws_api_client-1.0.12b0-py3-none-any.whl
Algorithm Hash digest
SHA256 3ea60d7a7f9816414cd1fbc9d6c3e4930b9f44ea35198050333dfc28d370dd26
MD5 ec21e8a676461516a1197ef7be98a3d4
BLAKE2b-256 9414178b05f2725f6532eeb1664846280f37b75aa17c942d5171a0b6a89a618e

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