1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-04 02:46:47 +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:
Kokul Shanmugharajah 2024-03-22 06:00:27 -07:00 committed by GitHub
parent d18868873e
commit d1e6843f3e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -14,7 +14,7 @@ import { createHash } from 'node:crypto';
import fs, { createReadStream } from 'node:fs';
import { access, constants, stat, unlink } from 'node:fs/promises';
import os from 'node:os';
import { basename } from 'node:path';
import path, { basename } from 'node:path';
import { CrawlService } from 'src/services/crawl.service';
import { BaseOptions, authenticate } from 'src/utils';
@ -61,13 +61,34 @@ class Asset {
throw new Error('File modified at not set');
}
// TODO: doesn't xmp replace the file extension? Will need investigation
const sideCarPath = `${this.path}.xmp`;
// XMP sidecars can come in two filename formats. For a photo named photo.ext, the filenames are photo.ext.xmp and photo.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;
try {
await access(sideCarPath, constants.R_OK);
sidecarData = new File([await fs.openAsBlob(sideCarPath)], basename(sideCarPath));
} catch {}
if (sidecarPath) {
try {
sidecarData = new File([await fs.openAsBlob(sidecarPath)], basename(sidecarPath));
} catch {}
}
const data: any = {
assetData: new File([await fs.openAsBlob(this.path)], basename(this.path)),