From f8d64be13c4c0fdba9b481aaa91b2a71aed11b95 Mon Sep 17 00:00:00 2001 From: Jason Rasmussen Date: Thu, 4 Jan 2024 00:00:17 -0500 Subject: [PATCH] feat(server)!: move welcome message to settings (#6157) * feat(server): move welcome message to settings * chore: open api --- cli/src/api/open-api/api.ts | 6 ++++++ docs/docs/install/environment-variables.md | 17 ++++++++--------- mobile/openapi/doc/SystemConfigServerDto.md | Bin 425 -> 465 bytes .../lib/model/system_config_server_dto.dart | Bin 2976 -> 3320 bytes .../test/system_config_server_dto_test.dart | Bin 599 -> 716 bytes server/immich-openapi-specs.json | 6 +++++- .../domain/server-info/server-info.service.ts | 6 +----- .../dto/system-config-server.dto.ts | 3 +++ .../system-config/system-config.core.ts | 1 + .../system-config.service.spec.ts | 1 + .../infra/entities/system-config.entity.ts | 2 ++ web/src/api/open-api/api.ts | 6 ++++++ .../settings/server/server-settings.svelte | 9 +++++++++ 13 files changed, 42 insertions(+), 15 deletions(-) diff --git a/cli/src/api/open-api/api.ts b/cli/src/api/open-api/api.ts index 3c2980ef80..089b69c474 100644 --- a/cli/src/api/open-api/api.ts +++ b/cli/src/api/open-api/api.ts @@ -4038,6 +4038,12 @@ export interface SystemConfigServerDto { * @memberof SystemConfigServerDto */ 'externalDomain': string; + /** + * + * @type {string} + * @memberof SystemConfigServerDto + */ + 'loginPageMessage': string; } /** * diff --git a/docs/docs/install/environment-variables.md b/docs/docs/install/environment-variables.md index 2a09a98242..68b44835c8 100644 --- a/docs/docs/install/environment-variables.md +++ b/docs/docs/install/environment-variables.md @@ -30,15 +30,14 @@ These environment variables are used by the `docker-compose.yml` file and do **N ## General -| Variable | Description | Default | Services | -| :-------------------------- | :------------------------------------------- | :-----------------: | :------------------------------------------- | -| `TZ` | Timezone | | microservices | -| `NODE_ENV` | Environment (production, development) | `production` | server, microservices, machine learning, web | -| `LOG_LEVEL` | Log Level (verbose, debug, log, warn, error) | `log` | server, microservices | -| `IMMICH_MEDIA_LOCATION` | Media Location | `./upload` | server, microservices | -| `PUBLIC_LOGIN_PAGE_MESSAGE` | Public Login Page Message | | web | -| `IMMICH_CONFIG_FILE` | Path to config file | | server | -| `IMMICH_WEB_ROOT` | Path of root index.html | `/usr/src/app/www'` | server | +| Variable | Description | Default | Services | +| :---------------------- | :------------------------------------------- | :-----------------: | :------------------------------------------- | +| `TZ` | Timezone | | microservices | +| `NODE_ENV` | Environment (production, development) | `production` | server, microservices, machine learning, web | +| `LOG_LEVEL` | Log Level (verbose, debug, log, warn, error) | `log` | server, microservices | +| `IMMICH_MEDIA_LOCATION` | Media Location | `./upload` | server, microservices | +| `IMMICH_CONFIG_FILE` | Path to config file | | server | +| `IMMICH_WEB_ROOT` | Path of root index.html | `/usr/src/app/www'` | server | :::tip diff --git a/mobile/openapi/doc/SystemConfigServerDto.md b/mobile/openapi/doc/SystemConfigServerDto.md index f749fb587d2c3b8f5de9a16826c02af75827d5b0..ead49eeb4f9a438037c8895321df90f68f43ab37 100644 GIT binary patch delta 29 jcmZ3zj}vMLIo8?!ls)rd__K>^cz9ia1T Jt+{HsxByaSb4dUI delta 44 zcmV+{0Mq~Y8K4)ivjLOW0U?tV0+o~80%? { const config = await this.configCore.getConfig(); - - // TODO move to system config - const loginPageMessage = process.env.PUBLIC_LOGIN_PAGE_MESSAGE || ''; - const isInitialized = await this.userRepository.hasAdmin(); return { - loginPageMessage, + loginPageMessage: config.server.loginPageMessage, trashDays: config.trash.days, oauthButtonText: config.oauth.buttonText, isInitialized, diff --git a/server/src/domain/system-config/dto/system-config-server.dto.ts b/server/src/domain/system-config/dto/system-config-server.dto.ts index 0b5cb35508..83a2b0df9b 100644 --- a/server/src/domain/system-config/dto/system-config-server.dto.ts +++ b/server/src/domain/system-config/dto/system-config-server.dto.ts @@ -3,4 +3,7 @@ import { IsString } from 'class-validator'; export class SystemConfigServerDto { @IsString() externalDomain!: string; + + @IsString() + loginPageMessage!: string; } diff --git a/server/src/domain/system-config/system-config.core.ts b/server/src/domain/system-config/system-config.core.ts index 8aaab1c9ed..f4ed674cf6 100644 --- a/server/src/domain/system-config/system-config.core.ts +++ b/server/src/domain/system-config/system-config.core.ts @@ -129,6 +129,7 @@ export const defaults = Object.freeze({ }, server: { externalDomain: '', + loginPageMessage: '', }, }); diff --git a/server/src/domain/system-config/system-config.service.spec.ts b/server/src/domain/system-config/system-config.service.spec.ts index 1f71a0beb8..f489d29b93 100644 --- a/server/src/domain/system-config/system-config.service.spec.ts +++ b/server/src/domain/system-config/system-config.service.spec.ts @@ -102,6 +102,7 @@ const updatedConfig = Object.freeze({ }, server: { externalDomain: '', + loginPageMessage: '', }, storageTemplate: { enabled: false, diff --git a/server/src/infra/entities/system-config.entity.ts b/server/src/infra/entities/system-config.entity.ts index 9033ec387e..28faccfcb9 100644 --- a/server/src/infra/entities/system-config.entity.ts +++ b/server/src/infra/entities/system-config.entity.ts @@ -85,6 +85,7 @@ export enum SystemConfigKey { PASSWORD_LOGIN_ENABLED = 'passwordLogin.enabled', SERVER_EXTERNAL_DOMAIN = 'server.externalDomain', + SERVER_LOGIN_PAGE_MESSAGE = 'server.loginPageMessage', STORAGE_TEMPLATE_ENABLED = 'storageTemplate.enabled', STORAGE_TEMPLATE_HASH_VERIFICATION_ENABLED = 'storageTemplate.hashVerificationEnabled', @@ -248,5 +249,6 @@ export interface SystemConfig { }; server: { externalDomain: string; + loginPageMessage: string; }; } diff --git a/web/src/api/open-api/api.ts b/web/src/api/open-api/api.ts index 3c2980ef80..089b69c474 100644 --- a/web/src/api/open-api/api.ts +++ b/web/src/api/open-api/api.ts @@ -4038,6 +4038,12 @@ export interface SystemConfigServerDto { * @memberof SystemConfigServerDto */ 'externalDomain': string; + /** + * + * @type {string} + * @memberof SystemConfigServerDto + */ + 'loginPageMessage': string; } /** * diff --git a/web/src/lib/components/admin-page/settings/server/server-settings.svelte b/web/src/lib/components/admin-page/settings/server/server-settings.svelte index 16c1eabfc5..c951bb940c 100644 --- a/web/src/lib/components/admin-page/settings/server/server-settings.svelte +++ b/web/src/lib/components/admin-page/settings/server/server-settings.svelte @@ -92,6 +92,15 @@ bind:value={serverConfig.externalDomain} isEdited={serverConfig.externalDomain !== savedConfig.externalDomain} /> + + +
handleReset(detail)}