Skip to content

Torward1024/MSB

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

69 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MSB Architecture

Python Version License Version

Mega-Super-Base (MSB) - a flexible and extensible architecture for Python applications, providing a modular system for managing entities, containers, operations, and projects with built-in type safety, serialization, and logging.

Features

  • Typed Entity Management: Automatic attribute validation and serialization.
  • Containers for Collections: Support for queries and bulk operations on entities.
  • Flexible Operation System: Through Super-classes with method resolution.
  • Projects as High-Level Containers: High-level data organization.
  • Universal Serialization: Support for nested objects and cyclic references.
  • Integrated Logging and Validation: Full support for logging and data validation.
  • No External Dependencies: Requires only Python >= 3.12.

Installation

pip install msb_arch

Quick Start

from msb_arch.base.baseentity import BaseEntity
from msb_arch.super.project import Project

class MyEntity(BaseEntity):
    value: int

class MyProject(Project):
    _item_type = MyEntity

    def create_item(self, item_code: str = "ITEM_DEFAULT", isactive: bool = True) -> None:
        item = MyEntity(name=item_code, isactive=isactive, value=42)
        self.add_item(item)
    def from_dict():
        pass

project = MyProject(name="MyProject")
project.create_item("item1")
print(project.get_item("item1").to_dict())
# Output: {'name': 'item1', 'isactive': True, 'type': 'MyEntity', 'value': 42}

Architecture

The project is divided into 4 modules:

Main classes:

  • BaseEntity: Abstract class for entities with type validation, serialization, and caching.
  • BaseContainer[T]: Generic container for BaseEntity collections with query and operation support.
  • Super: Abstract class for operation handlers with method resolution.
  • Project: Class for managing projects as entity containers.
  • Manipulator: Central class for operation registration and request processing.

API

Complete API reference is available in docs/api.md.

Examples

Practical usage examples are available in docs/examples.md.

Testing

The project includes a complete set of unit, integration, and performance tests using pytest. Tests are located in the tests/ directory and cover all modules with high coverage rates.

To run tests:

pytest tests/

License

MSB is licensed under the MSB Software License for non-commercial and research use, allowing free use, modification, and distribution for non-commercial purposes with attribution.

For commercial use, a separate royalty-bearing license is required. Please contact almax1024@gmail.com for details.

Contacts

About

Mega-Super-Base Architecture

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages