mirror of
https://github.com/immich-app/immich.git
synced 2026-03-22 20:59:50 +03:00
* faces * add openapi descriptions * remove dto descriptions * gen openapi * dtos * fix dtos * fix more * fix build * more * complete dtos * descriptions on rebase * gen rebase * revert correct integer type conversion * gen after revert * revert correct nullables * regen after revert * actually incorrect adding default here * revert correct number type conversion * regen after revert * revert nullable usage * regen fully * readd some comments * one more * one more * use enum * add missing * add missing controllers * add missing dtos * complete it * more * describe global key and slug * add remaining body and param descriptions * lint and format * cleanup * response and schema descriptions * test patch according to suggestion * revert added api response objects * revert added api body objects * revert added api param object * revert added api query objects * revert reorganized http code objects * revert reorganize ApiOkResponse objects * revert added api response objects (2) * revert added api tag object * revert added api schema objects * migrate missing asset.dto.ts * regenerate openapi builds * delete generated mustache files * remove descriptions from properties that are schemas * lint * revert nullable type changes * revert int/num type changes * remove explicit default * readd comment * lint * pr fixes * last bits and pieces * lint and format * chore: remove rejected patches * fix: deleting asset from asset-viewer on search results (#25596) * fix: escape handling in search asset viewer (#25621) * fix: correctly show owner in album options modal (#25618) * fix: validation issues * fix: validation issues --------- Co-authored-by: Jason Rasmussen <jason@rasm.me> Co-authored-by: Min Idzelis <min123@gmail.com> Co-authored-by: Daniel Dietzler <36593685+danieldietzler@users.noreply.github.com> Co-authored-by: Paul Makles <me@insrt.uk>
56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
import { ApiProperty, ApiPropertyOptional } from '@nestjs/swagger';
|
|
import { ArrayMinSize, IsNotEmpty, IsString } from 'class-validator';
|
|
import { Permission } from 'src/enum';
|
|
import { Optional, ValidateEnum } from 'src/validation';
|
|
|
|
export class APIKeyCreateDto {
|
|
@ApiPropertyOptional({ description: 'API key name' })
|
|
@IsString()
|
|
@IsNotEmpty()
|
|
@Optional()
|
|
name?: string;
|
|
|
|
@ValidateEnum({ enum: Permission, name: 'Permission', each: true, description: 'List of permissions' })
|
|
@ArrayMinSize(1)
|
|
permissions!: Permission[];
|
|
}
|
|
|
|
export class APIKeyUpdateDto {
|
|
@ApiPropertyOptional({ description: 'API key name' })
|
|
@Optional()
|
|
@IsString()
|
|
@IsNotEmpty()
|
|
name?: string;
|
|
|
|
@ValidateEnum({
|
|
enum: Permission,
|
|
name: 'Permission',
|
|
description: 'List of permissions',
|
|
each: true,
|
|
optional: true,
|
|
})
|
|
@ArrayMinSize(1)
|
|
permissions?: Permission[];
|
|
}
|
|
|
|
export class APIKeyResponseDto {
|
|
@ApiProperty({ description: 'API key ID' })
|
|
id!: string;
|
|
@ApiProperty({ description: 'API key name' })
|
|
name!: string;
|
|
@ApiProperty({ description: 'Creation date' })
|
|
createdAt!: Date;
|
|
@ApiProperty({ description: 'Last update date' })
|
|
updatedAt!: Date;
|
|
@ValidateEnum({ enum: Permission, name: 'Permission', each: true, description: 'List of permissions' })
|
|
permissions!: Permission[];
|
|
}
|
|
|
|
export class APIKeyCreateResponseDto {
|
|
@ApiProperty({ description: 'API key secret (only shown once)' })
|
|
secret!: string;
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
apiKey!: APIKeyResponseDto;
|
|
}
|