Skip to main content

Python bindings for accessing OSIDB API

Project description

OSIDB Bindings

A Pythonic way to talk to OSIDB without getting lost in HTTP details.

Requirements

  • gcc
  • krb5-devel
  • pip
  • python3
  • python3-devel

Installation

Install the bindings using pip (recommended within a virtual environment):

pip install osidb-bindings

Quick Start

Basic Authentication

import osidb_bindings

# For local OSIDB instances with username/password authentication
session = osidb_bindings.new_session(
    osidb_server_uri="http://localhost:8000/",
    username="your_username",
    password="your_password"
)

Kerberos Authentication

# For production/staging instances with Kerberos authentication (default)
session = osidb_bindings.new_session(osidb_server_uri="https://your-osidb-instance.com/")

Basic Operations

# Check connection status
status = session.status()

# Retrieve a specific flaw
flaw = session.flaws.retrieve(id="CVE-1111-2222")

# Access flaw attributes
print(flaw.title)
print(flaw.impact)

# Convert to dictionary for easier manipulation
flaw_dict = flaw.to_dict()
print(flaw_dict["title"])
print(flaw_dict["impact"])

# Retrieve multiple flaws with filtering
critical_flaws = session.flaws.retrieve_list(impact="CRITICAL")
recent_flaws = session.flaws.retrieve_list(changed_after="2023-01-01")

# Access paginated results
print(f"Total flaws found: {critical_flaws.count}")
for flaw in critical_flaws.results:
    print(f"CVE: {flaw.cve_id}, Impact: {flaw.impact}")

API Version Control

# Use latest API version (default behavior)
flaw = session.flaws.retrieve(id="CVE-1111-2222")

# Specify a particular API version for stability
flaw = session.flaws.retrieve(id="CVE-1111-2222", api_version="v1")

# Discover available API versions
print(session.endpoints)

Documentation

Features

  • Automatic Authentication - Handles JWT token refresh automatically
  • Multiple API Versions - Support for v1, v2, and future API versions
  • Intuitive Interface - Pythonic API that mirrors OSIDB REST endpoints
  • Comprehensive Coverage - Access to flaws, affects, trackers, and more
  • Pagination Support - Built-in handling of paginated responses
  • Error Handling - Clear exceptions for better debugging

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

osidb_bindings-5.0.0b1.tar.gz (281.4 kB view details)

Uploaded Source

Built Distribution

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

osidb_bindings-5.0.0b1-py3-none-any.whl (708.3 kB view details)

Uploaded Python 3

File details

Details for the file osidb_bindings-5.0.0b1.tar.gz.

File metadata

  • Download URL: osidb_bindings-5.0.0b1.tar.gz
  • Upload date:
  • Size: 281.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for osidb_bindings-5.0.0b1.tar.gz
Algorithm Hash digest
SHA256 3af746ce6ad2ef80558e85e283a80d64c0206eacaf8be1f63bc12bd1a16d5cd0
MD5 3b6f86546859f87574a2b922237144f8
BLAKE2b-256 fdc08718c59489f6eea16d28efacb54a004cb398bc96e8d8b6b0aed501c7aeba

See more details on using hashes here.

File details

Details for the file osidb_bindings-5.0.0b1-py3-none-any.whl.

File metadata

File hashes

Hashes for osidb_bindings-5.0.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 0ee4dd6bcabaa2a428c4b71b3f5a5ea1e57cfb5c845a96ed3fc9b4da7cd872ef
MD5 a34fd68d4cc8f342f2c90e00343f553a
BLAKE2b-256 7e22413e0b2bb43db3f02200651a10f4242b3dfdcede760fed4b66d7a5de959d

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