Skip to main content

Provides a helper to create sessions for use with Ansys OpenAPI clients.

Project description

PyAnsys Python PyPI GH-CI MIT Black pre-commit.ci status

Overview

OpenAPI-Common is intended for use with the custom code generation template in the PyAnsys project. It provides the source code for an authentication-aware client for OpenAPI client libraries.

OpenAPI-Common supports authentication with Basic, Negotiate, NTLM, and OpenID Connect. Most features of the underlying requests session are exposed for use. Some basic configuration is also provided by default.

Installation

Install the openapi-common repository with this code:

pip install ansys-openapi-common

Alternatively, clone and install the repository with this code:

git clone https://github.com/pyansys/openapi-common
cd openapi-common
pip install .

Usage

The API client class is intended to be wrapped by code that implements a client library. You should override the __init__() or connect() method to add any additional behavior that might be required.

Authentication is configured through the ApiClientFactory object and its with_xxx() methods. If no authentication is required, you can use the with_anonymous() method. You can provide additional configuration with the SessionConfiguration object.

>>> from ansys.openapi.common import ApiClientFactory
>>> session = ApiClientFactory('https://my-api.com/v1.svc')
...           .with_autologon()
...           .connect()
<ApiClient url: https://my-api.com/v1.svc>

Authentication schemes

OpenAPI-Common supports API servers configured with no authentication, API keys, client certificates, and basic authentication schemes.

Windows users can also use Windows Integrated Authentication to connect to Kerberos-enabled APIs with their Windows credentials and to NTLM where it is supported.

Linux users can make use of Kerberos authentication via the [linux-kerberos] extra. This requires a working installation of either MIT Kerberos or Heimdal, as well as some platform-specific build steps. An additional requirement is a correctly configured krb5.keytab file on your system.

Windows and Linux users can authenticate with OIDC-enabled APIs by using the [oidc] extra. Currently only the Authorization Code authentication flow is supported.

Authentication methods by platform

Authentication method

Windows

Linux

Builder method

Additional settings

API Key

✔️

✔️

.with_anonymous()

Set the appropriate header in api_session_configuration

Client Certificate

✔️

✔️

Any

Provide client_cert_path and optionally client_cert_key in api_session_configuration

Basic

✔️

✔️

.with_credentials()

NTLM

✔️

.with_credentials()

Kerberos

✔️

➕ with [linux-kerberos] extra

.with_autologon()

OIDC

➕ with [oidc] extra

➕ with [oidc] extra

.with_oidc()

Platform-specific Kerberos configuration

Kerberos authentication should be supported wherever the MIT or Heimdal Kerberos client can be installed. OpenAPI-Common has been tested on the platforms that follow. If you manage to use it on another platform, consider contributing installation steps for your platform by making a pull request.

Ubuntu 20.04

Ubuntu requires the gssapi Python module to be built from source. This requires the Kerberos headers, Python headers for the version of Python that you are using (here we have installed python3.10 from the deadsnakes ppa), and a supported compiler. (GCC works well.))

You should then be able to install this module with the [linux-kerberos] extra.

sudo apt install build-essential python3.10-dev libkrb5-dev
pip install ansys-openapi-common[linux-kerberos]

Once the installation completes, ensure that your krb5.conf file is set up correctly for your Kerberos configuration and that you have a valid keytab file, which is normally in /etc/krb5.keytab.

License

OpenAPI-Common is provided under the terms of the MIT license. You can find the license text in the LICENSE file at the root of the repository.

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

ansys_openapi_common-2.0.1.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

ansys_openapi_common-2.0.1-py3-none-any.whl (35.7 kB view details)

Uploaded Python 3

File details

Details for the file ansys_openapi_common-2.0.1.tar.gz.

File metadata

  • Download URL: ansys_openapi_common-2.0.1.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.10.14

File hashes

Hashes for ansys_openapi_common-2.0.1.tar.gz
Algorithm Hash digest
SHA256 9dbe0024a2d2be230d202000b9fb7689dda221a10bef15852392528c0920d98f
MD5 25135515e3a4e6277c5243d22c9b653e
BLAKE2b-256 aadad8f8298d608b1f4604af3e87f8d4ec6a6ce16d08dffbb76e192972fb987e

See more details on using hashes here.

File details

Details for the file ansys_openapi_common-2.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for ansys_openapi_common-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e9719eeb3ca5f3a980543ce085ab30dffc1dd46b3f571609291e2fc2933d05bf
MD5 c38286b1b127bd41daccc4e7c0a9ebf7
BLAKE2b-256 a638592fa963e50db6d4157bba17d89a65abc6cacdfaeea0275aaaa0266ce0c3

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