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

This version

0.7.3

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

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.7.3-cp313-cp313-manylinux_2_31_x86_64.whl (992.3 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.7.3-cp313-cp313-macosx_13_0_x86_64.whl (794.7 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_core_binary-0.7.3-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (664.5 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.7.3-cp312-cp312-win_amd64.whl (666.2 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.7.3-cp312-cp312-manylinux_2_31_x86_64.whl (992.3 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.7.3-cp312-cp312-macosx_13_0_x86_64.whl (792.7 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_core_binary-0.7.3-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (663.0 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_core_binary-0.7.3-cp311-cp311-win_amd64.whl (666.9 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.7.3-cp311-cp311-manylinux_2_31_x86_64.whl (894.7 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_core_binary-0.7.3-cp311-cp311-macosx_13_0_x86_64.whl (772.8 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_core_binary-0.7.3-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (646.2 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 b06e3cd224e85bd5b2c97574f79198d48c24bbe19b231bfb0faf2ba6acfdb353
MD5 72fe6fdbddaaa3d611631de7bcad74d3
BLAKE2b-256 3ef0a4b647a927d1c523b382d21eb70a03ff8072e4fd8cfea3fcde227133cd2c

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 9d7aebeaa333ea935f832f6aa1cd0d6ac04f8fd15a4c305c18b4f61c9ba0f7b3
MD5 d217d9bd1e421f8621f947b227ec3496
BLAKE2b-256 dac821471cd8a5323ceacd8063ab2ea2d6ffa54712cfc3f393c0bd981c9eb723

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 298f497fb50ed534e34e184810ec97cb74299c6abd87ca44fb24c1ec9db9d65c
MD5 8d2ac503803dc79448d86902db02e39b
BLAKE2b-256 417b19b069fd111b02b31664c2dcb9d19b49b618bab2abef841b0343634fae71

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 07492a2272d29d02bf86936a9b38f3ebec4223e478f8fc8fc8c13f98f69e426b
MD5 f52abdf3e26723d0dc5868f02384f204
BLAKE2b-256 fa5b350f5bc60fdfb966e7d3478ffde821ad8ecdbdf7115ebffae936b5c561c0

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 ff6d9ddb1ecf38ffb69d8a28f43f4113c57e2f0cb72505cfa679fde646897ff6
MD5 6710cd878a930d3230abedc4a3c99882
BLAKE2b-256 f541ad75b83e07cbc366128814f5fde3b9e217885d5882fc528fc8f661b09b6e

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 2e1e3eb017fb2d044a340910beb0a63711b964c6b2c4100be873107b27fb4b4b
MD5 fa344371ad2a6a31ee8ec5b040f72cec
BLAKE2b-256 2b95a34ec3642c12f23bccc020833564cc0c8f184e5cec8d1dc69b14cbb3d2fc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 e4737713b4bbf001c98af177dba071c9afb9e4d925ab8b6b3ddfdfd187a85d7e
MD5 289407b1b8695afb500857b44de463f2
BLAKE2b-256 17f025ef78f95c4d9c671accf77b916d7616a0635bdabf41f523229afe7e376e

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 7ac673461e7347a44836e131f08e37a92b2ba4eb35102fac1ccc86a75e6e90e9
MD5 495f59269e1d84b2c66d71f41a1605af
BLAKE2b-256 11005a717121712b91cf1e6927a27b50a4a730025907338c65bd4c88a5452cb7

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 be745f5c09d014fda4860131f5da14ecf97f56f38132922a8a364def0a6b4755
MD5 ae80f45605029c8e8712455f2fa7975e
BLAKE2b-256 94ac1356dfb414d55c6718f2945f67aaeefbd4dae029daf08a0944e981a6a544

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 4d3d1c745c0c1bd162304299fb7fdda2f40d088f6c1f0a05e30ef691cf2a8b24
MD5 5209a4e2ee002c4ae69e9d179f0fc0e5
BLAKE2b-256 a8aa3d193e86fc7892b9d63974ff4534180c9f4a5e4f3fcf82a5acf4f9db0422

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 320999ed8383ee16de7660baca4ebd6faf08d8daeaa374e6ef54ae9aff25d164
MD5 cac4cce52eb93d40a5847f65419832ea
BLAKE2b-256 0a2ea33c9f6346ce99e53accdcfb32e1a4e7b8a4f7c184f20ee06de0e4c94e0f

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.7.3-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 1a0d19671bee7618149623dc431fadbfc3636df7d7350591feb23dd8654f6962
MD5 624ae6e3931a6f613383f496278c203c
BLAKE2b-256 bbbd4504dfc9ad5bb7a72c86fe8963587cc7007eb2a18ec823bda0e8952fdc45

See more details on using hashes here.

Provenance

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