All checks were successful
Test Asgard Runner / test (push) Successful in 2s
- DB migrations 017 (betterchat_configs) and 020 (timedexecute_configs) applied - TypeORM entities matching production schema exactly - NestJS modules with full CRUD + apply-to-server + import-from-server - Pinia stores following teleport config pattern - BetterChatView: Chat Groups editor with color pickers, font sizes, format strings; Settings tab with word filter, anti-flood, player tagging - TimedExecuteView: TimerRepeat with presets, RealTime-Timer, OnConnect/OnDisconnect command lists - Wired into app.module.ts, router, DashboardLayout nav Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
81 lines
3.0 KiB
TypeScript
81 lines
3.0 KiB
TypeScript
import {
|
|
Controller,
|
|
Get,
|
|
Post,
|
|
Put,
|
|
Delete,
|
|
Body,
|
|
Param,
|
|
UseGuards,
|
|
} from '@nestjs/common';
|
|
import { ApiTags, ApiBearerAuth, ApiOperation } from '@nestjs/swagger';
|
|
import { TimedExecuteService } from './timedexecute.service';
|
|
import { CreateTimedExecuteConfigDto } from './dto/create-timedexecute-config.dto';
|
|
import { UpdateTimedExecuteConfigDto } from './dto/update-timedexecute-config.dto';
|
|
import { ImportTimedExecuteConfigDto } from './dto/import-timedexecute-config.dto';
|
|
import { CurrentTenant } from '../../common/decorators/current-tenant.decorator';
|
|
import { RequirePermission } from '../../common/decorators/require-permission.decorator';
|
|
import { JwtAuthGuard } from '../../common/guards/jwt-auth.guard';
|
|
import { PermissionsGuard } from '../../common/guards/permissions.guard';
|
|
|
|
@ApiTags('timedexecute')
|
|
@ApiBearerAuth()
|
|
@Controller('timedexecute')
|
|
@UseGuards(JwtAuthGuard, PermissionsGuard)
|
|
export class TimedExecuteController {
|
|
constructor(private readonly timedExecuteService: TimedExecuteService) {}
|
|
|
|
@Get('configs')
|
|
@RequirePermission('timedexecute.view')
|
|
@ApiOperation({ summary: 'List TimedExecute configs (summaries)' })
|
|
getConfigs(@CurrentTenant() licenseId: string) {
|
|
return this.timedExecuteService.getConfigs(licenseId);
|
|
}
|
|
|
|
@Get('configs/:id')
|
|
@RequirePermission('timedexecute.view')
|
|
@ApiOperation({ summary: 'Get full TimedExecute config with data' })
|
|
getConfig(@CurrentTenant() licenseId: string, @Param('id') id: string) {
|
|
return this.timedExecuteService.getConfig(licenseId, id);
|
|
}
|
|
|
|
@Post('configs')
|
|
@RequirePermission('timedexecute.manage')
|
|
@ApiOperation({ summary: 'Create TimedExecute config' })
|
|
createConfig(@CurrentTenant() licenseId: string, @Body() dto: CreateTimedExecuteConfigDto) {
|
|
return this.timedExecuteService.createConfig(licenseId, dto);
|
|
}
|
|
|
|
@Put('configs/:id')
|
|
@RequirePermission('timedexecute.manage')
|
|
@ApiOperation({ summary: 'Update TimedExecute config' })
|
|
updateConfig(
|
|
@CurrentTenant() licenseId: string,
|
|
@Param('id') id: string,
|
|
@Body() dto: UpdateTimedExecuteConfigDto,
|
|
) {
|
|
return this.timedExecuteService.updateConfig(licenseId, id, dto);
|
|
}
|
|
|
|
@Delete('configs/:id')
|
|
@RequirePermission('timedexecute.manage')
|
|
@ApiOperation({ summary: 'Delete TimedExecute config' })
|
|
deleteConfig(@CurrentTenant() licenseId: string, @Param('id') id: string) {
|
|
return this.timedExecuteService.deleteConfig(licenseId, id);
|
|
}
|
|
|
|
@Post('configs/:id/apply')
|
|
@RequirePermission('timedexecute.manage')
|
|
@ApiOperation({ summary: 'Deploy TimedExecute config to server' })
|
|
applyToServer(@CurrentTenant() licenseId: string, @Param('id') id: string) {
|
|
return this.timedExecuteService.applyToServer(licenseId, id);
|
|
}
|
|
|
|
@Post('import-from-server')
|
|
@RequirePermission('timedexecute.manage')
|
|
@ApiOperation({ summary: 'Import TimedExecute.json from server via NATS' })
|
|
importFromServer(@CurrentTenant() licenseId: string, @Body() dto: ImportTimedExecuteConfigDto) {
|
|
return this.timedExecuteService.importFromServer(licenseId, dto.config_name, dto.description);
|
|
}
|
|
}
|