1
0
mirror of https://github.com/immich-app/immich.git synced 2025-01-12 15:32:36 +02:00

feat(server): add env for reverse geocoding path (#6163)

* feat: add env for reverse geocoding path

* fix: quote in doc
This commit is contained in:
martin 2024-01-04 14:36:52 +01:00 committed by GitHub
parent 18f59f78e3
commit aefd93e43a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 27 additions and 15 deletions

View File

@ -30,14 +30,15 @@ These environment variables are used by the `docker-compose.yml` file and do **N
## General ## General
| Variable | Description | Default | Services | | Variable | Description | Default | Services |
| :---------------------- | :------------------------------------------- | :-----------------: | :------------------------------------------- | | :------------------------------ | :------------------------------------------- | :------------------: | :------------------------------------------- |
| `TZ` | Timezone | | microservices | | `TZ` | Timezone | | microservices |
| `NODE_ENV` | Environment (production, development) | `production` | server, microservices, machine learning, web | | `NODE_ENV` | Environment (production, development) | `production` | server, microservices, machine learning, web |
| `LOG_LEVEL` | Log Level (verbose, debug, log, warn, error) | `log` | server, microservices | | `LOG_LEVEL` | Log Level (verbose, debug, log, warn, error) | `log` | server, microservices |
| `IMMICH_MEDIA_LOCATION` | Media Location | `./upload` | server, microservices | | `IMMICH_MEDIA_LOCATION` | Media Location | `./upload` | server, microservices |
| `IMMICH_CONFIG_FILE` | Path to config file | | server | | `IMMICH_CONFIG_FILE` | Path to config file | | server |
| `IMMICH_WEB_ROOT` | Path of root index.html | `/usr/src/app/www'` | server | | `IMMICH_WEB_ROOT` | Path of root index.html | `/usr/src/app/www` | server |
| `IMMICH_REVERSE_GEOCODING_ROOT` | Path of reverse geocoding dump directory | `/usr/src/resources` | microservices |
:::tip :::tip

View File

@ -72,6 +72,14 @@ export const APP_MEDIA_LOCATION = process.env.IMMICH_MEDIA_LOCATION || './upload
export const WEB_ROOT_PATH = join(process.env.IMMICH_WEB_ROOT || '/usr/src/app/www', 'index.html'); export const WEB_ROOT_PATH = join(process.env.IMMICH_WEB_ROOT || '/usr/src/app/www', 'index.html');
const GEODATA_ROOT_PATH = process.env.IMMICH_REVERSE_GEOCODING_ROOT || '/usr/src/resources';
export const citiesFile = 'cities500.txt';
export const geodataDatePath = join(GEODATA_ROOT_PATH, 'geodata-date.txt');
export const geodataAdmin1Path = join(GEODATA_ROOT_PATH, 'admin1CodesASCII.txt');
export const geodataAdmin2Path = join(GEODATA_ROOT_PATH, 'admin2Codes.txt');
export const geodataCitites500Path = join(GEODATA_ROOT_PATH, citiesFile);
const image: Record<string, string[]> = { const image: Record<string, string[]> = {
'.3fr': ['image/3fr', 'image/x-hasselblad-3fr'], '.3fr': ['image/3fr', 'image/x-hasselblad-3fr'],
'.ari': ['image/ari', 'image/x-arriflex-ari'], '.ari': ['image/ari', 'image/x-arriflex-ari'],

View File

@ -1,4 +1,9 @@
import { import {
citiesFile,
geodataAdmin1Path,
geodataAdmin2Path,
geodataCitites500Path,
geodataDatePath,
GeoPoint, GeoPoint,
IMetadataRepository, IMetadataRepository,
ImmichTags, ImmichTags,
@ -20,8 +25,6 @@ import { DataSource, DeepPartial, QueryRunner, Repository } from 'typeorm';
type GeoEntity = GeodataPlacesEntity | GeodataAdmin1Entity | GeodataAdmin2Entity; type GeoEntity = GeodataPlacesEntity | GeodataAdmin1Entity | GeodataAdmin2Entity;
type GeoEntityClass = typeof GeodataPlacesEntity | typeof GeodataAdmin1Entity | typeof GeodataAdmin2Entity; type GeoEntityClass = typeof GeodataPlacesEntity | typeof GeodataAdmin1Entity | typeof GeodataAdmin2Entity;
const CITIES_FILE = 'cities500.txt';
export class MetadataRepository implements IMetadataRepository { export class MetadataRepository implements IMetadataRepository {
constructor( constructor(
@InjectRepository(GeodataPlacesEntity) private readonly geodataPlacesRepository: Repository<GeodataPlacesEntity>, @InjectRepository(GeodataPlacesEntity) private readonly geodataPlacesRepository: Repository<GeodataPlacesEntity>,
@ -35,7 +38,7 @@ export class MetadataRepository implements IMetadataRepository {
async init(): Promise<void> { async init(): Promise<void> {
this.logger.log('Initializing metadata repository'); this.logger.log('Initializing metadata repository');
const geodataDate = await readFile('/usr/src/resources/geodata-date.txt', 'utf8'); const geodataDate = await readFile(geodataDatePath, 'utf8');
const geocodingMetadata = await this.systemMetadataRepository.get(SystemMetadataKey.REVERSE_GEOCODING_STATE); const geocodingMetadata = await this.systemMetadataRepository.get(SystemMetadataKey.REVERSE_GEOCODING_STATE);
@ -48,7 +51,7 @@ export class MetadataRepository implements IMetadataRepository {
await this.systemMetadataRepository.set(SystemMetadataKey.REVERSE_GEOCODING_STATE, { await this.systemMetadataRepository.set(SystemMetadataKey.REVERSE_GEOCODING_STATE, {
lastUpdate: geodataDate, lastUpdate: geodataDate,
lastImportFileName: CITIES_FILE, lastImportFileName: citiesFile,
}); });
this.logger.log('Geodata import completed'); this.logger.log('Geodata import completed');
@ -116,7 +119,7 @@ export class MetadataRepository implements IMetadataRepository {
admin2Code: lineSplit[11], admin2Code: lineSplit[11],
modificationDate: lineSplit[18], modificationDate: lineSplit[18],
}), }),
`/usr/src/resources/${CITIES_FILE}`, geodataCitites500Path,
GeodataPlacesEntity, GeodataPlacesEntity,
); );
} }
@ -129,7 +132,7 @@ export class MetadataRepository implements IMetadataRepository {
key: lineSplit[0], key: lineSplit[0],
name: lineSplit[1], name: lineSplit[1],
}), }),
'/usr/src/resources/admin1CodesASCII.txt', geodataAdmin1Path,
GeodataAdmin1Entity, GeodataAdmin1Entity,
); );
} }
@ -142,7 +145,7 @@ export class MetadataRepository implements IMetadataRepository {
key: lineSplit[0], key: lineSplit[0],
name: lineSplit[1], name: lineSplit[1],
}), }),
'/usr/src/resources/admin2Codes.txt', geodataAdmin2Path,
GeodataAdmin2Entity, GeodataAdmin2Entity,
); );
} }