## Database Migrations (18 new) - Migrate all primary keys from SERIAL to UUID - Add soft delete (deleted_at) to all 19 entities - Add missing indexes for performance optimization - Add CHECK constraints for data validation - Add user audit fields (last_login_at, timezone, locale) - Add weather station location fields (latitude, longitude, elevation) - Add foreign key relationships (CameraDevice→Device, ValidatedEvent→WeatherStation) - Prepare private key encryption fields ## Backend Entity Updates - All entities updated with UUID primary keys - Added @DeleteDateColumn for soft delete support - Updated relations and foreign key types ## Backend Service/Controller Updates - Changed ID parameters from number to string (UUID) - Removed ParseIntPipe from controllers - Updated TypeORM queries for string IDs ## Frontend Updates - Updated all service interfaces to use string IDs - Fixed CameraDevice.location as JSONB object - Updated weather.ts with new fields (elevation, timezone) - Added Supabase integration hooks and lib - Fixed chart components for new data structure ## Cleanup - Removed deprecated .claude/agents configuration files 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
34 lines
1.2 KiB
TypeScript
34 lines
1.2 KiB
TypeScript
import { Module, forwardRef } from '@nestjs/common';
|
|
import { TypeOrmModule } from '@nestjs/typeorm';
|
|
import { JwtModule } from '@nestjs/jwt';
|
|
import { PassportModule } from '@nestjs/passport';
|
|
import { AuthController } from './auth.controller';
|
|
import { AuthService } from './auth.service';
|
|
import { JwtStrategy } from './strategies/jwt.strategy';
|
|
import { UserProfile } from '../entities/user-profile.entity';
|
|
import { UserIdentity } from '../entities/user-identity.entity';
|
|
import { PaymentsModule } from '../payments/payments.module';
|
|
import { MetricsModule } from '../metrics/metrics.module';
|
|
import { SupabaseModule } from '../supabase/supabase.module';
|
|
|
|
@Module({
|
|
imports: [
|
|
TypeOrmModule.forFeature([UserProfile, UserIdentity]),
|
|
PassportModule,
|
|
JwtModule.registerAsync({
|
|
useFactory: () => ({
|
|
secret:
|
|
process.env.JWT_ACCESS_SECRET || 'default-secret-change-in-production',
|
|
signOptions: { expiresIn: process.env.JWT_ACCESS_EXPIRATION || '2h' },
|
|
}),
|
|
}),
|
|
forwardRef(() => PaymentsModule),
|
|
MetricsModule,
|
|
SupabaseModule,
|
|
],
|
|
controllers: [AuthController],
|
|
providers: [AuthService, JwtStrategy],
|
|
exports: [AuthService],
|
|
})
|
|
export class AuthModule {}
|