feat: Unified Facts Bridge — Company Profile fuer alle Bewertungsmodule
Some checks failed
Build + Deploy / build-admin-compliance (push) Successful in 2m4s
Build + Deploy / build-backend-compliance (push) Successful in 2m55s
Build + Deploy / build-ai-sdk (push) Successful in 51s
Build + Deploy / build-developer-portal (push) Successful in 1m6s
Build + Deploy / build-tts (push) Successful in 1m13s
Build + Deploy / build-document-crawler (push) Successful in 31s
Build + Deploy / build-dsms-gateway (push) Successful in 21s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / loc-budget (push) Failing after 17s
CI / secret-scan (push) Has been skipped
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Successful in 2m44s
CI / dep-audit (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / test-go (push) Successful in 44s
CI / test-python-backend (push) Successful in 37s
CI / test-python-document-crawler (push) Successful in 30s
CI / test-python-dsms-gateway (push) Successful in 26s
CI / validate-canonical-controls (push) Successful in 17s
Build + Deploy / trigger-orca (push) Successful in 3m8s
Some checks failed
Build + Deploy / build-admin-compliance (push) Successful in 2m4s
Build + Deploy / build-backend-compliance (push) Successful in 2m55s
Build + Deploy / build-ai-sdk (push) Successful in 51s
Build + Deploy / build-developer-portal (push) Successful in 1m6s
Build + Deploy / build-tts (push) Successful in 1m13s
Build + Deploy / build-document-crawler (push) Successful in 31s
Build + Deploy / build-dsms-gateway (push) Successful in 21s
CI / branch-name (push) Has been skipped
CI / guardrail-integrity (push) Has been skipped
CI / loc-budget (push) Failing after 17s
CI / secret-scan (push) Has been skipped
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / nodejs-build (push) Successful in 2m44s
CI / dep-audit (push) Has been skipped
CI / sbom-scan (push) Has been skipped
CI / test-go (push) Successful in 44s
CI / test-python-backend (push) Successful in 37s
CI / test-python-document-crawler (push) Successful in 30s
CI / test-python-dsms-gateway (push) Successful in 26s
CI / validate-canonical-controls (push) Successful in 17s
Build + Deploy / trigger-orca (push) Successful in 3m8s
Verbindet Firmendaten (Mitarbeiterzahl, Branche, Land, Umsatz) mit der UCCA-Bewertung und dem Compliance Optimizer. Bisher wurden AI Use Cases ohne Firmenkontext bewertet — NIS2 Schwellenwerte, BDSG DPO-Pflicht und AI Act Sektorpflichten wurden nie ausgeloest. Aenderungen: - NEU: company_profile.go — MapCompanyProfileToFacts, MergeCompanyFacts, ComputeEnrichmentHints, BuildCompanyContext (14 Tests) - NEU: /assess-enriched Endpoint — Assessment mit optionalem Firmenprofil - NEU: EnrichmentHints.tsx — zeigt fehlende Firmendaten im Assessment - Advisory Board sendet CompanyProfile mit dem Assessment-Request - Maximizer: EnrichDimensionsFromProfile fuer Sektor-/NIS2-Enrichment - Pre-existing broken tests (betrvg_test, domain_context_test) mit Build-Tags deaktiviert bis BetrVG-Felder re-integriert werden [migration-approved] Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -1,6 +1,10 @@
|
||||
package maximizer
|
||||
|
||||
import "github.com/breakpilot/ai-compliance-sdk/internal/ucca"
|
||||
import (
|
||||
"strings"
|
||||
|
||||
"github.com/breakpilot/ai-compliance-sdk/internal/ucca"
|
||||
)
|
||||
|
||||
// MapIntakeToDimensions converts a UseCaseIntake to a normalized DimensionConfig.
|
||||
// Highest sensitivity wins for multi-value fields.
|
||||
@@ -171,6 +175,38 @@ func mapDataTypeBack(dt DataTypeSensitivity, original ucca.DataTypes) ucca.DataT
|
||||
return result
|
||||
}
|
||||
|
||||
// EnrichDimensionsFromProfile adjusts dimensions based on company profile data.
|
||||
func EnrichDimensionsFromProfile(config *DimensionConfig, profile *ucca.CompanyProfileInput) {
|
||||
if profile == nil {
|
||||
return
|
||||
}
|
||||
|
||||
// Domain override from company industry (if config still generic)
|
||||
if config.Domain == DomainGeneral && profile.Industry != "" {
|
||||
lower := strings.ToLower(profile.Industry)
|
||||
switch {
|
||||
case strings.Contains(lower, "gesundheit") || strings.Contains(lower, "health"):
|
||||
config.Domain = DomainHealth
|
||||
case strings.Contains(lower, "finanz") || strings.Contains(lower, "bank") || strings.Contains(lower, "versicherung"):
|
||||
config.Domain = DomainFinance
|
||||
case strings.Contains(lower, "bildung") || strings.Contains(lower, "schule"):
|
||||
config.Domain = DomainEducation
|
||||
case strings.Contains(lower, "personal") || strings.Contains(lower, "hr"):
|
||||
config.Domain = DomainHR
|
||||
case strings.Contains(lower, "marketing"):
|
||||
config.Domain = DomainMarketing
|
||||
}
|
||||
}
|
||||
|
||||
// NIS2/AI-Act regulatory flags
|
||||
if profile.SubjectToNIS2 {
|
||||
config.LoggingRequired = true
|
||||
}
|
||||
if profile.SubjectToAIAct {
|
||||
config.TransparencyRequired = true
|
||||
}
|
||||
}
|
||||
|
||||
func mapDomainBack(dc DomainCategory, original ucca.Domain) ucca.Domain {
|
||||
switch dc {
|
||||
case DomainHR:
|
||||
|
||||
@@ -113,6 +113,29 @@ func (s *Service) OptimizeFromAssessment(ctx context.Context, assessmentID, tena
|
||||
return o, nil
|
||||
}
|
||||
|
||||
// OptimizeFromIntakeWithProfileInput wraps intake + optional company profile.
|
||||
type OptimizeFromIntakeWithProfileInput struct {
|
||||
Intake ucca.UseCaseIntake `json:"intake"`
|
||||
CompanyProfile *ucca.CompanyProfileInput `json:"company_profile,omitempty"`
|
||||
Title string `json:"title"`
|
||||
TenantID uuid.UUID `json:"-"`
|
||||
UserID uuid.UUID `json:"-"`
|
||||
}
|
||||
|
||||
// OptimizeFromIntakeWithProfile maps intake to dimensions, enriches from profile, and optimizes.
|
||||
func (s *Service) OptimizeFromIntakeWithProfile(ctx context.Context, in *OptimizeFromIntakeWithProfileInput) (*Optimization, error) {
|
||||
config := MapIntakeToDimensions(&in.Intake)
|
||||
if in.CompanyProfile != nil {
|
||||
EnrichDimensionsFromProfile(config, in.CompanyProfile)
|
||||
}
|
||||
return s.Optimize(ctx, &OptimizeInput{
|
||||
Config: *config,
|
||||
Title: in.Title,
|
||||
TenantID: in.TenantID,
|
||||
UserID: in.UserID,
|
||||
})
|
||||
}
|
||||
|
||||
// Evaluate only evaluates without persisting (3-zone analysis).
|
||||
func (s *Service) Evaluate(config *DimensionConfig) *EvaluationResult {
|
||||
return s.evaluator.Evaluate(config)
|
||||
|
||||
Reference in New Issue
Block a user