mirror of
https://github.com/immich-app/immich.git
synced 2026-03-07 18:47:31 +03:00
docs(openapi): add descriptions to OpenAPI specification (#25185)
* 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>
This commit is contained in:
@@ -1,3 +1,4 @@
|
||||
import { ApiProperty, ApiPropertyOptional } from '@nestjs/swagger';
|
||||
import { Type } from 'class-transformer';
|
||||
import { IsNotEmpty, IsObject, IsString, IsUUID, ValidateNested } from 'class-validator';
|
||||
import { WorkflowAction, WorkflowFilter } from 'src/database';
|
||||
@@ -6,68 +7,85 @@ import type { ActionConfig, FilterConfig } from 'src/types/plugin-schema.types';
|
||||
import { Optional, ValidateBoolean, ValidateEnum } from 'src/validation';
|
||||
|
||||
export class WorkflowFilterItemDto {
|
||||
@ApiProperty({ description: 'Plugin filter ID' })
|
||||
@IsUUID()
|
||||
pluginFilterId!: string;
|
||||
|
||||
@ApiPropertyOptional({ description: 'Filter configuration' })
|
||||
@IsObject()
|
||||
@Optional()
|
||||
filterConfig?: FilterConfig;
|
||||
}
|
||||
|
||||
export class WorkflowActionItemDto {
|
||||
@ApiProperty({ description: 'Plugin action ID' })
|
||||
@IsUUID()
|
||||
pluginActionId!: string;
|
||||
|
||||
@ApiPropertyOptional({ description: 'Action configuration' })
|
||||
@IsObject()
|
||||
@Optional()
|
||||
actionConfig?: ActionConfig;
|
||||
}
|
||||
|
||||
export class WorkflowCreateDto {
|
||||
@ValidateEnum({ enum: PluginTriggerType, name: 'PluginTriggerType' })
|
||||
@ValidateEnum({ enum: PluginTriggerType, name: 'PluginTriggerType', description: 'Workflow trigger type' })
|
||||
triggerType!: PluginTriggerType;
|
||||
|
||||
@ApiProperty({ description: 'Workflow name' })
|
||||
@IsString()
|
||||
@IsNotEmpty()
|
||||
name!: string;
|
||||
|
||||
@ApiPropertyOptional({ description: 'Workflow description' })
|
||||
@IsString()
|
||||
@Optional()
|
||||
description?: string;
|
||||
|
||||
@ValidateBoolean({ optional: true })
|
||||
@ValidateBoolean({ optional: true, description: 'Workflow enabled' })
|
||||
enabled?: boolean;
|
||||
|
||||
@ApiProperty({ description: 'Workflow filters' })
|
||||
@ValidateNested({ each: true })
|
||||
@Type(() => WorkflowFilterItemDto)
|
||||
filters!: WorkflowFilterItemDto[];
|
||||
|
||||
@ApiProperty({ description: 'Workflow actions' })
|
||||
@ValidateNested({ each: true })
|
||||
@Type(() => WorkflowActionItemDto)
|
||||
actions!: WorkflowActionItemDto[];
|
||||
}
|
||||
|
||||
export class WorkflowUpdateDto {
|
||||
@ValidateEnum({ enum: PluginTriggerType, name: 'PluginTriggerType', optional: true })
|
||||
@ValidateEnum({
|
||||
enum: PluginTriggerType,
|
||||
name: 'PluginTriggerType',
|
||||
optional: true,
|
||||
description: 'Workflow trigger type',
|
||||
})
|
||||
triggerType?: PluginTriggerType;
|
||||
|
||||
@ApiPropertyOptional({ description: 'Workflow name' })
|
||||
@IsString()
|
||||
@IsNotEmpty()
|
||||
@Optional()
|
||||
name?: string;
|
||||
|
||||
@ApiPropertyOptional({ description: 'Workflow description' })
|
||||
@IsString()
|
||||
@Optional()
|
||||
description?: string;
|
||||
|
||||
@ValidateBoolean({ optional: true })
|
||||
@ValidateBoolean({ optional: true, description: 'Workflow enabled' })
|
||||
enabled?: boolean;
|
||||
|
||||
@ApiPropertyOptional({ description: 'Workflow filters' })
|
||||
@ValidateNested({ each: true })
|
||||
@Type(() => WorkflowFilterItemDto)
|
||||
@Optional()
|
||||
filters?: WorkflowFilterItemDto[];
|
||||
|
||||
@ApiPropertyOptional({ description: 'Workflow actions' })
|
||||
@ValidateNested({ each: true })
|
||||
@Type(() => WorkflowActionItemDto)
|
||||
@Optional()
|
||||
@@ -75,31 +93,49 @@ export class WorkflowUpdateDto {
|
||||
}
|
||||
|
||||
export class WorkflowResponseDto {
|
||||
@ApiProperty({ description: 'Workflow ID' })
|
||||
id!: string;
|
||||
@ApiProperty({ description: 'Owner user ID' })
|
||||
ownerId!: string;
|
||||
@ValidateEnum({ enum: PluginTriggerType, name: 'PluginTriggerType' })
|
||||
@ValidateEnum({ enum: PluginTriggerType, name: 'PluginTriggerType', description: 'Workflow trigger type' })
|
||||
triggerType!: PluginTriggerType;
|
||||
@ApiProperty({ description: 'Workflow name' })
|
||||
name!: string | null;
|
||||
@ApiProperty({ description: 'Workflow description' })
|
||||
description!: string;
|
||||
@ApiProperty({ description: 'Creation date' })
|
||||
createdAt!: string;
|
||||
@ApiProperty({ description: 'Workflow enabled' })
|
||||
enabled!: boolean;
|
||||
@ApiProperty({ description: 'Workflow filters' })
|
||||
filters!: WorkflowFilterResponseDto[];
|
||||
@ApiProperty({ description: 'Workflow actions' })
|
||||
actions!: WorkflowActionResponseDto[];
|
||||
}
|
||||
|
||||
export class WorkflowFilterResponseDto {
|
||||
@ApiProperty({ description: 'Filter ID' })
|
||||
id!: string;
|
||||
@ApiProperty({ description: 'Workflow ID' })
|
||||
workflowId!: string;
|
||||
@ApiProperty({ description: 'Plugin filter ID' })
|
||||
pluginFilterId!: string;
|
||||
@ApiProperty({ description: 'Filter configuration' })
|
||||
filterConfig!: FilterConfig | null;
|
||||
@ApiProperty({ description: 'Filter order', type: 'number' })
|
||||
order!: number;
|
||||
}
|
||||
|
||||
export class WorkflowActionResponseDto {
|
||||
@ApiProperty({ description: 'Action ID' })
|
||||
id!: string;
|
||||
@ApiProperty({ description: 'Workflow ID' })
|
||||
workflowId!: string;
|
||||
@ApiProperty({ description: 'Plugin action ID' })
|
||||
pluginActionId!: string;
|
||||
@ApiProperty({ description: 'Action configuration' })
|
||||
actionConfig!: ActionConfig | null;
|
||||
@ApiProperty({ description: 'Action order', type: 'number' })
|
||||
order!: number;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user