Merged in chore/remove-unused-env-vars (pull request #2463)
chore: Remove unused env vars and feature toggles * Remove unused env vars and feature toggles Approved-by: Joakim Jäderberg
This commit is contained in:
23
apps/scandic-web/env/client.ts
vendored
23
apps/scandic-web/env/client.ts
vendored
@@ -1,24 +1,12 @@
|
||||
import { createEnv } from "@t3-oss/env-nextjs"
|
||||
import { z } from "zod"
|
||||
|
||||
import { getLiveStatus } from "./getLiveStatus"
|
||||
import { isLangLive } from "./isLangLive"
|
||||
|
||||
import type { Lang } from "@scandic-hotels/common/constants/language"
|
||||
|
||||
const _env = createEnv({
|
||||
export const env = createEnv({
|
||||
client: {
|
||||
NEXT_PUBLIC_NODE_ENV: z.enum(["development", "test", "production"]),
|
||||
NEXT_PUBLIC_PORT: z.string().default("3000"),
|
||||
NEXT_PUBLIC_SENTRY_ENVIRONMENT: z.string().default("development"),
|
||||
NEXT_PUBLIC_SENTRY_CLIENT_SAMPLERATE: z.coerce.number().default(0.001),
|
||||
NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS: z
|
||||
.string()
|
||||
.regex(/^([a-z]{2},)*([a-z]{2}){0,1}$/)
|
||||
.transform((val) => {
|
||||
return val.split(",")
|
||||
})
|
||||
.default(""),
|
||||
NEXT_PUBLIC_PUBLIC_URL: z.string().optional(),
|
||||
},
|
||||
emptyStringAsUndefined: true,
|
||||
@@ -28,15 +16,6 @@ const _env = createEnv({
|
||||
NEXT_PUBLIC_SENTRY_ENVIRONMENT: process.env.NEXT_PUBLIC_SENTRY_ENVIRONMENT,
|
||||
NEXT_PUBLIC_SENTRY_CLIENT_SAMPLERATE:
|
||||
process.env.NEXT_PUBLIC_SENTRY_CLIENT_SAMPLERATE,
|
||||
NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS:
|
||||
process.env.NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS,
|
||||
NEXT_PUBLIC_PUBLIC_URL: process.env.NEXT_PUBLIC_PUBLIC_URL,
|
||||
},
|
||||
})
|
||||
|
||||
export const env = {
|
||||
..._env,
|
||||
NEW_SITE_LIVE_STATUS: getLiveStatus(_env),
|
||||
isLangLive: (lang: Lang) =>
|
||||
isLangLive(lang, _env.NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS),
|
||||
}
|
||||
|
||||
53
apps/scandic-web/env/getLiveStatus.ts
vendored
53
apps/scandic-web/env/getLiveStatus.ts
vendored
@@ -1,53 +0,0 @@
|
||||
import { Lang } from "@scandic-hotels/common/constants/language"
|
||||
|
||||
export function getLiveStatus(
|
||||
internalEnv:
|
||||
| {
|
||||
NEW_SITE_LIVE_FOR_LANGS: string[]
|
||||
}
|
||||
| {
|
||||
NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS: string[]
|
||||
}
|
||||
): "ALL_LANGUAGES_LIVE" | "SOME_LANGUAGES_LIVE" | "NOT_LIVE" {
|
||||
const configuredLangs = getConfiguredLangs(internalEnv)
|
||||
if (!configuredLangs) {
|
||||
return "NOT_LIVE"
|
||||
}
|
||||
|
||||
const allLangs = Object.keys(Lang)
|
||||
const liveLangs = allLangs.filter((lang) => configuredLangs.includes(lang))
|
||||
if (liveLangs.length === 0) {
|
||||
return "NOT_LIVE"
|
||||
}
|
||||
|
||||
if (
|
||||
liveLangs.length === allLangs.length &&
|
||||
allLangs.every((lang) => liveLangs.includes(lang))
|
||||
) {
|
||||
return "ALL_LANGUAGES_LIVE"
|
||||
}
|
||||
|
||||
return "SOME_LANGUAGES_LIVE"
|
||||
}
|
||||
|
||||
function getConfiguredLangs<T extends {}>(env: T): string[] | undefined {
|
||||
if (
|
||||
!(
|
||||
"NEW_SITE_LIVE_FOR_LANGS" in env ||
|
||||
"NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS" in env
|
||||
)
|
||||
) {
|
||||
return undefined
|
||||
}
|
||||
|
||||
const configuredLangs =
|
||||
"NEW_SITE_LIVE_FOR_LANGS" in env
|
||||
? env.NEW_SITE_LIVE_FOR_LANGS
|
||||
: env.NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS
|
||||
|
||||
if (!Array.isArray(configuredLangs)) {
|
||||
throw new Error("Misconfigured environment variable, expected array")
|
||||
}
|
||||
|
||||
return configuredLangs
|
||||
}
|
||||
18
apps/scandic-web/env/isLangLive.test.ts
vendored
18
apps/scandic-web/env/isLangLive.test.ts
vendored
@@ -1,18 +0,0 @@
|
||||
import { describe, expect, it } from "@jest/globals"
|
||||
|
||||
import { Lang } from "@scandic-hotels/common/constants/language"
|
||||
|
||||
import { isLangLive } from "./isLangLive"
|
||||
|
||||
describe("hideForNextRelease", () => {
|
||||
it("should return true if en is part of live languages", () => {
|
||||
expect(isLangLive(Lang.en, ["en", "sv"])).toBe(true)
|
||||
expect(isLangLive(Lang.en, ["en"])).toBe(true)
|
||||
})
|
||||
|
||||
it("should return false if en is not part of live languages", () => {
|
||||
expect(isLangLive(Lang.en, [])).toBe(false)
|
||||
expect(isLangLive(Lang.en, ["sv"])).toBe(false)
|
||||
expect(isLangLive(Lang.en, ["sv,fi"])).toBe(false)
|
||||
})
|
||||
})
|
||||
5
apps/scandic-web/env/isLangLive.ts
vendored
5
apps/scandic-web/env/isLangLive.ts
vendored
@@ -1,5 +0,0 @@
|
||||
import type { Lang } from "@scandic-hotels/common/constants/language"
|
||||
|
||||
export function isLangLive(lang: Lang, liveLangs: string[]): boolean {
|
||||
return liveLangs.includes(lang)
|
||||
}
|
||||
39
apps/scandic-web/env/server.ts
vendored
39
apps/scandic-web/env/server.ts
vendored
@@ -1,14 +1,9 @@
|
||||
import { createEnv } from "@t3-oss/env-nextjs"
|
||||
import { z } from "zod"
|
||||
|
||||
import { getLiveStatus } from "./getLiveStatus"
|
||||
import { isLangLive } from "./isLangLive"
|
||||
|
||||
import type { Lang } from "@scandic-hotels/common/constants/language"
|
||||
|
||||
const TWENTYFOUR_HOURS = 24 * 60 * 60
|
||||
|
||||
const _env = createEnv({
|
||||
export const env = createEnv({
|
||||
/**
|
||||
* Due to t3-env only checking typeof window === "undefined"
|
||||
* and Netlify running Deno, window is never "undefined"
|
||||
@@ -112,13 +107,6 @@ const _env = createEnv({
|
||||
GOOGLE_STATIC_MAP_SIGNATURE_SECRET: z.string(),
|
||||
GOOGLE_DYNAMIC_MAP_ID: z.string(),
|
||||
GOOGLE_STATIC_MAP_ID: z.string(),
|
||||
ENABLE_BOOKING_WIDGET: z
|
||||
.string()
|
||||
// only allow "true" or "false"
|
||||
.refine((s) => s === "true" || s === "false")
|
||||
// transform to boolean
|
||||
.transform((s) => s === "true")
|
||||
.default("false"),
|
||||
ENABLE_SURPRISES: z
|
||||
.string()
|
||||
// only allow "true" or "false"
|
||||
@@ -155,11 +143,6 @@ const _env = createEnv({
|
||||
SAS_AUTH_ENDPOINT: z.string().default(""),
|
||||
SAS_OCP_APIM: z.string().default(""),
|
||||
SAS_AUTH_CLIENTID: z.string().default(""),
|
||||
SAS_ENABLED: z
|
||||
.string()
|
||||
.refine((s) => s === "1" || s === "0")
|
||||
.transform((s) => s === "1")
|
||||
.default("0"),
|
||||
SAS_POINT_TRANSFER_ENABLED: z
|
||||
.string()
|
||||
// only allow "true" or "false"
|
||||
@@ -192,17 +175,6 @@ const _env = createEnv({
|
||||
.transform((s) => s === "true")
|
||||
.default("true"),
|
||||
WARMUP_TOKEN: z.string().optional(),
|
||||
/**
|
||||
* Include the languages that should be hidden for the next release
|
||||
* Should be in the format of "en,da,de,fi,no,sv" or empty
|
||||
*/
|
||||
NEW_SITE_LIVE_FOR_LANGS: z
|
||||
.string()
|
||||
.regex(/^([a-z]{2},)*([a-z]{2}){0,1}$/)
|
||||
.transform((val) => {
|
||||
return val.split(",")
|
||||
})
|
||||
.default(""),
|
||||
DTMC_ENTRA_ID_CLIENT: z.string(),
|
||||
DTMC_ENTRA_ID_ISSUER: z.string(),
|
||||
/**
|
||||
@@ -284,7 +256,6 @@ const _env = createEnv({
|
||||
GOOGLE_STATIC_MAP_ID: process.env.GOOGLE_STATIC_MAP_ID,
|
||||
GOOGLE_DYNAMIC_MAP_ID: process.env.GOOGLE_DYNAMIC_MAP_ID,
|
||||
USE_NEW_REWARD_MODEL: process.env.USE_NEW_REWARD_MODEL,
|
||||
ENABLE_BOOKING_WIDGET: process.env.ENABLE_BOOKING_WIDGET,
|
||||
ENABLE_SURPRISES: process.env.ENABLE_SURPRISES,
|
||||
ENABLE_DTMC: process.env.ENABLE_DTMC,
|
||||
SHOW_SITE_WIDE_ALERT: process.env.SHOW_SITE_WIDE_ALERT,
|
||||
@@ -295,7 +266,6 @@ const _env = createEnv({
|
||||
SAS_AUTH_ENDPOINT: process.env.SAS_AUTH_ENDPOINT,
|
||||
SAS_OCP_APIM: process.env.SAS_OCP_APIM,
|
||||
SAS_AUTH_CLIENTID: process.env.SAS_AUTH_CLIENTID,
|
||||
SAS_ENABLED: process.env.SAS,
|
||||
SAS_POINT_TRANSFER_ENABLED: process.env.SAS_POINT_TRANSFER_ENABLED,
|
||||
|
||||
CACHE_TIME_HOTELS: process.env.CACHE_TIME_HOTELS,
|
||||
@@ -307,7 +277,6 @@ const _env = createEnv({
|
||||
GIT_SHA: process.env.GIT_SHA,
|
||||
ENABLE_WARMUP_HOTEL: process.env.ENABLE_WARMUP_HOTEL,
|
||||
WARMUP_TOKEN: process.env.WARMUP_TOKEN,
|
||||
NEW_SITE_LIVE_FOR_LANGS: process.env.NEXT_PUBLIC_NEW_SITE_LIVE_FOR_LANGS,
|
||||
|
||||
DTMC_ENTRA_ID_CLIENT: process.env.DTMC_ENTRA_ID_CLIENT,
|
||||
DTMC_ENTRA_ID_ISSUER: process.env.DTMC_ENTRA_ID_ISSUER,
|
||||
@@ -316,12 +285,6 @@ const _env = createEnv({
|
||||
},
|
||||
})
|
||||
|
||||
export const env = {
|
||||
..._env,
|
||||
NEW_SITE_LIVE_STATUS: getLiveStatus(_env),
|
||||
isLangLive: (lang: Lang) => isLangLive(lang, _env.NEW_SITE_LIVE_FOR_LANGS),
|
||||
} as const
|
||||
|
||||
function replaceTopLevelDomain(url: string, domain: string) {
|
||||
return url.replaceAll("{topleveldomain}", domain)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user