Files
immich/server/src/controllers/job.controller.ts

46 lines
1.8 KiB
TypeScript
Raw Normal View History

import { Body, Controller, Get, HttpCode, HttpStatus, Param, Post, Put } from '@nestjs/common';
2025-11-11 17:01:14 -05:00
import { ApiOperation, ApiTags } from '@nestjs/swagger';
2024-09-16 16:49:12 -04:00
import { AllJobStatusResponseDto, JobCommandDto, JobCreateDto, JobIdParamDto, JobStatusDto } from 'src/dtos/job.dto';
2025-11-11 17:01:14 -05:00
import { ApiTag, Permission } from 'src/enum';
import { Authenticated } from 'src/middleware/auth.guard';
import { JobService } from 'src/services/job.service';
2025-11-11 17:01:14 -05:00
@ApiTags(ApiTag.Jobs)
@Controller('jobs')
export class JobController {
constructor(private service: JobService) {}
@Get()
@Authenticated({ permission: Permission.JobRead, admin: true })
2025-11-11 17:01:14 -05:00
@ApiOperation({
summary: 'Retrieve queue counts and status',
description: 'Retrieve the counts of the current queue, as well as the current status.',
})
getAllJobsStatus(): Promise<AllJobStatusResponseDto> {
return this.service.getAllJobsStatus();
}
2024-09-16 16:49:12 -04:00
@Post()
@Authenticated({ permission: Permission.JobCreate, admin: true })
@HttpCode(HttpStatus.NO_CONTENT)
2025-11-11 17:01:14 -05:00
@ApiOperation({
summary: 'Create a manual job',
description:
'Run a specific job. Most jobs are queued automatically, but this endpoint allows for manual creation of a handful of jobs, including various cleanup tasks, as well as creating a new database backup.',
})
2024-09-16 16:49:12 -04:00
createJob(@Body() dto: JobCreateDto): Promise<void> {
return this.service.create(dto);
}
@Put(':id')
@Authenticated({ permission: Permission.JobCreate, admin: true })
2025-11-11 17:01:14 -05:00
@ApiOperation({
summary: 'Run jobs',
description:
'Queue all assets for a specific job type. Defaults to only queueing assets that have not yet been processed, but the force command can be used to re-process all assets.',
})
2023-07-01 00:41:12 -04:00
sendJobCommand(@Param() { id }: JobIdParamDto, @Body() dto: JobCommandDto): Promise<JobStatusDto> {
return this.service.handleCommand(id, dto);
}
}