mirror of
https://github.com/immich-app/immich.git
synced 2025-01-10 13:56:47 +01:00
0aaeab124d
* build: add typesense to docker * feat(server): typesense search * feat(web): search * fix(web): show api error response message * chore: search tests * chore: regenerate open api * fix: disable typesense on e2e * fix: number properties for open api (dart) * fix: e2e test * fix: change lat/lng from floats to typesense geopoint * dev: Add smartInfo relation to findAssetById to be able to query against it --------- Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
33 lines
1.2 KiB
TypeScript
33 lines
1.2 KiB
TypeScript
import { AssetEntity, AssetType } from '@app/infra/db/entities';
|
|
import { Inject } from '@nestjs/common';
|
|
import { IAssetUploadedJob, IJobRepository, JobName } from '../job';
|
|
import { ISearchRepository } from '../search';
|
|
import { AssetCore } from './asset.core';
|
|
import { IAssetRepository } from './asset.repository';
|
|
|
|
export class AssetService {
|
|
private assetCore: AssetCore;
|
|
|
|
constructor(
|
|
@Inject(IAssetRepository) assetRepository: IAssetRepository,
|
|
@Inject(IJobRepository) private jobRepository: IJobRepository,
|
|
@Inject(ISearchRepository) searchRepository: ISearchRepository,
|
|
) {
|
|
this.assetCore = new AssetCore(assetRepository, searchRepository);
|
|
}
|
|
|
|
async handleAssetUpload(data: IAssetUploadedJob) {
|
|
await this.jobRepository.queue({ name: JobName.GENERATE_JPEG_THUMBNAIL, data });
|
|
|
|
if (data.asset.type == AssetType.VIDEO) {
|
|
await this.jobRepository.queue({ name: JobName.VIDEO_CONVERSION, data });
|
|
await this.jobRepository.queue({ name: JobName.EXTRACT_VIDEO_METADATA, data });
|
|
} else {
|
|
await this.jobRepository.queue({ name: JobName.EXIF_EXTRACTION, data });
|
|
}
|
|
}
|
|
|
|
save(asset: Partial<AssetEntity>) {
|
|
return this.assetCore.save(asset);
|
|
}
|
|
}
|