1
0
mirror of https://github.com/flarum/core.git synced 2025-08-04 15:37:51 +02:00

fix(em): prevent major updater for pre-releases (#4131)

This commit is contained in:
Sami Mazouz
2024-11-30 14:06:44 +01:00
committed by GitHub
parent be27dab12c
commit f26c50fc6c
2 changed files with 34 additions and 1 deletions

View File

@@ -7,6 +7,7 @@ import MajorUpdater from './MajorUpdater';
import ExtensionItem from './ExtensionItem';
import { Extension } from 'flarum/admin/AdminApplication';
import ItemList from 'flarum/common/utils/ItemList';
import { isProductionReady } from '../utils/versions';
export interface IUpdaterAttrs extends ComponentAttrs {}
@@ -24,7 +25,7 @@ export default class Updater extends Component<IUpdaterAttrs> {
<div className="ExtensionManager-updaterControls">{this.controlItems().toArray()}</div>
{this.availableUpdatesView()}
</div>,
core && core.package['latest-major'] ? (
core && core.package['latest-major'] && isProductionReady(core.package['latest-major']) ? (
<MajorUpdater coreUpdate={core.package} updateState={app.extensionManager.control.lastUpdateRun.major} />
) : null,
];

View File

@@ -0,0 +1,32 @@
export enum VersionStability {
Stable = 'stable',
Alpha = 'alpha',
Beta = 'beta',
RC = 'rc',
Dev = 'dev',
}
export function isProductionReady(version: string): boolean {
return [VersionStability.Stable].includes(stability(version));
}
export function stability(version: string): VersionStability {
const split = version.split('-');
if (split.length === 1) {
return VersionStability.Stable;
}
const stab = split[1].split('.')[0].toLowerCase();
switch (stab) {
case 'alpha':
return VersionStability.Alpha;
case 'beta':
return VersionStability.Beta;
case 'rc':
return VersionStability.RC;
default:
return VersionStability.Dev;
}
}