Fix StartOS 0.4 TypeScript packaging to match SDK API
This commit is contained in:
+28
@@ -0,0 +1,28 @@
|
||||
import * as T from '../../../base/lib/types';
|
||||
import { ImageId, VolumeId } from '../../../base/lib/types';
|
||||
import { SDKManifest, SDKImageInputSpec } from '../../../base/lib/types/ManifestTypes';
|
||||
import { VersionGraph } from '../version/VersionGraph';
|
||||
/**
|
||||
* @description Use this function to define critical information about your package
|
||||
*
|
||||
* @param manifest Static properties of the package
|
||||
*/
|
||||
export declare function setupManifest<Id extends string, VolumesTypes extends VolumeId, Manifest extends {
|
||||
id: Id;
|
||||
volumes: VolumesTypes[];
|
||||
} & SDKManifest>(manifest: Manifest & SDKManifest): Manifest;
|
||||
/**
|
||||
* Build the final publishable manifest by combining the SDK manifest definition
|
||||
* with version graph metadata, OS version, SDK version, and computed fields
|
||||
* (migration ranges, hardware requirements, alerts, etc.).
|
||||
*
|
||||
* @param versions - The service's VersionGraph, used to extract the current version, release notes, and migration ranges
|
||||
* @param manifest - The SDK manifest definition (from `setupManifest`)
|
||||
* @returns A fully resolved Manifest ready for packaging
|
||||
*/
|
||||
export declare function buildManifest<Id extends string, Version extends string, Dependencies extends Record<string, unknown>, VolumesTypes extends VolumeId, ImagesTypes extends ImageId, Manifest extends {
|
||||
dependencies: Dependencies;
|
||||
id: Id;
|
||||
images: Record<ImagesTypes, SDKImageInputSpec>;
|
||||
volumes: VolumesTypes[];
|
||||
}>(versions: VersionGraph<Version>, manifest: SDKManifest & Manifest): Manifest & T.Manifest;
|
||||
+71
@@ -0,0 +1,71 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.setupManifest = setupManifest;
|
||||
exports.buildManifest = buildManifest;
|
||||
const StartSdk_1 = require("../StartSdk");
|
||||
const package_json_1 = require("../../package.json");
|
||||
/**
|
||||
* @description Use this function to define critical information about your package
|
||||
*
|
||||
* @param manifest Static properties of the package
|
||||
*/
|
||||
function setupManifest(manifest) {
|
||||
return manifest;
|
||||
}
|
||||
/**
|
||||
* Build the final publishable manifest by combining the SDK manifest definition
|
||||
* with version graph metadata, OS version, SDK version, and computed fields
|
||||
* (migration ranges, hardware requirements, alerts, etc.).
|
||||
*
|
||||
* @param versions - The service's VersionGraph, used to extract the current version, release notes, and migration ranges
|
||||
* @param manifest - The SDK manifest definition (from `setupManifest`)
|
||||
* @returns A fully resolved Manifest ready for packaging
|
||||
*/
|
||||
function buildManifest(versions, manifest) {
|
||||
const images = Object.entries(manifest.images).reduce((images, [k, v]) => {
|
||||
v.arch = v.arch ?? ['aarch64', 'x86_64', 'riscv64'];
|
||||
if (v.emulateMissingAs === undefined)
|
||||
v.emulateMissingAs = v.arch.includes('x86_64')
|
||||
? 'x86_64'
|
||||
: (v.arch[0] ?? null);
|
||||
v.nvidiaContainer = !!v.nvidiaContainer;
|
||||
images[k] = v;
|
||||
return images;
|
||||
}, {});
|
||||
return {
|
||||
...manifest,
|
||||
gitHash: null,
|
||||
osVersion: manifest.osVersion ?? StartSdk_1.OSVersion,
|
||||
sdkVersion: package_json_1.version,
|
||||
version: versions.current.options.version,
|
||||
releaseNotes: versions.current.options.releaseNotes,
|
||||
satisfies: versions.current.options.satisfies || [],
|
||||
canMigrateTo: versions.canMigrateTo().toString(),
|
||||
canMigrateFrom: versions.canMigrateFrom().toString(),
|
||||
images,
|
||||
alerts: {
|
||||
install: manifest.alerts?.install || null,
|
||||
update: manifest.alerts?.update || null,
|
||||
uninstall: manifest.alerts?.uninstall || null,
|
||||
restore: manifest.alerts?.restore || null,
|
||||
start: manifest.alerts?.start || null,
|
||||
stop: manifest.alerts?.stop || null,
|
||||
},
|
||||
hardwareRequirements: {
|
||||
device: manifest.hardwareRequirements?.device || [],
|
||||
ram: manifest.hardwareRequirements?.ram || null,
|
||||
arch: Object.values(images).reduce((arch, inputSpec) => {
|
||||
if (inputSpec.emulateMissingAs) {
|
||||
return arch;
|
||||
}
|
||||
if (arch === null) {
|
||||
return inputSpec.arch;
|
||||
}
|
||||
return arch.filter((a) => inputSpec.arch.includes(a));
|
||||
}, null),
|
||||
},
|
||||
hardwareAcceleration: manifest.hardwareAcceleration ?? false,
|
||||
plugins: manifest.plugins ?? [],
|
||||
};
|
||||
}
|
||||
//# sourceMappingURL=setupManifest.js.map
|
||||
+1
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"setupManifest.js","sourceRoot":"","sources":["../../../../package/lib/manifest/setupManifest.ts"],"names":[],"mappings":"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"}
|
||||
Reference in New Issue
Block a user