feat: api key dto docs

This commit is contained in:
Ahmed Bouhuolia
2025-07-06 10:44:32 +02:00
parent 456a9e1ad9
commit cd1a70ca94
2 changed files with 97 additions and 2 deletions

View File

@@ -1,12 +1,30 @@
import { Controller, Post, Param, Get, Put } from '@nestjs/common';
import { GenerateApiKey } from './commands/GenerateApiKey.service';
import { GetApiKeysService } from './queries/GetApiKeys.service';
import { ApiExcludeController, ApiTags } from '@nestjs/swagger';
import {
ApiTags,
ApiOperation,
ApiResponse,
ApiParam,
ApiExtraModels,
getSchemaPath,
} from '@nestjs/swagger';
import { ApiCommonHeaders } from '@/common/decorators/ApiCommonHeaders';
import {
ApiKeyResponseDto,
ApiKeyRevokeResponseDto,
ApiKeyListResponseDto,
ApiKeyListItemDto,
} from './dtos/ApiKey.dto';
@Controller('api-keys')
@ApiTags('Api keys')
@ApiCommonHeaders()
@ApiExtraModels(
ApiKeyResponseDto,
ApiKeyRevokeResponseDto,
ApiKeyListResponseDto,
)
export class AuthApiKeysController {
constructor(
private readonly getApiKeysService: GetApiKeysService,
@@ -14,17 +32,42 @@ export class AuthApiKeysController {
) {}
@Post('generate')
@ApiOperation({ summary: 'Generate a new API key' })
@ApiResponse({
status: 201,
description: 'The generated API key',
type: ApiKeyResponseDto,
})
async generate() {
return this.generateApiKeyService.generate();
}
@Put(':id/revoke')
@ApiOperation({ summary: 'Revoke an API key' })
@ApiParam({ name: 'id', type: Number, description: 'API key ID' })
@ApiResponse({
status: 200,
description: 'API key revoked',
type: ApiKeyRevokeResponseDto,
})
async revoke(@Param('id') id: number) {
return this.generateApiKeyService.revoke(id);
}
@Get()
@ApiOperation({ summary: 'Get all API keys for the current tenant' })
@ApiResponse({
status: 200,
description: 'List of API keys',
schema: {
type: 'array',
items: {
$ref: getSchemaPath(ApiKeyListItemDto),
},
},
})
async getApiKeys() {
return this.getApiKeysService.getApiKeys();
const data = await this.getApiKeysService.getApiKeys();
return data;
}
}