Skip to main content

Python API client for OpenCTI.

Project description

OpenCTI client for Python

Website readthedocs Number of PyPI downloads Slack Status

The official OpenCTI Python client helps developers to use the OpenCTI API by providing easy to use methods and utils. This client is also used by some OpenCTI components.

Install

To install the latest Python client library, please use pip:

$ pip3 install pycti

Local development

# Fork the current repository, then clone your fork
$ git clone https://github.com/YOUR-USERNAME/opencti.git
$ cd client-python
$ git remote add upstream https://github.com/OpenCTI-Platform/opencti.git
# Create a branch for your feature/fix
$ git checkout -b [branch-name]
# Create a virtualenv
$ cd client-python
$ python3 -m venv .venv
$ source .venv/bin/activate
# Install the client-python and dependencies for the development and the documentation
$ python3 -m pip install -e .[dev,doc]
# Set up the git hook scripts
$ pre-commit install
# Create your feature/fix
# Create tests for your changes
$ pytest
# Push you feature/fix on Github
$ git add [file(s)]
$ git commit -m "[descriptive message]"
$ git push origin [branch-name]
# Open a pull request

Install the package locally

$ pip install -e .

Documentation

Client usage

To learn about how to use the OpenCTI Python client and read some examples and cases, refer to the client documentation.

API reference

To learn about the methods available for executing queries and retrieving their answers, refer to the client API Reference.

Tests

Install dependencies

$ pip install -r ./test-requirements.txt

pytest is used to launch the tests.

Launch tests

Prerequisite

Your OpenCTI API should be running. Your conftest.py should be configured with your API url, your token, and if applicable, your mTLS cert/key.

Launching

Unit tests

$ pytest ./tests/01-unit/

Integration testing

$ pytest ./tests/02-integration/

Example testing:

OpenCTI must be running

cd examples
# Configure with you local instance of OpenCTI
export OPENCTI_API_URL="http://localhost:4000"
export OPENCTI_API_TOKEN="xxxxxxxxxxxxxxxxxxxxxx"

#Run one example file
python get_indicators_of_malware.py

About

OpenCTI is a product designed and developed by the company Filigran.

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

pycti-7.260309.0.4.tar.gz (254.2 kB view details)

Uploaded Source

Built Distribution

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

pycti-7.260309.0.4-py3-none-any.whl (346.4 kB view details)

Uploaded Python 3

File details

Details for the file pycti-7.260309.0.4.tar.gz.

File metadata

  • Download URL: pycti-7.260309.0.4.tar.gz
  • Upload date:
  • Size: 254.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for pycti-7.260309.0.4.tar.gz
Algorithm Hash digest
SHA256 9af17beaf0c54d444ce8f65bbffae8646d60790a8424a6f66435e4c0be10bbae
MD5 5b89763c06e41f0f81e1a19cc9fd40fb
BLAKE2b-256 74c814e0bb85d9681ab2c5f52a52940ddd89bca706d0503f718e11f9929f5f7f

See more details on using hashes here.

File details

Details for the file pycti-7.260309.0.4-py3-none-any.whl.

File metadata

  • Download URL: pycti-7.260309.0.4-py3-none-any.whl
  • Upload date:
  • Size: 346.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for pycti-7.260309.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0eb648107b1aac6d4c6cf9abce79fdfb8835d8ea197a6bda89e23c927fc1b077
MD5 99d11534364a88522aae45a36d9592e9
BLAKE2b-256 b9f44af70e0d722bbed03c03c07d15999c1a66e717b468b08a28e0190aba9b40

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