mirror of
https://github.com/immich-app/immich.git
synced 2025-01-21 03:02:44 +01:00
feat(cli) CLI when uploading photo.EXT, it detects both photo.EXT.xmp and photo.xmp (#8186)
* Initial implementation * chore: remove duplicate access check --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
This commit is contained in:
parent
d18868873e
commit
d1e6843f3e
1 changed files with 28 additions and 7 deletions
|
@ -14,7 +14,7 @@ import { createHash } from 'node:crypto';
|
||||||
import fs, { createReadStream } from 'node:fs';
|
import fs, { createReadStream } from 'node:fs';
|
||||||
import { access, constants, stat, unlink } from 'node:fs/promises';
|
import { access, constants, stat, unlink } from 'node:fs/promises';
|
||||||
import os from 'node:os';
|
import os from 'node:os';
|
||||||
import { basename } from 'node:path';
|
import path, { basename } from 'node:path';
|
||||||
import { CrawlService } from 'src/services/crawl.service';
|
import { CrawlService } from 'src/services/crawl.service';
|
||||||
import { BaseOptions, authenticate } from 'src/utils';
|
import { BaseOptions, authenticate } from 'src/utils';
|
||||||
|
|
||||||
|
@ -61,13 +61,34 @@ class Asset {
|
||||||
throw new Error('File modified at not set');
|
throw new Error('File modified at not set');
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: doesn't xmp replace the file extension? Will need investigation
|
// XMP sidecars can come in two filename formats. For a photo named photo.ext, the filenames are photo.ext.xmp and photo.xmp
|
||||||
const sideCarPath = `${this.path}.xmp`;
|
const assetPath = path.parse(this.path);
|
||||||
|
const assetPathWithoutExt = path.join(assetPath.dir, assetPath.name);
|
||||||
|
const sidecarPathWithoutExt = `${assetPathWithoutExt}.xmp`;
|
||||||
|
const sideCarPathWithExt = `${this.path}.xmp`;
|
||||||
|
|
||||||
|
const [sideCarWithExtExists, sideCarWithoutExtExists] = await Promise.all([
|
||||||
|
access(sideCarPathWithExt, constants.R_OK)
|
||||||
|
.then(() => true)
|
||||||
|
.catch(() => false),
|
||||||
|
access(sidecarPathWithoutExt, constants.R_OK)
|
||||||
|
.then(() => true)
|
||||||
|
.catch(() => false),
|
||||||
|
]);
|
||||||
|
|
||||||
|
let sidecarPath = undefined;
|
||||||
|
if (sideCarWithExtExists) {
|
||||||
|
sidecarPath = sideCarPathWithExt;
|
||||||
|
} else if (sideCarWithoutExtExists) {
|
||||||
|
sidecarPath = sidecarPathWithoutExt;
|
||||||
|
}
|
||||||
|
|
||||||
let sidecarData: Blob | undefined = undefined;
|
let sidecarData: Blob | undefined = undefined;
|
||||||
|
if (sidecarPath) {
|
||||||
try {
|
try {
|
||||||
await access(sideCarPath, constants.R_OK);
|
sidecarData = new File([await fs.openAsBlob(sidecarPath)], basename(sidecarPath));
|
||||||
sidecarData = new File([await fs.openAsBlob(sideCarPath)], basename(sideCarPath));
|
|
||||||
} catch {}
|
} catch {}
|
||||||
|
}
|
||||||
|
|
||||||
const data: any = {
|
const data: any = {
|
||||||
assetData: new File([await fs.openAsBlob(this.path)], basename(this.path)),
|
assetData: new File([await fs.openAsBlob(this.path)], basename(this.path)),
|
||||||
|
|
Loading…
Reference in a new issue