Skip to main content

Python class that allow to create client for REST API with dynamic code generation

Project description

FitRequest

This module allows you to write REST api client with automatic code generation.

Skillcorner Coverage Build PyPI - Version Versions License

Example of implementation: SkillCorner Python client for SkillCorner API.

Help

See documentation for more details.

Installation

pip install fitrequest

A simple example

from fitrequest.client import FitRequest


class RestApiClient(FitRequest):
    base_url = "http://base_api_url"
    base_client_name="rest_api"
    _docstring_template = 'GET request on endpoint: {endpoint}\nDocs URL anchor: http://base_api_url/docs/{docs_url_anchor}'
    _methods_binding = [
        {
            'name': 'get_item',
            'endpoint': '/items/{}',
            'docs_url_anchor': 'items/items_list',
            'resource_name': 'item_id',
        }
    ]

This is a simple definition of a subclass of FitRequest object. By instanciating this class, we can do the following:

my_client = RestApiClient()
response = my_client.get_item(item_id=3)

response variable will hold the value of the JSON response of the following HTTP request:

GET http://base_api_url/items/3

Subclass definition

MethodDetails and methods_binding

MethodDetails is a dataclass that holds the following attributes:

  • name: the name of the method that will be created in the subclass of FitRequest
  • endpoint: the endpoint of the request
  • docstring: the docstring of the method that will be created in the subclass of FitRequest
  • exec_method: the name of the method that will be executed to retrieve the response
  • extra_params: the list of named arguments to add to the method signature
  • raise_for_status: wether to raise exception for response status code >= 400 and < 600
  • response_key: the key of the JSON response that will be returned by the method
  • resource_name: the name of the arg that will be used in the definition of the python method and sent as a path or query parameter in the request

_methods_binding is almost a list of MethodDetails (as dict) that will be used to create the methods in the subclass of FitRequest.

The methods can be extended with a docstring template in which you can use any other method attribute. You can also have all the methods starting with 'get' duplicated as a save method starting with 'get_and_save' taking a filepath argument and dumping the data into a file.

For the moment, the generation of methods supports only one query or path parameters. If an endpoint requires more variables in its definition, you will need to actually write the method. For example, it is not possible to send a request to the following endpoint with the current version of FitRequest:

GET http://base_api_url/path/to/resource/{resource_id}/subresource/{subresource_id}

It will be a topic for a future release.

_build_final_url method

This method is used to build the final url of the request. Sometimes, you may need to add some extra information in the url before making the query. For example, you may need to add a token in the url. Here is a simple example:

    def _build_final_url(self, endpoint: str, **kwargs) -> str:
            return f'{self.base_url}{endpoint}?token={self.token}'

Authentication

Basic authentication

Basic authentication is supported by FitRequest. You just need to override the following method to your subclass of FitRequest:

from requests.auth import HTTPBasicAuth

    def _authenticate(self) -> HTTPBasicAuth:
        return HTTPBasicAuth(self.username, self.password)

This will set the auth attribute of the request's session.

Header based authentication

Some API requires extra headers to be set in the request. If you need to do so, you will have to override the session property in your subclass of FitRequest:

from requests import Session

    @property
    def session(self) -> Session:
        session = super().session
        session.headers['APIKey'] = self.api_key
        return session

Contact

You can contact Skillcorner Team at: support@skillcorner.com.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fitrequest-0.1.3.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

fitrequest-0.1.3-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file fitrequest-0.1.3.tar.gz.

File metadata

  • Download URL: fitrequest-0.1.3.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.9.17 Linux/5.10.201-191.748.amzn2.x86_64

File hashes

Hashes for fitrequest-0.1.3.tar.gz
Algorithm Hash digest
SHA256 a834165f16d6ce0eeefc8ae1aca80d1c1c43d4d4be3d951bd16da96c7e19f069
MD5 f3c1e76fe9077cc07c9f0f9bd90e0f1e
BLAKE2b-256 08e65f317f39e725eb92838a06c37d1b539230b3b15f3dbbcd9d9a30b0b820a6

See more details on using hashes here.

File details

Details for the file fitrequest-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: fitrequest-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 8.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.9.17 Linux/5.10.201-191.748.amzn2.x86_64

File hashes

Hashes for fitrequest-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3fe9bf6f9cbfff3aa7eda51340cc63b1c6597b833a6806f2f02fcffb3262121f
MD5 24b73add136950f72ecdeea683708dfb
BLAKE2b-256 72325dbaf34460c94f3b2d2c0fabfe6660cb1ef9dbaac88218369c256cc362a5

See more details on using hashes here.

Supported by

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