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.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.5.1b4-cp313-cp313-win_amd64.whl (638.7 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.1b4-cp313-cp313-manylinux_2_31_x86_64.whl (950.6 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.1b4-cp313-cp313-macosx_11_0_universal2.whl (637.3 kB view details)

Uploaded CPython 3.13macOS 11.0+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1b4-cp313-cp313-macosx_10_13_universal2.whl (731.6 kB view details)

Uploaded CPython 3.13macOS 10.13+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1b4-cp312-cp312-win_amd64.whl (643.1 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.1b4-cp312-cp312-manylinux_2_31_x86_64.whl (951.4 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.1b4-cp312-cp312-macosx_11_0_universal2.whl (636.3 kB view details)

Uploaded CPython 3.12macOS 11.0+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1b4-cp312-cp312-macosx_10_9_universal2.whl (728.0 kB view details)

Uploaded CPython 3.12macOS 10.9+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1b4-cp311-cp311-win_amd64.whl (643.8 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.1b4-cp311-cp311-manylinux_2_31_x86_64.whl (861.0 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.5.1b4-cp311-cp311-macosx_11_0_universal2.whl (619.7 kB view details)

Uploaded CPython 3.11macOS 11.0+ universal2 (ARM64, x86-64)

bosa_core_binary-0.5.1b4-cp311-cp311-macosx_10_9_universal2.whl (719.9 kB view details)

Uploaded CPython 3.11macOS 10.9+ universal2 (ARM64, x86-64)

File details

Details for the file bosa_core_binary-0.5.1b4-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 7b33a1dd5d0b71920908d6c415a6cca300c0e977d030139adbeec6589e5589f6
MD5 a7e723c7eac9c6b347b2fa043ec43511
BLAKE2b-256 28a3a1e6cb32978f33c5da22d3c917ef72167148f6aec4a3400cb89b82486d15

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-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.5.1b4-cp313-cp313-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 5a9d2cdb7f0379532daa1b73c14b2ff203f2f03e8a41fbdc13d2d8907c432e1d
MD5 845fe8d8ca79889be1d74338e888ef3e
BLAKE2b-256 e9227a2be12788c5eaeb13bf6b97b8364b3fa2f9ac3fd283371cc4576dc2dfc9

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b4-cp313-cp313-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp313-cp313-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 76c43f398668c054e21f41d3ddffa831e3f58f64af483bb741b6231ffdb5cadd
MD5 2a48fea641c12f828906372ba9bb4f1d
BLAKE2b-256 a34e59bf9e8582a0b0c3b4a58555112b0862acd20ed20ccfc1c4913d195bf0f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-cp313-cp313-macosx_11_0_universal2.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.5.1b4-cp313-cp313-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp313-cp313-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 44b89d5bdb7cb08deec0ff936a81e2502f4860332b0ff01e80afb14f3fc7662e
MD5 ec91c2df0665f4be337fbcd03eaaad20
BLAKE2b-256 f492b475a33a9acfd4326eaf02284d4331121b440ad58fa34c23b3ae4d64e304

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-cp313-cp313-macosx_10_13_universal2.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.5.1b4-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 d0ecc8a6db105690e5405b25f13450621300079bfc56f48d628adef1403ed436
MD5 3ce3951ee403fb3dd394c15fc38a28bb
BLAKE2b-256 e81cc737872f060f6a78aff5a1120fffcd27099505c9446c2784db5cbca7cc5b

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-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.5.1b4-cp312-cp312-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 9f99825d27634254025f02ebf3db223be0a2039f167aeb36f2b31662bf4aad48
MD5 49743db65db7f9b99011dcf0e1529b6c
BLAKE2b-256 c05530988746c83913a53888f26ae0e5f2e8aa111ad4b7c325998f5b7088bc63

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b4-cp312-cp312-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp312-cp312-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 021590d2cdea683e84e564437507af2c9f70b2e08067218967d6fb79a4599ada
MD5 69ba0c62fdab8495cbd6667ef4fd9180
BLAKE2b-256 e01349b6beafbbed3d30b595062362ccd04305bc6a2ca3c2770d266bf9b9dc10

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-cp312-cp312-macosx_11_0_universal2.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.5.1b4-cp312-cp312-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp312-cp312-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 4884cd519ff2cb723cb9cd994a43be1edde0359db2b8147e765947db026ed145
MD5 66dc817f8c22aa7c1d98b76afd704e76
BLAKE2b-256 aca1250c0f8467ec38255e67a51ae75ebf2d5563aea07c8a8c97176ff06dfe84

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-cp312-cp312-macosx_10_9_universal2.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.5.1b4-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 aa351bbfa7eadf171281621333daf0c28fa3ce6a7afdc854a4bb8d1552666bdf
MD5 c69e2eb4d7fd35870700ef81ceeb47fc
BLAKE2b-256 1d928e9efc0a1cf2d5f3b35f81f73bc183af835ecf33bde5ecfd3ba280df9199

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-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.5.1b4-cp311-cp311-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 b0ddaf5afbc01ab1f65ba5d34308241d2be7d61c912f38470ddd01892a84cf46
MD5 9b24aecbaf63496064f3426f62715df5
BLAKE2b-256 5d7adfc3387d05ed9024b47e96a64d02a6ea2271817ec5d5e6d5c8e862ee3f5f

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b4-cp311-cp311-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp311-cp311-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 95234a43f3d640889995a0f0d08d43d84863b8ef9ee91cf0177d9a40e69f781d
MD5 bbbe30845fddd4a9c25c9e96ea536aa0
BLAKE2b-256 4ce06f4c88304b87a013f7b80b33569636fb4a09aa0f5786cb22cdb5c94fdf50

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-cp311-cp311-macosx_11_0_universal2.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.5.1b4-cp311-cp311-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b4-cp311-cp311-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 a7b9f16185ef53de2825c393451372c00804921912d3bd94c463e25cef4f57f6
MD5 3baa4a59a637deb4104370f579de5fb7
BLAKE2b-256 d7f2c89a47fec3b05708bce521409aa84a4534ffb8103757ec94910ddb0f8122

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.5.1b4-cp311-cp311-macosx_10_9_universal2.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