mirror of
https://github.com/immich-app/immich.git
synced 2026-01-13 13:36:35 -08:00
43 lines
1.9 KiB
TypeScript
43 lines
1.9 KiB
TypeScript
import { Body, Controller, HttpCode, HttpStatus, Post, StreamableFile } from '@nestjs/common';
|
|
import { ApiTags } from '@nestjs/swagger';
|
|
import { Endpoint, HistoryBuilder } from 'src/decorators';
|
|
import { AssetIdsDto } from 'src/dtos/asset.dto';
|
|
import { AuthDto } from 'src/dtos/auth.dto';
|
|
import { DownloadInfoDto, DownloadResponseDto } from 'src/dtos/download.dto';
|
|
import { ApiTag, Permission } from 'src/enum';
|
|
import { Auth, Authenticated, FileResponse } from 'src/middleware/auth.guard';
|
|
import { DownloadService } from 'src/services/download.service';
|
|
import { asStreamableFile } from 'src/utils/file';
|
|
|
|
@ApiTags(ApiTag.Download)
|
|
@Controller('download')
|
|
export class DownloadController {
|
|
constructor(private service: DownloadService) {}
|
|
|
|
@Post('info')
|
|
@Authenticated({ permission: Permission.AssetDownload, sharedLink: true })
|
|
@Endpoint({
|
|
summary: 'Retrieve download information',
|
|
description:
|
|
'Retrieve information about how to request a download for the specified assets or album. The response includes groups of assets that can be downloaded together.',
|
|
history: new HistoryBuilder().added('v1').beta('v1').stable('v2'),
|
|
})
|
|
getDownloadInfo(@Auth() auth: AuthDto, @Body() dto: DownloadInfoDto): Promise<DownloadResponseDto> {
|
|
return this.service.getDownloadInfo(auth, dto);
|
|
}
|
|
|
|
@Post('archive')
|
|
@Authenticated({ permission: Permission.AssetDownload, sharedLink: true })
|
|
@FileResponse()
|
|
@HttpCode(HttpStatus.OK)
|
|
@Endpoint({
|
|
summary: 'Download asset archive',
|
|
description:
|
|
'Download a ZIP archive containing the specified assets. The assets must have been previously requested via the "getDownloadInfo" endpoint.',
|
|
history: new HistoryBuilder().added('v1').beta('v1').stable('v2'),
|
|
})
|
|
downloadArchive(@Auth() auth: AuthDto, @Body() dto: AssetIdsDto): Promise<StreamableFile> {
|
|
return this.service.downloadArchive(auth, dto).then(asStreamableFile);
|
|
}
|
|
}
|