Fixing an issue when invalid version is supplied (not semver) shouldn't crash server.

This commit is contained in:
mike12345567 2024-02-16 15:41:36 +00:00
parent 101caf323a
commit 364579acc4
1 changed files with 27 additions and 18 deletions

View File

@ -6,6 +6,7 @@ import * as context from "./context"
import semver from "semver" import semver from "semver"
import { bustCache, withCache, TTL, CacheKey } from "./cache/generic" import { bustCache, withCache, TTL, CacheKey } from "./cache/generic"
import environment from "./environment" import environment from "./environment"
import { logAlert } from "./logging"
export const getInstall = async (): Promise<Installation> => { export const getInstall = async (): Promise<Installation> => {
return withCache(CacheKey.INSTALLATION, TTL.ONE_DAY, getInstallFromDB, { return withCache(CacheKey.INSTALLATION, TTL.ONE_DAY, getInstallFromDB, {
@ -80,27 +81,35 @@ export const checkInstallVersion = async (): Promise<void> => {
const currentVersion = install.version const currentVersion = install.version
const newVersion = environment.VERSION const newVersion = environment.VERSION
if (currentVersion !== newVersion) { try {
const isUpgrade = semver.gt(newVersion, currentVersion) if (currentVersion !== newVersion) {
const isDowngrade = semver.lt(newVersion, currentVersion) const isUpgrade = semver.gt(newVersion, currentVersion)
const isDowngrade = semver.lt(newVersion, currentVersion)
const success = await updateVersion(newVersion) const success = await updateVersion(newVersion)
if (success) { if (success) {
await context.doInIdentityContext( await context.doInIdentityContext(
{ {
_id: install.installId, _id: install.installId,
type: IdentityType.INSTALLATION, type: IdentityType.INSTALLATION,
}, },
async () => { async () => {
if (isUpgrade) { if (isUpgrade) {
await events.installation.upgraded(currentVersion, newVersion) await events.installation.upgraded(currentVersion, newVersion)
} else if (isDowngrade) { } else if (isDowngrade) {
await events.installation.downgraded(currentVersion, newVersion) await events.installation.downgraded(currentVersion, newVersion)
}
} }
} )
) await events.identification.identifyInstallationGroup(install.installId)
await events.identification.identifyInstallationGroup(install.installId) }
}
} catch (err: any) {
if (err?.message?.includes("Invalid Version")) {
logAlert(`Invalid version "${newVersion}" - is it semver?`)
} else {
logAlert("Failed to retrieve version", err)
} }
} }
} }