NERIS API Client
Project description
NERIS API Client
A Python class to interact with the NERIS API programmatically.
NOTE: Due to the changes and transition to using Oauth 2.0 version 1.2 is now deprecated. Please upgrade to version 1.3. You can do that in a package manager with the following update:
neris-api-client = ">=1.3"or in yourrequirements.txtyou can doneris-api-client >=1.3. Or you can install withpip install neris_api_client>=1.3..
Versioning
This API client does not directly follow semver practices. In order to remove confusion between the NERIS API client and API, we have decided to align the major version of this client with the major version of the API release. The minor and patch versions of this client will differ from API release version, they will instead represent changes made to the API client itself.
Installation
To install:
pip install neris-api-client
Package published on PyPi: NERIS API Client
Usage
Auth with password auth flow
All config parameters can be specified as environment variables prefixed with NERIS_ e.g. NERIS_GRANT_TYPE=password.
from neris_api_client import NerisApiClient, Config
client = NerisApiClient(
Config(
base_url="https://api-test.neris.fsri.org/v1",
grant_type="password",
username="neris.user@email.co",
password="*******",
)
)
# Get an entity
entity = client.get_entity("FD24027240")
# If MFA enabled, prompt for auth challenge answer
Provide MFA code for email_otp: ******
Auth with client_credentials auth flow
All config parameters can be specified as environment variables prefixed with NERIS_ e.g. NERIS_GRANT_TYPE=client_credentials.
from neris_api_client import NerisApiClient, Config
client = NerisApiClient(
Config(
base_url="https://api-test.neris.fsri.org/v1",
grant_type="client_credentials",
client_id="********************",
client_secret="***************",
)
)
# Get an entity
entity = client.get_entity("FD24027240")
Using environment varables to instantiate the library
Configuration should be stored in the environment. The following uses dotenv to load the configuration, but you can use whatever you like. In the cloud, you might load all of these values into the environment from an encrypted parameter store.
All variables prefixed are prefixed with NERIS_
- See env.example for the parameter options.
- Store the
/envfile in the current working directory.
from dotenv import load_dotenv
from neris_api_client import NerisApiClient, Config
# Credentials must be defined in .env
load_dotenv()
client = NerisApiClient()
# Get an entity
entity = client.get_entity("FD24027240")
Additional config parameters
| Parameter | Description |
|---|---|
| debug | Controls whether the application outputs debug information. |
| validate | Controls whether the client performs model validations. |
Disclaimer
The models in this package are generated using datamodel-code-generator and are not guaranteed
to contain all of the information present in the full specification. The generated models are used to validate request payloads prior to
API submission.
Additional Information
To ask a question, make a suggestion, or otherwise get help with the NERIS API Client, please visit the NERIS helpdesk.
Beta sandbox users:
- Be sure to use the base URL
https://api-test.neris.fsri.org/v1with the NERIS API Client. You will not be able to authenticate requests in the other environments. - For the beta testing period, your user is only authorized to perform actions on behalf of the FSRI Fire Department
FD24027214.
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 neris_api_client-1.5.2.tar.gz.
File metadata
- Download URL: neris_api_client-1.5.2.tar.gz
- Upload date:
- Size: 84.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a8aa2b2ae457b8fe2aca977d532571658db8556650c04c93bef9c5e40a3efb28
|
|
| MD5 |
494a9910c9fd2dca2f5737ba4e141016
|
|
| BLAKE2b-256 |
1a547e6bdea8f6922d4ebf7e4219abc3db803bf0bf0cb4a4c0c12b20c6c00b2c
|
File details
Details for the file neris_api_client-1.5.2-py3-none-any.whl.
File metadata
- Download URL: neris_api_client-1.5.2-py3-none-any.whl
- Upload date:
- Size: 83.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d96874da611a58a6e961dd3f7e1c0d66938793f1d1d208028fbde4a3a098a93c
|
|
| MD5 |
67aeb226d837367a1dbda7ee60c947f9
|
|
| BLAKE2b-256 |
6280d7ff653e3f68088dd47789250dfa315ba2f7a906adde449e39ca89990c7f
|