Skip to main content

Python SDK to access the Tenchi Security Zanshin API v1

Project description

 Coverage badge PyPI version shields.io PyPI pyversions

Zanshin Python SDK

This Python package contains an SDK to interact with the API of the Zanshin SaaS service from Tenchi Security.

This SDK is used to implement a command-line utility, which is available on Github and on PyPI.

Setting up Credentials

There are three ways that the SDK handles credentials. The order of evaluation is:

Client Parameters

When calling the Client class, you can pass the values API Key, API URL, Proxy URL and User Agent you want to use as below:

from zanshinsdk import Client

client = Client(api_key="my_zanshin_api_key")

print(client.get_me())

:warning: These values will overwrite anything you set as Environment Variables or in the Config File.

Environment Variables

You can use the following Environment Variables to configure Zanshin SDK:

  • ZANSHIN_API_KEY: Will setup your Zanshin credentials
  • ZANSHIN_API_URL: Will define the API URL. Default is https://api.zanshin.tenchisecurity.com
  • ZANSHIN_USER_AGENT: If you want to overwrite the User Agent when calling Zanshin API
  • HTTP_PROXY | HTTPS_PROXY: Zanshin SDK uses HTTPX under the hood, checkout the Environment Variables section of their documentation for more use cases

Usage

export ZANSHIN_API_KEY="eyJhbGciOiJIU..."

:warning: These Environment Variables will overwrite anything you set on the Config File.

Config File

Second is by using a configuration file in the format created by the Python RawConfigParser class.

The file is located at ~/.tenchi/config, where ~ is the current user's home directory.

Each section is treated as a configuration profile, and the SDK will look for a section called default if another is not explicitly selected.

These are the supported options:

  • api_key (required) which contains the Zanshin API key obtained at the Zanshin web portal.
  • user_agent (optional) allows you to override the default user-agent header used by the SDK when making API requests.
  • api_url (optional) directs the SDK to use a different API endpoint than the default (https://api.zanshin.tenchisecurity.com).

This is what a minimal configuration file looks like:

[default]
api_key = abcdefghijklmnopqrstuvxyz

The SDK

The SDK uses Python 3 type hints extensively. It attempts to abstract API artifacts such as pagination by using Python generators, thus making the service easier to interact with.

The network connections are done using the wonderful httpx library.

Currently it focuses on returning the parsed JSON values instead of converting them into native classes for higher level abstractions.

The zanshinsdk.Client class is the main entry point of the SDK. Here is a quick example that shows information about the owner of the API key in use:

from zanshinsdk import Client
from json import dumps

client = Client()   # loads API key from the "default" profile in ~/.tenchi/config
me = client.get_me()    # calls /me API endpoint
print(dumps(me, indent=4))

For more examples, checkout the docs.

All operations call raise_for_status on the httpx Response object internally, so any 4xx or 5xx will raise exceptions.

Installing

To install the SDK, you can use pip. You have two options to install ZanshinSDK:

  • Essentials

Using pip install zanshinsdk will install the SDK with all features exception ability to perform onboarding of new Scan Targets. For this, you'll need to install boto3.

  • With Boto3

With pip install zanshinsdk[with_boto3] you'll automatically install boto3 along with ZanshinSDK. This will enable you to perform Onboard of new Scan Targets via SDK.

Testing

To run all tests call make test on the project root directory. Make sure there's a [default] profile configured, else some tests will fail. Also, be sure to install boto3 and moto[all] or some integration tests will fail.

Support

If you are a Zanshin customer and have any questions regarding the use of the service, its API or this SDK package, please get in touch via e-mail at support {at} tenchisecurity {dot} com or via the support widget on the Zanshin Portal.

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

zanshinsdk-1.6.3.1.tar.gz (39.2 kB view details)

Uploaded Source

Built Distribution

zanshinsdk-1.6.3.1-py3-none-any.whl (42.7 kB view details)

Uploaded Python 3

File details

Details for the file zanshinsdk-1.6.3.1.tar.gz.

File metadata

  • Download URL: zanshinsdk-1.6.3.1.tar.gz
  • Upload date:
  • Size: 39.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Darwin/24.0.0

File hashes

Hashes for zanshinsdk-1.6.3.1.tar.gz
Algorithm Hash digest
SHA256 20f74e76a5abb5a699e2a5544bb0e017a9e8cd0ccb9696585966ea7195ba663d
MD5 33cfeb1a909d8652b3ab7f3b4bceb9af
BLAKE2b-256 33fba242df57eedb5a511c4a499430aac3d570d815ea1a7d680f9f69d8fa1b8d

See more details on using hashes here.

File details

Details for the file zanshinsdk-1.6.3.1-py3-none-any.whl.

File metadata

  • Download URL: zanshinsdk-1.6.3.1-py3-none-any.whl
  • Upload date:
  • Size: 42.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Darwin/24.0.0

File hashes

Hashes for zanshinsdk-1.6.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9e13a2b773f43369060aa14960b76982d1d2af4d5475d000463a4b604c86b8dc
MD5 06162a5ff5686e66efe3ff5e7b56fa04
BLAKE2b-256 b198da746922a0838502def03b773286f4841b2e2ed5ceaef37f0a6ae89c93ae

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