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.6.2-cp313-cp313-win_amd64.whl (666.1 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.6.2-cp313-cp313-manylinux_2_31_x86_64.whl (999.4 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.6.2-cp313-cp313-macosx_13_0_x86_64.whl (800.7 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.6.2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (671.4 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.6.2-cp312-cp312-win_amd64.whl (670.4 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.6.2-cp312-cp312-manylinux_2_31_x86_64.whl (999.6 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.6.2-cp312-cp312-macosx_13_0_x86_64.whl (799.5 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.6.2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (669.1 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.6.2-cp311-cp311-win_amd64.whl (671.6 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.6.2-cp311-cp311-manylinux_2_31_x86_64.whl (900.7 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.6.2-cp311-cp311-macosx_13_0_x86_64.whl (780.4 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_core_binary-0.6.2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (653.4 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

Details for the file bosa_core_binary-0.6.2-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 ac5f61fb0b99d271971461eac008adf3182a71a7f55aba90531ae2f1538d5d8a
MD5 2453681316da6980607f24b7a0879fe2
BLAKE2b-256 34f1977cf5faee180a19cd36855ed7b292f2ab8351d769246e27e2c089d7615a

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 4c358c69c3362663b50afcb2df58768852cb50ad4e0020bfa79db567d176d2eb
MD5 ea8d962e36ec474ae8491ce4c15af3a4
BLAKE2b-256 ec32ab06ecaa3ec1a1b8a789e498fc58630c36048e2ee00cc9d9b2ac0c7f285f

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.6.2-cp313-cp313-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 4c969bc4f96bc1fed42b14de9ab6aff6dc0f5a66f61ee6fdb75556b0dbabee91
MD5 80d73edf08e196c7e00516c020a5df0d
BLAKE2b-256 ac51002019d6bfc250b73f49b82aa4fddbdc13528f9f6734a54c06dfe73efcdf

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.6.2-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.6.2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 b731f81daeb2acd890844a252a9b1a273d77312578ce3ed6f2f0f64a41f1529a
MD5 8145a200088ce0efbbe23e45f690247f
BLAKE2b-256 e7c581c96a8e049bea1cd5ac09239b881e87da1a0666d2a8a8f51458be0e63ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.6.2-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.6.2-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 424975b2a47807935f3ecfd5f63e42a78eb1f23695dafa3ae2e440a43b293886
MD5 b5176c140c335e50279c24376501ba59
BLAKE2b-256 7fd2003bf766ffc3a3b0abe13aecd02e86d41b00c4ccc60f19631e1864c1777a

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 4c30fb4756594f17d8fa67accce3cc567ef7cc1601418b1d756064ca1de776f5
MD5 5b46c225342aede1277f6127f25b7eeb
BLAKE2b-256 11cde2b2c237d2df35823e65a052779f1e745af02d966629bae095801ae40c72

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.6.2-cp312-cp312-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 e8d615fd8caa5292ff27f69e85d36ff0786b01074155d1d99275070e358c169d
MD5 2a2e31d0f72df4e90ef6737c733f8795
BLAKE2b-256 f059cba681642d3264f48a7d5b8c19fd27a76a8fc8a8e5a425054418b922cfc6

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.6.2-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.6.2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 689860a67ea3c72f82b7a0a7ce0219e38a1848be6d944b5d0b05ce527774c568
MD5 6bad07fb930c1e600c95b28483beb7a7
BLAKE2b-256 b42a0e344336061deee30c116d22be59c119ca2199322706b2f6086e5aec2f98

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.6.2-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.6.2-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 bd6d4ed5616d470c4b2d3d22502ca62416e19e8857b0e06a11aa09ab17c9152a
MD5 704bc0d2b4bc10d8373c5a35d9f5bf6d
BLAKE2b-256 82b71df3d05dc4ab0bd43081ad9cddac00da5ee1a8c1c5a469c84c683f1d0e97

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 663ad836b61869c0eab618d86bbc8aa6bb407361d168137fba52a7eea547c60d
MD5 bd97615c8035d347f84a71c543f06523
BLAKE2b-256 2a4a89c533f3bd359993c5abef5233ffd5fd0e7cf11acb8ba00fd88a1cb43ce6

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.6.2-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 27c27abfc985ff497ef31773dfbd98c2c8645b3e524cc848640b8f102e67ee19
MD5 fe1e9615958e3a4e90dceab8f6013a36
BLAKE2b-256 1b354443c0f7a1059085673819c5a8afcbb945e5b81c4952ba368f2dad298168

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.6.2-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.6.2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.6.2-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 70611675383e52798ece1da1ab4709fc7176c6a9ef077b7a2f91279209edfd98
MD5 79753a5ba5ca4933977683778872e849
BLAKE2b-256 43dc73a12ec17740bd0ac4cb67603eb30804fe5d9da318d516a13d1c1a22c7a6

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_core_binary-0.6.2-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