feat(clean-release): complete compliance redesign phases and polish tasks T047-T052
This commit is contained in:
@@ -14,8 +14,16 @@ from .core.config_manager import ConfigManager
|
||||
from .core.scheduler import SchedulerService
|
||||
from .services.resource_service import ResourceService
|
||||
from .services.mapping_service import MappingService
|
||||
from .services.clean_release.repositories import (
|
||||
CandidateRepository, ArtifactRepository, ManifestRepository,
|
||||
PolicyRepository, ComplianceRepository, ReportRepository,
|
||||
ApprovalRepository, PublicationRepository, AuditRepository,
|
||||
CleanReleaseAuditLog
|
||||
)
|
||||
from .services.clean_release.repository import CleanReleaseRepository
|
||||
from .core.database import init_db, get_auth_db
|
||||
from .services.clean_release.facade import CleanReleaseFacade
|
||||
from .services.reports.report_service import ReportsService
|
||||
from .core.database import init_db, get_auth_db, get_db
|
||||
from .core.logger import logger
|
||||
from .core.auth.jwt import decode_token
|
||||
from .core.auth.repository import AuthRepository
|
||||
@@ -55,8 +63,10 @@ logger.info("SchedulerService initialized")
|
||||
resource_service = ResourceService()
|
||||
logger.info("ResourceService initialized")
|
||||
|
||||
clean_release_repository = CleanReleaseRepository()
|
||||
logger.info("CleanReleaseRepository initialized")
|
||||
# Clean Release Redesign Singletons
|
||||
# Note: These use get_db() which is a generator, so we need a way to provide a session.
|
||||
# For singletons in dependencies.py, we might need a different approach or
|
||||
# initialize them inside the dependency functions.
|
||||
|
||||
# [DEF:get_plugin_loader:Function]
|
||||
# @PURPOSE: Dependency injector for PluginLoader.
|
||||
@@ -109,15 +119,45 @@ def get_mapping_service() -> MappingService:
|
||||
# [/DEF:get_mapping_service:Function]
|
||||
|
||||
|
||||
_clean_release_repository = CleanReleaseRepository()
|
||||
|
||||
# [DEF:get_clean_release_repository:Function]
|
||||
# @PURPOSE: Dependency injector for CleanReleaseRepository.
|
||||
# @PRE: Global clean_release_repository must be initialized.
|
||||
# @POST: Returns shared CleanReleaseRepository instance.
|
||||
# @RETURN: CleanReleaseRepository - Shared clean release repository instance.
|
||||
# @PURPOSE: Legacy compatibility shim for CleanReleaseRepository.
|
||||
# @POST: Returns a shared CleanReleaseRepository instance.
|
||||
def get_clean_release_repository() -> CleanReleaseRepository:
|
||||
return clean_release_repository
|
||||
"""Legacy compatibility shim for CleanReleaseRepository."""
|
||||
return _clean_release_repository
|
||||
# [/DEF:get_clean_release_repository:Function]
|
||||
|
||||
|
||||
# [DEF:get_clean_release_facade:Function]
|
||||
# @PURPOSE: Dependency injector for CleanReleaseFacade.
|
||||
# @POST: Returns a facade instance with a fresh DB session.
|
||||
def get_clean_release_facade(db = Depends(get_db)) -> CleanReleaseFacade:
|
||||
candidate_repo = CandidateRepository(db)
|
||||
artifact_repo = ArtifactRepository(db)
|
||||
manifest_repo = ManifestRepository(db)
|
||||
policy_repo = PolicyRepository(db)
|
||||
compliance_repo = ComplianceRepository(db)
|
||||
report_repo = ReportRepository(db)
|
||||
approval_repo = ApprovalRepository(db)
|
||||
publication_repo = PublicationRepository(db)
|
||||
audit_repo = AuditRepository(db)
|
||||
|
||||
return CleanReleaseFacade(
|
||||
candidate_repo=candidate_repo,
|
||||
artifact_repo=artifact_repo,
|
||||
manifest_repo=manifest_repo,
|
||||
policy_repo=policy_repo,
|
||||
compliance_repo=compliance_repo,
|
||||
report_repo=report_repo,
|
||||
approval_repo=approval_repo,
|
||||
publication_repo=publication_repo,
|
||||
audit_repo=audit_repo,
|
||||
config_manager=config_manager
|
||||
)
|
||||
# [/DEF:get_clean_release_facade:Function]
|
||||
|
||||
# [DEF:oauth2_scheme:Variable]
|
||||
# @PURPOSE: OAuth2 password bearer scheme for token extraction.
|
||||
oauth2_scheme = OAuth2PasswordBearer(tokenUrl="/api/auth/login")
|
||||
|
||||
Reference in New Issue
Block a user