MAJOR IMPLEMENTATION COMPLETED: ✅ Modern database structure with Laravel best practices ✅ Complete Eloquent relationships (Amministratore→Stabili→Movements) ✅ 8-character alphanumeric codes system (ADM, ANA, MOV, ALL prefixes) ✅ Multi-database architecture for administrators ✅ Complete property management (anagrafica_condominiale, diritti_reali, contratti) ✅ Distribution system for multi-server deployment ✅ Universal responsive UI with permission-based sidebar NEW MODELS & MIGRATIONS: - AnagraficaCondominiale: Complete person/entity management - ContattoAnagrafica: Multi-contact system with usage flags - DirittoReale: Property rights with quotas and percentages - ContrattoLocazione: Rental contracts with landlord/tenant - TipoUtilizzo: Property usage types (residential, commercial, etc.) - Enhanced Stabile: Cadastral data, SDI, rate configuration - Enhanced UnitaImmobiliare: Modern structure with backward compatibility SERVICES & CONTROLLERS: - DistributionService: Multi-server deployment and migration - FileManagerController: Administrator folder management - DistributionController: API for server-to-server communication - MultiDatabaseService: Dynamic database connections READY FOR PRODUCTION: ✅ Database schema: Complete and tested ✅ Models relationships: All working and verified ✅ Code generation: Automatic 8-char codes implemented ✅ Testing: Successful data creation confirmed ✅ Documentation: Complete internal technical docs NEXT PHASE: Millésimal tables, expense categories, cost distribution engine
34 lines
2.0 KiB
PHP
34 lines
2.0 KiB
PHP
<?php
|
|
use App\Http\Controllers\Api\ImportController;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
// Laravel per default fornisce una rotta di test, la lasciamo.
|
|
Route::get('/user', function (Request $request) {
|
|
return $request->user();
|
|
})->middleware('auth:sanctum');
|
|
|
|
// --- IL NOSTRO ENDPOINT DI IMPORTAZIONE ---
|
|
// Proteggiamo la rotta con 'auth:sanctum', che richiede un token API per l'accesso.
|
|
Route::middleware('auth:sanctum')->prefix('v1')->group(function () {
|
|
Route::post('/import/condominio', [ImportController::class, 'importCondominio'])->name('api.import.condominio');
|
|
// In futuro aggiungeremo qui le rotte per importare le unità, i fornitori, etc.
|
|
Route::post('/import/fornitore', [ImportController::class, 'importFornitore'])->name('api.import.fornitore');
|
|
Route::post('/import/anagrafica', [ImportController::class, 'importAnagrafica'])->name('api.import.anagrafica');
|
|
});
|
|
|
|
// --- API PER DISTRIBUZIONE MULTI-SERVER ---
|
|
Route::prefix('v1/distribution')->group(function () {
|
|
// Health check pubblico per verificare stato server
|
|
Route::get('/health', [\App\Http\Controllers\Api\DistributionController::class, 'health'])->name('api.health');
|
|
|
|
// API per migrazione amministratori (richiede autenticazione)
|
|
Route::middleware('auth:sanctum')->group(function () {
|
|
Route::post('/import-administrator', [\App\Http\Controllers\Api\DistributionController::class, 'importAdministrator']);
|
|
Route::post('/activate-administrator', [\App\Http\Controllers\Api\DistributionController::class, 'activateAdministrator']);
|
|
Route::post('/sync-administrator', [\App\Http\Controllers\Api\DistributionController::class, 'syncAdministrator']);
|
|
Route::post('/backup-administrator', [\App\Http\Controllers\Api\DistributionController::class, 'backupAdministrator']);
|
|
Route::get('/administrator-routing/{codice}', [\App\Http\Controllers\Api\DistributionController::class, 'getAdministratorRouting']);
|
|
});
|
|
});
|