workspace-v1/projects/erp-construccion/docs/02-definicion-modulos/MAE-016-gestion-documental/especificaciones/ET-DOC-003-servicio de versionamiento.md
rckrdmrd 66161b1566 feat: Workspace-v1 complete migration with NEXUS v3.4
Sistema NEXUS v3.4 migrado con:

Estructura principal:
- core/orchestration: Sistema SIMCO + CAPVED (27 directivas, 28 perfiles)
- core/catalog: Catalogo de funcionalidades reutilizables
- shared/knowledge-base: Base de conocimiento compartida
- devtools/scripts: Herramientas de desarrollo
- control-plane/registries: Control de servicios y CI/CD
- orchestration/: Configuracion de orquestacion de agentes

Proyectos incluidos (11):
- gamilit (submodule -> GitHub)
- trading-platform (OrbiquanTIA)
- erp-suite con 5 verticales:
  - erp-core, construccion, vidrio-templado
  - mecanicas-diesel, retail, clinicas
- betting-analytics
- inmobiliaria-analytics
- platform_marketing_content
- pos-micro, erp-basico

Configuracion:
- .gitignore completo para Node.js/Python/Docker
- gamilit como submodule (git@github.com:rckrdmrd/gamilit-workspace.git)
- Sistema de puertos estandarizado (3005-3199)

Generated with NEXUS v3.4 Migration System
EPIC-010: Configuracion Git y Repositorios
2026-01-04 03:37:42 -06:00

1.3 KiB

ET-DOC-003: Servicio de Versionamiento

ID: ET-DOC-003 | Módulo: MAE-016

Version Service

@Injectable()
export class VersionService {
  async createVersion(
    documentId: string,
    file: Express.Multer.File,
    changeNotes: string,
    userId: string
  ): Promise<DocumentVersion> {
    const document = await this.documentRepo.findOne(documentId);
    const newVersion = document.currentVersion + 1;
    
    const s3Path = await this.storageService.upload(file, {
      projectId: document.projectId,
      type: document.type,
      uploadedBy: userId
    });
    
    const version = await this.versionRepo.save({
      documentId,
      version: newVersion,
      s3Path,
      fileSize: file.size,
      changeNotes,
      createdBy: userId
    });
    
    document.currentVersion = newVersion;
    document.s3Path = s3Path;
    await this.documentRepo.save(document);
    
    return version;
  }

  async compareVersions(v1Id: string, v2Id: string): Promise<VersionComparison> {
    const v1 = await this.versionRepo.findOne(v1Id);
    const v2 = await this.versionRepo.findOne(v2Id);
    
    // For PDFs, generate visual diff
    const diff = await this.pdfDiffService.compare(v1.s3Path, v2.s3Path);
    
    return { v1, v2, diff };
  }
}

Generado: 2025-11-21