mirror of
https://github.com/immich-app/immich.git
synced 2026-05-30 02:42:34 -04:00
8db61d341f
* 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>
137 lines
4.3 KiB
TypeScript
137 lines
4.3 KiB
TypeScript
import { ApiProperty } from '@nestjs/swagger';
|
|
import { Type } from 'class-transformer';
|
|
import { IsInt, IsObject, IsPositive, ValidateNested } from 'class-validator';
|
|
import { Memory } from 'src/database';
|
|
import { AssetResponseDto, mapAsset } from 'src/dtos/asset-response.dto';
|
|
import { AuthDto } from 'src/dtos/auth.dto';
|
|
import { AssetOrderWithRandom, MemoryType } from 'src/enum';
|
|
import { Optional, ValidateBoolean, ValidateDate, ValidateEnum, ValidateUUID } from 'src/validation';
|
|
|
|
class MemoryBaseDto {
|
|
@ValidateBoolean({ optional: true, description: 'Is memory saved' })
|
|
isSaved?: boolean;
|
|
|
|
@ValidateDate({ optional: true, description: 'Date when memory was seen' })
|
|
seenAt?: Date;
|
|
}
|
|
|
|
export class MemorySearchDto {
|
|
@ValidateEnum({ enum: MemoryType, name: 'MemoryType', description: 'Memory type', optional: true })
|
|
type?: MemoryType;
|
|
|
|
@ValidateDate({ optional: true, description: 'Filter by date' })
|
|
for?: Date;
|
|
|
|
@ValidateBoolean({ optional: true, description: 'Include trashed memories' })
|
|
isTrashed?: boolean;
|
|
|
|
@ValidateBoolean({ optional: true, description: 'Filter by saved status' })
|
|
isSaved?: boolean;
|
|
|
|
@IsInt()
|
|
@IsPositive()
|
|
@Type(() => Number)
|
|
@Optional()
|
|
@ApiProperty({ type: 'integer', description: 'Number of memories to return' })
|
|
size?: number;
|
|
|
|
@ValidateEnum({ enum: AssetOrderWithRandom, name: 'MemorySearchOrder', description: 'Sort order', optional: true })
|
|
order?: AssetOrderWithRandom;
|
|
}
|
|
|
|
class OnThisDayDto {
|
|
@ApiProperty({ type: 'number', description: 'Year for on this day memory', minimum: 1 })
|
|
@IsInt()
|
|
@IsPositive()
|
|
year!: number;
|
|
}
|
|
|
|
type MemoryData = OnThisDayDto;
|
|
|
|
export class MemoryUpdateDto extends MemoryBaseDto {
|
|
@ValidateDate({ optional: true, description: 'Memory date' })
|
|
memoryAt?: Date;
|
|
}
|
|
|
|
export class MemoryCreateDto extends MemoryBaseDto {
|
|
@ValidateEnum({ enum: MemoryType, name: 'MemoryType', description: 'Memory type' })
|
|
type!: MemoryType;
|
|
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
@IsObject()
|
|
@ValidateNested()
|
|
@Type((options) => {
|
|
switch (options?.object.type) {
|
|
case MemoryType.OnThisDay: {
|
|
return OnThisDayDto;
|
|
}
|
|
|
|
default: {
|
|
return Object;
|
|
}
|
|
}
|
|
})
|
|
data!: MemoryData;
|
|
|
|
@ValidateDate({ description: 'Memory date' })
|
|
memoryAt!: Date;
|
|
|
|
@ValidateUUID({ optional: true, each: true, description: 'Asset IDs to associate with memory' })
|
|
assetIds?: string[];
|
|
}
|
|
|
|
export class MemoryStatisticsResponseDto {
|
|
@ApiProperty({ type: 'integer', description: 'Total number of memories' })
|
|
total!: number;
|
|
}
|
|
|
|
export class MemoryResponseDto {
|
|
@ApiProperty({ description: 'Memory ID' })
|
|
id!: string;
|
|
@ValidateDate({ description: 'Creation date' })
|
|
createdAt!: Date;
|
|
@ValidateDate({ description: 'Last update date' })
|
|
updatedAt!: Date;
|
|
@ValidateDate({ optional: true, description: 'Deletion date' })
|
|
deletedAt?: Date;
|
|
@ValidateDate({ description: 'Memory date' })
|
|
memoryAt!: Date;
|
|
@ValidateDate({ optional: true, description: 'Date when memory was seen' })
|
|
seenAt?: Date;
|
|
@ValidateDate({ optional: true, description: 'Date when memory should be shown' })
|
|
showAt?: Date;
|
|
@ValidateDate({ optional: true, description: 'Date when memory should be hidden' })
|
|
hideAt?: Date;
|
|
@ApiProperty({ description: 'Owner user ID' })
|
|
ownerId!: string;
|
|
@ValidateEnum({ enum: MemoryType, name: 'MemoryType', description: 'Memory type' })
|
|
type!: MemoryType;
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
data!: MemoryData;
|
|
@ApiProperty({ description: 'Is memory saved' })
|
|
isSaved!: boolean;
|
|
// Description lives on schema to avoid duplication
|
|
@ApiProperty({ description: undefined })
|
|
assets!: AssetResponseDto[];
|
|
}
|
|
|
|
export const mapMemory = (entity: Memory, auth: AuthDto): MemoryResponseDto => {
|
|
return {
|
|
id: entity.id,
|
|
createdAt: entity.createdAt,
|
|
updatedAt: entity.updatedAt,
|
|
deletedAt: entity.deletedAt ?? undefined,
|
|
memoryAt: entity.memoryAt,
|
|
seenAt: entity.seenAt ?? undefined,
|
|
showAt: entity.showAt ?? undefined,
|
|
hideAt: entity.hideAt ?? undefined,
|
|
ownerId: entity.ownerId,
|
|
type: entity.type as MemoryType,
|
|
data: entity.data as unknown as MemoryData,
|
|
isSaved: entity.isSaved,
|
|
assets: ('assets' in entity ? entity.assets : []).map((asset) => mapAsset(asset, { auth })),
|
|
};
|
|
};
|