mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 02:46:47 +01:00
* fix(server): Does not assign lat/lon if they are at 0,0 #2991 * Adds migration file to fix null island rows * Removed down migration * Leave empty down function
This commit is contained in:
parent
079aa13edb
commit
f1b8a7ab54
4 changed files with 44 additions and 4 deletions
|
@ -0,0 +1,13 @@
|
|||
import { MigrationInterface, QueryRunner } from "typeorm"
|
||||
|
||||
export class FixGPSNullIsland1692057328660 implements MigrationInterface {
|
||||
|
||||
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||
await queryRunner.query(`UPDATE "exif" SET latitude = NULL, longitude = NULL WHERE latitude = 0 AND longitude = 0;`);
|
||||
}
|
||||
|
||||
public async down(): Promise<void> {
|
||||
// Setting lat,lon to 0 not necessary
|
||||
}
|
||||
|
||||
}
|
|
@ -308,8 +308,16 @@ export class MetadataExtractionProcessor {
|
|||
|
||||
const latitude = getExifProperty('GPSLatitude');
|
||||
const longitude = getExifProperty('GPSLongitude');
|
||||
newExif.latitude = latitude !== null ? parseLatitude(latitude) : null;
|
||||
newExif.longitude = longitude !== null ? parseLongitude(longitude) : null;
|
||||
const lat = parseLatitude(latitude);
|
||||
const lon = parseLongitude(longitude);
|
||||
|
||||
if (lat === 0 && lon === 0) {
|
||||
this.logger.warn(`Latitude & Longitude were on Null Island (${lat},${lon}), not assigning coordinates`);
|
||||
} else {
|
||||
newExif.latitude = lat;
|
||||
newExif.longitude = lon;
|
||||
}
|
||||
|
||||
if (getExifProperty('MotionPhoto')) {
|
||||
// Seen on more recent Pixel phones: starting as early as Pixel 4a, possibly earlier.
|
||||
const rawDirectory = getExifProperty('Directory');
|
||||
|
|
|
@ -23,6 +23,12 @@ describe('parsing latitude from string input', () => {
|
|||
});
|
||||
});
|
||||
|
||||
describe('parsing latitude from null input', () => {
|
||||
it('returns null for null input', () => {
|
||||
expect(parseLatitude(null)).toBeNull();
|
||||
});
|
||||
});
|
||||
|
||||
describe('parsing longitude from string input', () => {
|
||||
it('returns null for invalid inputs', () => {
|
||||
expect(parseLongitude('')).toBeNull();
|
||||
|
@ -44,3 +50,9 @@ describe('parsing longitude from string input', () => {
|
|||
expect(parseLongitude('-0.0')).toBeCloseTo(-0.0);
|
||||
});
|
||||
});
|
||||
|
||||
describe('parsing longitude from null input', () => {
|
||||
it('returns null for null input', () => {
|
||||
expect(parseLongitude(null)).toBeNull();
|
||||
});
|
||||
});
|
||||
|
|
|
@ -1,6 +1,9 @@
|
|||
import { isNumberInRange } from '../numbers';
|
||||
|
||||
export function parseLatitude(input: string | number): number | null {
|
||||
export function parseLatitude(input: string | number | null): number | null {
|
||||
if (input === null) {
|
||||
return null;
|
||||
}
|
||||
const latitude = typeof input === 'string' ? Number.parseFloat(input) : input;
|
||||
|
||||
if (isNumberInRange(latitude, -90, 90)) {
|
||||
|
@ -9,7 +12,11 @@ export function parseLatitude(input: string | number): number | null {
|
|||
return null;
|
||||
}
|
||||
|
||||
export function parseLongitude(input: string | number): number | null {
|
||||
export function parseLongitude(input: string | number | null): number | null {
|
||||
if (input === null) {
|
||||
return null;
|
||||
}
|
||||
|
||||
const longitude = typeof input === 'string' ? Number.parseFloat(input) : input;
|
||||
|
||||
if (isNumberInRange(longitude, -180, 180)) {
|
||||
|
|
Loading…
Reference in a new issue