Skip to main content

BOSA Core Library

Project description

BOSA Core

BOSA Core is a flexible plugin-based architecture that allows you to build modular and extensible applications. It provides a robust framework for managing plugins, handling dependencies, and injecting services.

Key Features

  • 🔌 Plugin-based Architecture
  • 💉 Dependency Injection
  • 🔄 Service Registry
  • 🛠️ Flexible Plugin Handlers
  • 🌐 HTTP Interface Support
  • 📊 OpenTelemetry Integration
  • 🛡️ Sentry Error Tracking
  • 📜 Logging

Installation

Prerequisites

1. Installation from Pypi

Choose one of the following methods to install the package:

Using pip

pip install bosa-core-binary

Using Poetry

poetry add bosa-core-binary

2. Development Installation (Git)

For development purposes, you can install directly from the Git repository:

poetry add "git+ssh://git@github.com/GDP-ADMIN/bosa-sdk.git#subdirectory=python/bosa-core"

Plugin Architecture Overview

Plugin Architecture

How It Works

  1. Plugin Manager: The central piece that orchestrates everything

    • Manages plugin lifecycle
    • Handles service registration
    • Initializes plugins with required dependencies
  2. Service Registry: A container for all services

    • Stores service instances
    • Handles dependency injection
    • Maps service types to their implementations
    • Note: You don't need to create your own Service Registry - it's integrated into the Manager!
  3. Plugin Handler: Interface for providing services to plugins

    • Creates service injections through create_injections
    • Initializes plugin-specific resources
    • Can be extended for different types of plugins (e.g., HTTP handlers)
  4. Plugin: Base class for all plugins

    • Has basic metadata (name, description, version)
    • Receives injected services automatically
    • Can be extended with specific functionality
  5. Open Telemetry: Initializer class to use open telemetry

    • Integrates with OpenTelemetry for tracing and metrics
    • Provides observability for plugins and services
    • Can be configured to export data to various backends (e.g., Jaeger, Prometheus)
  6. Sentry: Initializer class to use sentry

    • Integrates with Sentry for error tracking and performance monitoring
    • Captures exceptions and sends them to Sentry
    • Provides insights into application performance and errors

Authentication

BOSA Core provides a robust, multi-tenancy authentication system, allowing secure client and user management.

  1. Client Management:

    • Clients are created using a Master Key (BOSA_WHITELISTED_KEYS).
    • Each client has a unique API key used for authentication.
    • API Key Format: sk-client-<base64-client-id>.<base64-client-name>.<client-secret>.
    • Clients can manage their users and authentication settings.
  2. User Authentication:

    • Clients create users by providing an identifier.
    • Each user receives a secret, which is displayed only once.
    • Users authenticate using their identifier and secret.
    • User API Key Format: sk-user-<base64-user-id>.<base64-user-identifier>.<user-secret>.
  3. Token-Based Access:

    • Upon authentication, users receive JWT tokens for secure access.
    • Tokens are verified for subsequent requests.
    • Tokens expire after 30 days (default: 43,200 minutes).
    • Tokens can be revoked when necessary.
  4. Third-Party Integrations:

    • Users can create integrations with third-party services.
    • Authentication credentials are securely stored.
    • Each integration can be assigned scoped access.

For detailed implementation, refer to the Authentication README.

Implementation Details

The plugin system works through these key components:

1. Plugin Manager

from fastapi_interface import FastApiHttpInterface

# Create FastAPI handler
fastapi_handler = FastApiHttpInterface()

# Initialize manager with the handler
manager = PluginManager(handlers=[fastapi_handler])
manager.register_plugin(MyPlugin)
  • Initializes the plugin system
  • Manages plugin lifecycle
  • Handles service registration

2. Plugin Handler

from bosa_core.plugin import PluginHandler

class MyHandler(PluginHandler):
    @classmethod
    def create_injections(cls, instance):
        # Tell the manager what services this handler provides
        return {MyService: instance}

    @classmethod
    def initialize_plugin(cls, instance, plugin):
        # Initialize plugin resources
        pass
  • Creates service mappings via create_injections
  • Initializes plugin resources
  • Can be customized for different plugin types

3. Plugin

from bosa_core.plugin import Plugin
from fastapi_interface import FastApiService

class MyPlugin(Plugin):
    # Services will be injected automatically
    fastapi_service: FastApiService

    def __init__(self, name, description, version):
        super().__init__(name, description, version)
  • Base class for all plugins
  • Receives injected services
  • Can be extended with custom functionality

4. Open telemetry external exporter (enable fastapi & langchain instrumentation)

from bosa_core.telemetry import OpenTelemetryConfig, FastAPIConfig, init_telemetry
from fastapi import FastAPI

endpoint = "your-exporter-endpoint"
port = "your-exporter-port"
attributes = {
   "key1":"val1"
}
app = FastAPI()
use_langchain_instrumentation = True
fastapi_config = FastAPIConfig(app=app)
otel_config = OpenTelemetryConfig(endpoint=endpoint, port=port, attributes=attributes, fastapi_config=fastapi_config, use_langchain=use_langchain_instrumentation)
init_telemetry(TelemetryConfig(otel_config=otel_config))

5. Sentry

from bosa_core.telemetry import SentryConfig, init_telemetry

def traces_sampler(sampling_context: dict) -> float:
    """Determine appropriate sampling rate for Sentry transactions.
    Args:
        sampling_context: Context dictionary containing transaction information
    Returns:
        float: Sampling rate between 0 and 1
    """

    ### you can use customization (ex: for certain name sampler will be 0.1) for trace_sampler in this class
    return 1.0


dsn = "your-dsn"
environment = "development/staging/production"
release = "your release tag"
sentry_config = SentryConfig(
        dsn=dsn,
        environment=environment,
        release=release,
        traces_sampler=traces_sampler,
        send_default_pii=True,
    )
init_telemetry(TelemetryConfig(sentry_config=sentry_config))

6. Sentry with Open Telemetry (enable fastapi & langchain instrumentation)

from bosa_core.telemetry import SentryConfig, init_telemetry, FastAPIConfig, OpenTelemetryConfig
from fastapi import FastAPI


def traces_sampler(sampling_context: dict) -> float:
    """Determine appropriate sampling rate for Sentry transactions.
    Args:
        sampling_context: Context dictionary containing transaction information
    Returns:
        float: Sampling rate between 0 and 1
    """

    ### you can use customization (ex: for certain name sampler will be 0.1) for trace_sampler in this class
    return 1.0


dsn = "your-dsn"
environment = "development/staging/production"
release = "your release tag"

attributes = {
   "key1":"val1"
}
app = FastAPI()
use_langchain_instrumentation = True
fastapi_config = FastAPIConfig(app=app)
opentelemetry_init = OpenTelemetryConfig(attributes=attributes, fastapi_config=fastapi_config, use_langchain=use_langchain_instrumentation)

sentry_config = SentryConfig(
        dsn=dsn,
        environment=environment,
        release=release,
        traces_sampler=traces_sampler,
        send_default_pii=True,
        open_telemetry_initiliazer=opentelemetry_init
    )
init_telemetry(sentry_config=sentry_config)

7. Logging Ner API Handler

from bosa_core.logger import init_ner_pii_logging_handler

init_ner_pii_logging_handler(logger_name="logging-name", api_url="https://dev-api-gdplabs-ner-api.obrol.id/anonymize", api_field="text", pii_ner_process_enabled=True)


logger.info("contoh nomor ktp 3525011212941001\ncontoh email john.doe@example.com\ncontoh nomor telepon +628121729819 dan 0812898029384.\ncontoh npwp 01.123.456.7-891.234" ) # if you using gdplabs ner API output will be contoh nomor ktp <ID_KTP_1>\ncontoh email <EMAIL_ADDRESS_1>\ncontoh nomor telepon <PHONE_NUMBER_1> dan <PHONE_NUMBER_2>.\ncontoh npwp <ID_NPWP_1>

[!WARNING] If you are using Logger Ner API handler, the logging process may take some time because it needs to call an API for every log entry synchronously.

8. Logging Regex Handler

from bosa_core.logger import init_regex_pii_logging_handler

init_regex_pii_logging_handler(logger_name="logging-name", pii_regex_process_enabled=True)


logger.info("contoh nomor ktp 3525011212941001\ncontoh email john.doe@example.com\ncontoh nomor telepon +628121729819 dan 0812898029384.\ncontoh npwp 01.123.456.7-891.234" ) # if you using gdplabs ner API output will be contoh nomor ktp <ID_KTP_1>\ncontoh email <EMAIL_ADDRESS_1>\ncontoh nomor telepon <PHONE_NUMBER_1> dan <PHONE_NUMBER_2>.\ncontoh npwp <ID_NPWP_1>

Getting Started

  1. Install dependencies:

    poetry install
    
  2. Create a plugin:

    class MyPlugin(Plugin):
        name = "my-plugin"
        description = "My awesome plugin"
        version = "1.0.0"
    
  3. Register and use:

    # Using FastAPI as an example
    from fastapi import FastAPI
    from fastapi_interface import FastApiHttpInterface
    
    app = FastAPI()
    fastapi_handler = FastApiHttpInterface(app)
    manager = PluginManager(handlers=[fastapi_handler])
    manager.register_plugin(MyPlugin)
    

Development

  • Use Poetry for dependency management
  • Install pre-commit hooks poetry run pre-commit install. This will run checks before each commit.
  • Run ./build.local.sh to perform all checks:
    • Code formatting and validation (ruff)
    • Documentation style (pydocstyle)
    • Tests (pytest)
    • And more!

References

Product Requirements Documents(PRD):

  • N/A

Architecture Documents:

Design Documents:

Implementation Documents:

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 Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

bosa_core_binary-0.9.2b1-cp313-cp313-win_amd64.whl (734.5 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.9.2b1-cp313-cp313-manylinux_2_34_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ x86-64

bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_x86_64.whl (907.5 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (758.0 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.9.2b1-cp312-cp312-win_amd64.whl (739.7 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.9.2b1-cp312-cp312-manylinux_2_34_x86_64.whl (1.1 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ x86-64

bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_x86_64.whl (905.7 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (754.1 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.9.2b1-cp311-cp311-win_amd64.whl (746.2 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.9.2b1-cp311-cp311-manylinux_2_34_x86_64.whl (981.7 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.34+ x86-64

bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_x86_64.whl (882.4 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (737.6 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

Details for the file bosa_core_binary-0.9.2b1-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 983a2aa0579ce7c2ba1c1fd1caab81b897b03c1ffa9c6b580485d90d456184dd
MD5 de3c8e51fcba745afbdc93c771bade53
BLAKE2b-256 b606c75dbf4e4882f542977246d2f56ac29024579e0d507cd610755340e6d38f

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp313-cp313-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp313-cp313-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 7b7d3ca86db295c7644b576358db0a5ea67ca11d2c2f18db464e2d09d34646e9
MD5 646942e8fbca4d7a3c2aa8cafe7f7c3d
BLAKE2b-256 4d4ad8417ae6bbe61621a276a3c25a8c993ae322b3a42b8dfd3e44153eef9456

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 29f7ff2864cdd5f7c4b5934c60e5620739f77bd6d87548294201e1093e774dfa
MD5 595a3690fd2b35f696a28065bb3e50da
BLAKE2b-256 e8639a22ee48294a9fc7282c16b258a5783576cdba35a13fc4fa58b1a3f2a91a

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_x86_64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 13822c1c641fd9f9b6e2cf2108dd64c94f8ba2403257af8d4019384ebb6455f4
MD5 1dfdfa8644210fa3acb596ec021a11fc
BLAKE2b-256 8d53e53a547105b814efce4f8dd0935d626e841edff0e8a8ac9de7578888e195

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 ec9908c9398754b6bd4406dd81204d088cc5c920c88415bfbf2b672fbb0e383d
MD5 f71f756d3cc215091307add335499a71
BLAKE2b-256 658b36c8dfcb7032ec7bc93d07441db8a61657b361855e6b291efdeb9f7e0fde

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp312-cp312-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp312-cp312-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 6d5f8b81a6fc121b92634606c7f1b5eeee51b6fed3c31929d761a6735cb1a035
MD5 8d3a4681926052fb7249af03ebd35135
BLAKE2b-256 a17396f00cddb113f109352cf56988517e0a14fec1e69cd237890b5d9f045e2f

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 760886011c27c27978cd448aae0128b22a171c76a2b98f7e8a1c5814190d3a1c
MD5 79e439cf9e708c1ddcc197accf9b1c51
BLAKE2b-256 6f3ea43c7de26ed9baa64173605ed821b1c376b8bbeb4262fa788d16291eabe2

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_x86_64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 7c9c40bbad5465612fa59f794097d4d8adea4caa87e328a09c7cef3e13a4e3c6
MD5 01f36c41c870ca23071195fc5bc0fca9
BLAKE2b-256 fd9dff1edd9c7f00f5b2789d135330b9478be2c5714b05d24f1e4702d2a83cf7

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 ff87df60572f5acc1d4599a0a75e9414b07b097a326cc4d89f2ba81eb789ae2e
MD5 04ac1ae6542fb6cf062bd611de188b56
BLAKE2b-256 e1331ccf10182feaf595fe5340796f968a49d2e8468e777d48c88568c1b55416

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp311-cp311-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp311-cp311-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp311-cp311-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 97349a40c4815be267ecdb923d0d1f3660c86da76cc4737cd8e9dfeef0a3804a
MD5 d6ef7c8d229b372db113f2d6e500f4da
BLAKE2b-256 bc929e31589d33dc759a3f5e3117ba03d0662f010a6958d052eba4b8286acd9d

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 ef7c45c981a8b70bfced4d610ebe3d7b8ac1d28c6e520aaea05da9f8742b6998
MD5 1578a40769675f8e32e97e7c8837c2eb
BLAKE2b-256 59424e63b3b7f4018e2d7b7e4d862031f203acdb2ca4c056798315ed59a21b92

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_x86_64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 7077a68643fc9dac633fd43470ad185c20d24701f18247333a4c4d9a1d4d5e2e
MD5 0b196f9e78253ab9f795b6a7d2b09d36
BLAKE2b-256 5742d35e4092c341baa812830e9811cb1bcc6950dc0483e08e8c3ff6951ac685

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.9.2b1-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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