mirror of
https://github.com/Kir-Antipov/mc-publish.git
synced 2025-01-22 18:14:45 +01:00
id
can be read from metadata again
This commit is contained in:
parent
4cf81648dc
commit
48e56214c9
1 changed files with 5 additions and 2 deletions
|
@ -9,6 +9,7 @@ import { ENVIRONMENT } from "@/utils/environment";
|
||||||
import { ArgumentError, ArgumentNullError, ErrorBuilder, FailMode, FileNotFoundError } from "@/utils/errors";
|
import { ArgumentError, ArgumentNullError, ErrorBuilder, FailMode, FileNotFoundError } from "@/utils/errors";
|
||||||
import { Logger, getDefaultLogger } from "@/utils/logging";
|
import { Logger, getDefaultLogger } from "@/utils/logging";
|
||||||
import { DYNAMIC_MODULE_LOADER } from "@/utils/reflection";
|
import { DYNAMIC_MODULE_LOADER } from "@/utils/reflection";
|
||||||
|
import { UnionToIntersection } from "@/utils/types";
|
||||||
import { VersionType } from "@/utils/versioning";
|
import { VersionType } from "@/utils/versioning";
|
||||||
import { PathLike } from "node:fs";
|
import { PathLike } from "node:fs";
|
||||||
|
|
||||||
|
@ -68,7 +69,7 @@ async function publish(action: Action, githubContext: GitHubContext, logger: Log
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const options = await fillInDefaultValues(platformOptions, githubContext, metadataReader);
|
const options = await fillInDefaultValues(platformOptions, platform, githubContext, metadataReader);
|
||||||
const uploader = createPlatformUploader(platform, { logger, githubContext });
|
const uploader = createPlatformUploader(platform, { logger, githubContext });
|
||||||
try {
|
try {
|
||||||
action.output[platform as string] = await uploader.upload(options);
|
action.output[platform as string] = await uploader.upload(options);
|
||||||
|
@ -91,12 +92,13 @@ async function publish(action: Action, githubContext: GitHubContext, logger: Log
|
||||||
* Fills in the default values for the specified options.
|
* Fills in the default values for the specified options.
|
||||||
*
|
*
|
||||||
* @param options - The options to fill in the default values for.
|
* @param options - The options to fill in the default values for.
|
||||||
|
* @param platform - The target platform.
|
||||||
* @param githubContext - The GitHub context.
|
* @param githubContext - The GitHub context.
|
||||||
* @param reader - The metadata reader.
|
* @param reader - The metadata reader.
|
||||||
*
|
*
|
||||||
* @returns A promise that resolves to the options with default values filled in.
|
* @returns A promise that resolves to the options with default values filled in.
|
||||||
*/
|
*/
|
||||||
async function fillInDefaultValues<T extends McPublishInput[PlatformType]>(options: T, githubContext: GitHubContext, reader?: LoaderMetadataReader): Promise<T> {
|
async function fillInDefaultValues<T extends McPublishInput[P], P extends PlatformType>(options: T, platform: P, githubContext: GitHubContext, reader?: LoaderMetadataReader): Promise<T> {
|
||||||
ArgumentError.throwIfNullOrEmpty(options.files, "options.files");
|
ArgumentError.throwIfNullOrEmpty(options.files, "options.files");
|
||||||
|
|
||||||
options = { ...options };
|
options = { ...options };
|
||||||
|
@ -108,6 +110,7 @@ async function fillInDefaultValues<T extends McPublishInput[PlatformType]>(optio
|
||||||
const gameVersions = await gameVersionProvider?.(wrappedGameVersions);
|
const gameVersions = await gameVersionProvider?.(wrappedGameVersions);
|
||||||
const unwrappedGameVersions = gameVersions ? GameVersionFilter.filter(gameVersions, options.gameVersionFilter).map(x => x.id) : wrappedGameVersions;
|
const unwrappedGameVersions = gameVersions ? GameVersionFilter.filter(gameVersions, options.gameVersionFilter).map(x => x.id) : wrappedGameVersions;
|
||||||
|
|
||||||
|
(options as UnionToIntersection<McPublishInput[PlatformType]>).id ||= metadata?.getProjectId(platform) || "";
|
||||||
options.version ||= githubContext.payload.release?.tag_name || metadata?.version;
|
options.version ||= githubContext.payload.release?.tag_name || metadata?.version;
|
||||||
options.versionType ||= VersionType.parseFromFileName(metadata?.version || primaryFile.name);
|
options.versionType ||= VersionType.parseFromFileName(metadata?.version || primaryFile.name);
|
||||||
options.name ??= githubContext.payload.release?.name || options.version;
|
options.name ??= githubContext.payload.release?.name || options.version;
|
||||||
|
|
Loading…
Reference in a new issue