azaharizaman / nexus-period
Nexus Period Management Package - Framework-agnostic fiscal period management
v0.1.0-alpha1
2026-05-05 02:28 UTC
Requires
- php: ^8.3
This package is auto-updated.
Last update: 2026-05-05 03:09:25 UTC
README
Framework-agnostic fiscal period management package for the Nexus ERP system.
Purpose
The Period package manages fiscal periods for various business processes (Accounting, Inventory, Payroll, Manufacturing). It ensures that transactions can only be posted to open periods and provides period lifecycle management (Pending → Open → Closed → Locked).
Key Features
- Multiple Period Types: Independent period management for Accounting, Inventory, Payroll, Manufacturing
- Period Lifecycle: Pending → Open → Closed → Locked with validation
- Transaction Validation: Fast period validation (<5ms) for every transaction
- Audit Trail: Comprehensive logging of period status changes
- Year-End Close: Automated year-end closing with reconciliation support
Architecture
Contracts (Interfaces)
PeriodManagerInterface- Main service contract for period operationsPeriodInterface- Period entity contractPeriodRepositoryInterface- Persistence contractPeriodValidatorInterface- Validation logic contractPeriodAuditLoggerInterface- Audit logging contract
Enums
PeriodType- Accounting, Inventory, Payroll, ManufacturingPeriodStatus- Pending, Open, Closed, Locked
Value Objects
PeriodDateRange- Immutable start/end date range with validationPeriodMetadata- Name, description, fiscal year informationFiscalYear- Fiscal year with start/end dates
Usage Example
use Nexus\Period\Services\PeriodManager; use Nexus\Period\Enums\PeriodType; // Check if posting is allowed for a specific date $canPost = $periodManager->isPostingAllowed( new \DateTimeImmutable('2024-11-15'), PeriodType::Accounting ); // Close the current accounting period $periodManager->closePeriod( $periodId, 'Monthly close for October 2024', $userId ); // Lock a closed period (prevents any further changes) $periodManager->lockPeriod( $periodId, 'Year-end finalization', $userId ); // Lock all periods in a fiscal year $lockedCount = $periodManager->lockFiscalYear( '2024', PeriodType::Accounting, 'Annual audit completed', $userId ); // Get all periods for a fiscal year $periods = $periodManager->getPeriodsForFiscalYear('2024', PeriodType::Accounting); // Unlock a locked period (exceptional case, requires special authorization) $periodManager->unlockPeriod( $periodId, 'Audit adjustment required', $userId ); // Get the currently open period $openPeriod = $periodManager->getOpenPeriod(PeriodType::Accounting);
Integration
This package is consumed by:
Nexus\Finance- for journal entry validationNexus\Accounting- for financial statement period managementNexus\Inventory- for stock movement validationNexus\Payroll- for payroll posting validationNexus\Manufacturing- for production order validation
Performance Requirements
- Period posting validation: < 5ms (critical path for all transactions)
- Get open period query: < 10ms with proper caching
- Period status change: < 50ms including audit logging
- List periods for fiscal year: < 100ms
- Bulk period creation (12 periods): < 500ms
📖 Documentation
Package Documentation
Additional Resources
IMPLEMENTATION_SUMMARY.md- Implementation progressREQUIREMENTS.md- RequirementsTEST_SUITE_SUMMARY.md- TestsVALUATION_MATRIX.md- Valuation