Skip to main content

BOSA Core Library

Project description

BOSA Core

dummy commit

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

Uploaded CPython 3.13Windows x86-64

bosa_core_binary-0.5.1b1-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.1b1-cp313-cp313-macosx_11_0_universal2.macosx_13_0_arm64.whl (630.9 kB view details)

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

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

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

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

Uploaded CPython 3.12Windows x86-64

bosa_core_binary-0.5.1b1-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.1b1-cp312-cp312-macosx_11_0_universal2.macosx_13_0_arm64.whl (629.9 kB view details)

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

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

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

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

Uploaded CPython 3.11Windows x86-64

bosa_core_binary-0.5.1b1-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.1b1-cp311-cp311-macosx_11_0_universal2.macosx_13_0_arm64.whl (618.7 kB view details)

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

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

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

File details

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 3c60008973ba7a5d907b12a27eed556d43548480075a0fca1cfc9720df130124
MD5 645ca7409d3246e53407bfddbdbf8582
BLAKE2b-256 dd4dd2893e317e612e9c88ecd2a1e162e6dba45f3564583ed6e69c4a716bbcaf

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 b386bca3d497a7359304e3d5806068031c708b145c4c043e41f0ab8a4f728053
MD5 709ea9e64d9bdb02a6445b240839b65e
BLAKE2b-256 dcf1ed22c3cbb940acc2dfd56deecb34b8377c1171ef12c29332c680dc59822a

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b1-cp313-cp313-macosx_11_0_universal2.macosx_13_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp313-cp313-macosx_11_0_universal2.macosx_13_0_arm64.whl
Algorithm Hash digest
SHA256 3dec91755ccc7d8e1e1af90b12735d0ee7af2424b03b88085dcd5eec063e203f
MD5 2a041e39d9371bdf013b19a681ac3dc8
BLAKE2b-256 aa59704369e06f4479e30879151961e2a91b2bdeecea099319b9603e7e79cbec

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp313-cp313-macosx_10_13_universal2.macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 182dfd179b0b963b12bc2b025893c8c198bb2c00120778e4c3971a635f85ee5d
MD5 061c3c5d5d7eee8d961c0d34fca53a90
BLAKE2b-256 15286fb87ce7a171c87baca76442dfb977a831b90654891398ea8ad8fea483a2

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 c50f639c2af8c8f04c827c10832edab786f7325c6530c9cc734ee0e8187d51d1
MD5 ea4ef9bc665f7aabe82f05bb0b77c214
BLAKE2b-256 9f2d4e2a2b186e4396afbdab776683df8e7b10aa7e810af491e1a7f2aebf0389

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 ed9985c036781694bed44dceef1b102c32ec346ea2302d2dc9a94b606db8098a
MD5 519b8cc59f26a205cb9a5f43be66bc41
BLAKE2b-256 5bfda73dfa6f436f6d3c2d74b6736c1dbb1527796e4847a3c8641aa3d5b1eb49

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b1-cp312-cp312-macosx_11_0_universal2.macosx_13_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp312-cp312-macosx_11_0_universal2.macosx_13_0_arm64.whl
Algorithm Hash digest
SHA256 0cbe60fb05fb547cbf23e95caea9384aadb069697b7e0dfc93d6df0b1624aa76
MD5 d25881388a9bd2159d24540f7f79b03e
BLAKE2b-256 ae53b260e31992448c81b325aeb2b185257f4796904bc6e71b83da933fdda8b9

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp312-cp312-macosx_10_9_universal2.macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 ecc05cea1ede39058b78d5296dcc64ff1c3e5dcd8c40c20b1509df3853fc5fa3
MD5 7074b29ad14e43460fc4f7e885693675
BLAKE2b-256 4581146a0ab74acf3663ab8d21ff32859d84488a9232d8eeceb20b795a21fccb

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 ffb8ffa7877461a7c90a858b93975d04045925e2c5fc32103d1b240188f69d95
MD5 3fb45f51ba539a77d49cd228cba65441
BLAKE2b-256 9e3d4da3c279d59434a3ac0b995ce0611e6c026edd321b97b4028cefb384671c

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 92427c4ad4f1270053f4e25bf09205201b8aae3e7b6fbe9d8aa8268d874a34ef
MD5 fe4fc22346ef39001555430413111864
BLAKE2b-256 3a432b2fc52c8bb89b376be305b02dae6745485e0c0257c89c2b86265752797b

See more details on using hashes here.

File details

Details for the file bosa_core_binary-0.5.1b1-cp311-cp311-macosx_11_0_universal2.macosx_13_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp311-cp311-macosx_11_0_universal2.macosx_13_0_arm64.whl
Algorithm Hash digest
SHA256 5890279faf9347c7e987696064e7069cf48b0e8d4d3a782b36dcbe056195f0d1
MD5 e7604b6aa327ceb7374bf8be8e245d89
BLAKE2b-256 922dd29c74d29a22688ec680bce548542110474d392d6d38f91e7986a2b8bee0

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for bosa_core_binary-0.5.1b1-cp311-cp311-macosx_10_9_universal2.macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 8de077b561b9ea61a64432daa22d9199289877fd8a2f0baa07e87eec2c34dbc6
MD5 625c145d83c237dcb6cdba979002d54f
BLAKE2b-256 57e8223ab83dab028ab9045ea1dd37a8968ed762d462cd2b860512d63cd90f5c

See more details on using hashes here.

Provenance

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

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