mirror of
https://github.com/immich-app/immich.git
synced 2025-11-18 20:43:20 -05:00
89 lines
2.7 KiB
TypeScript
89 lines
2.7 KiB
TypeScript
import { Body, Controller, Delete, Get, HttpCode, HttpStatus, Param, Post, Put, Query } from '@nestjs/common';
|
|
import { ApiOperation, ApiTags } from '@nestjs/swagger';
|
|
import { EndpointLifecycle } from 'src/decorators';
|
|
import { AssetResponseDto } from 'src/dtos/asset-response.dto';
|
|
import {
|
|
AssetBulkDeleteDto,
|
|
AssetBulkUpdateDto,
|
|
AssetJobsDto,
|
|
AssetStatsDto,
|
|
AssetStatsResponseDto,
|
|
DeviceIdDto,
|
|
RandomAssetsDto,
|
|
UpdateAssetDto,
|
|
} from 'src/dtos/asset.dto';
|
|
import { AuthDto } from 'src/dtos/auth.dto';
|
|
import { RouteKey } from 'src/enum';
|
|
import { Auth, Authenticated } from 'src/middleware/auth.guard';
|
|
import { AssetService } from 'src/services/asset.service';
|
|
import { UUIDParamDto } from 'src/validation';
|
|
|
|
@ApiTags('Assets')
|
|
@Controller(RouteKey.ASSET)
|
|
export class AssetController {
|
|
constructor(private service: AssetService) {}
|
|
|
|
@Get('random')
|
|
@Authenticated()
|
|
@EndpointLifecycle({ deprecatedAt: 'v1.116.0' })
|
|
getRandom(@Auth() auth: AuthDto, @Query() dto: RandomAssetsDto): Promise<AssetResponseDto[]> {
|
|
return this.service.getRandom(auth, dto.count ?? 1);
|
|
}
|
|
|
|
/**
|
|
* Get all asset of a device that are in the database, ID only.
|
|
*/
|
|
@Get('/device/:deviceId')
|
|
@ApiOperation({
|
|
summary: 'getAllUserAssetsByDeviceId',
|
|
description: 'Get all asset of a device that are in the database, ID only.',
|
|
})
|
|
@Authenticated()
|
|
getAllUserAssetsByDeviceId(@Auth() auth: AuthDto, @Param() { deviceId }: DeviceIdDto) {
|
|
return this.service.getUserAssetsByDeviceId(auth, deviceId);
|
|
}
|
|
|
|
@Get('statistics')
|
|
@Authenticated()
|
|
getAssetStatistics(@Auth() auth: AuthDto, @Query() dto: AssetStatsDto): Promise<AssetStatsResponseDto> {
|
|
return this.service.getStatistics(auth, dto);
|
|
}
|
|
|
|
@Post('jobs')
|
|
@Authenticated()
|
|
@HttpCode(HttpStatus.NO_CONTENT)
|
|
runAssetJobs(@Auth() auth: AuthDto, @Body() dto: AssetJobsDto): Promise<void> {
|
|
return this.service.run(auth, dto);
|
|
}
|
|
|
|
@Put()
|
|
@HttpCode(HttpStatus.NO_CONTENT)
|
|
@Authenticated()
|
|
updateAssets(@Auth() auth: AuthDto, @Body() dto: AssetBulkUpdateDto): Promise<void> {
|
|
return this.service.updateAll(auth, dto);
|
|
}
|
|
|
|
@Delete()
|
|
@HttpCode(HttpStatus.NO_CONTENT)
|
|
@Authenticated()
|
|
deleteAssets(@Auth() auth: AuthDto, @Body() dto: AssetBulkDeleteDto): Promise<void> {
|
|
return this.service.deleteAll(auth, dto);
|
|
}
|
|
|
|
@Get(':id')
|
|
@Authenticated({ sharedLink: true })
|
|
getAssetInfo(@Auth() auth: AuthDto, @Param() { id }: UUIDParamDto): Promise<AssetResponseDto> {
|
|
return this.service.get(auth, id) as Promise<AssetResponseDto>;
|
|
}
|
|
|
|
@Put(':id')
|
|
@Authenticated()
|
|
updateAsset(
|
|
@Auth() auth: AuthDto,
|
|
@Param() { id }: UUIDParamDto,
|
|
@Body() dto: UpdateAssetDto,
|
|
): Promise<AssetResponseDto> {
|
|
return this.service.update(auth, id, dto);
|
|
}
|
|
}
|