mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-04 10:22:53 +09:00 
			
		
		
		
	feat(server): near-duplicate detection (#8228)
* duplicate detection job, entity, config * queueing * job panel, update api * use embedding in db instead of fetching * disable concurrency * only queue visible assets * handle multiple duplicateIds * update concurrent queue check * add provider * add web placeholder, server endpoint, migration, various fixes * update sql * select embedding by default * rename variable * simplify * remove separate entity, handle re-running with different threshold, set default back to 0.02 * fix tests * add tests * add index to entity * formatting * update asset mock * fix `upsertJobStatus` signature * update sql * formatting * default to 0.03 * optimize clustering * use asset's `duplicateId` if present * update sql * update tests * expose admin setting * refactor * formatting * skip if ml is disabled * debug trash e2e * remove from web * remove from sidebar * test if ml is disabled * update sql * separate duplicate detection from clip in config, disable by default for now * fix doc * lower minimum `maxDistance` * update api * Add and Use Duplicate Detection Feature Flag (#9364) * Add Duplicate Detection Flag * Use Duplicate Detection Flag * Attempt Fixes for Failing Checks * lower minimum `maxDistance` * fix tests --------- Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com> * chore: fixes and additions after rebase * chore: update api (remove new Role enum) * fix: left join smart search so getAll works without machine learning * test: trash e2e go back to checking length of assets is zero * chore: regen api after rebase * test: fix tests after rebase * redundant join --------- Co-authored-by: Nicholas Flamy <30300649+NicholasFlamy@users.noreply.github.com> Co-authored-by: Zack Pollard <zackpollard@ymail.com> Co-authored-by: Zack Pollard <zack@futo.org>
This commit is contained in:
		@@ -410,6 +410,7 @@ export type JobStatusDto = {
 | 
			
		||||
};
 | 
			
		||||
export type AllJobStatusResponseDto = {
 | 
			
		||||
    backgroundTask: JobStatusDto;
 | 
			
		||||
    duplicateDetection: JobStatusDto;
 | 
			
		||||
    faceDetection: JobStatusDto;
 | 
			
		||||
    facialRecognition: JobStatusDto;
 | 
			
		||||
    library: JobStatusDto;
 | 
			
		||||
@@ -748,6 +749,7 @@ export type ServerConfigDto = {
 | 
			
		||||
};
 | 
			
		||||
export type ServerFeaturesDto = {
 | 
			
		||||
    configFile: boolean;
 | 
			
		||||
    duplicateDetection: boolean;
 | 
			
		||||
    email: boolean;
 | 
			
		||||
    facialRecognition: boolean;
 | 
			
		||||
    map: boolean;
 | 
			
		||||
@@ -927,6 +929,10 @@ export type ClipConfig = {
 | 
			
		||||
    modelName: string;
 | 
			
		||||
    modelType?: ModelType;
 | 
			
		||||
};
 | 
			
		||||
export type DuplicateDetectionConfig = {
 | 
			
		||||
    enabled: boolean;
 | 
			
		||||
    maxDistance: number;
 | 
			
		||||
};
 | 
			
		||||
export type RecognitionConfig = {
 | 
			
		||||
    enabled: boolean;
 | 
			
		||||
    maxDistance: number;
 | 
			
		||||
@@ -937,6 +943,7 @@ export type RecognitionConfig = {
 | 
			
		||||
};
 | 
			
		||||
export type SystemConfigMachineLearningDto = {
 | 
			
		||||
    clip: ClipConfig;
 | 
			
		||||
    duplicateDetection: DuplicateDetectionConfig;
 | 
			
		||||
    enabled: boolean;
 | 
			
		||||
    facialRecognition: RecognitionConfig;
 | 
			
		||||
    url: string;
 | 
			
		||||
@@ -1399,6 +1406,14 @@ export function getAllUserAssetsByDeviceId({ deviceId }: {
 | 
			
		||||
        ...opts
 | 
			
		||||
    }));
 | 
			
		||||
}
 | 
			
		||||
export function getAssetDuplicates(opts?: Oazapfts.RequestOpts) {
 | 
			
		||||
    return oazapfts.ok(oazapfts.fetchJson<{
 | 
			
		||||
        status: 200;
 | 
			
		||||
        data: AssetResponseDto[];
 | 
			
		||||
    }>("/asset/duplicates", {
 | 
			
		||||
        ...opts
 | 
			
		||||
    }));
 | 
			
		||||
}
 | 
			
		||||
/**
 | 
			
		||||
 * Checks if multiple assets exist on the server and returns all existing - used by background backup
 | 
			
		||||
 */
 | 
			
		||||
@@ -2876,6 +2891,7 @@ export enum JobName {
 | 
			
		||||
    FaceDetection = "faceDetection",
 | 
			
		||||
    FacialRecognition = "facialRecognition",
 | 
			
		||||
    SmartSearch = "smartSearch",
 | 
			
		||||
    DuplicateDetection = "duplicateDetection",
 | 
			
		||||
    BackgroundTask = "backgroundTask",
 | 
			
		||||
    StorageTemplateMigration = "storageTemplateMigration",
 | 
			
		||||
    Migration = "migration",
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user