mirror of
https://github.com/CringeStudios/element-desktop.git
synced 2025-01-19 07:54:59 +01:00
Backport more build config to master
This commit is contained in:
parent
38ccd77b81
commit
201000da39
@ -7,6 +7,9 @@
|
|||||||
* On Windows:
|
* On Windows:
|
||||||
* Prefixes the nightly version with `0.0.1-nightly.` as it breaks if it is not semver
|
* Prefixes the nightly version with `0.0.1-nightly.` as it breaks if it is not semver
|
||||||
*
|
*
|
||||||
|
* On macOS:
|
||||||
|
* Passes --notarytool-team-id to build.mac.notarize.notarize if specified and removes build.mac.afterSign
|
||||||
|
*
|
||||||
* On Linux:
|
* On Linux:
|
||||||
* Replaces spaces in the product name with dashes as spaces in paths can cause issues
|
* Replaces spaces in the product name with dashes as spaces in paths can cause issues
|
||||||
* Passes --deb-custom-control to build.deb.fpm if specified
|
* Passes --deb-custom-control to build.deb.fpm if specified
|
||||||
@ -15,6 +18,7 @@
|
|||||||
import parseArgs from "minimist";
|
import parseArgs from "minimist";
|
||||||
import fsProm from "fs/promises";
|
import fsProm from "fs/promises";
|
||||||
import * as os from "os";
|
import * as os from "os";
|
||||||
|
import { Configuration } from "app-builder-lib";
|
||||||
|
|
||||||
const ELECTRON_BUILDER_CFG_FILE = "electron-builder.json";
|
const ELECTRON_BUILDER_CFG_FILE = "electron-builder.json";
|
||||||
|
|
||||||
@ -25,54 +29,23 @@ const argv = parseArgs<{
|
|||||||
"nightly"?: string;
|
"nightly"?: string;
|
||||||
"signtool-thumbprint"?: string;
|
"signtool-thumbprint"?: string;
|
||||||
"signtool-subject-name"?: string;
|
"signtool-subject-name"?: string;
|
||||||
|
"notarytool-team-id"?: string;
|
||||||
"deb-custom-control"?: string;
|
"deb-custom-control"?: string;
|
||||||
|
"deb-changelog"?: string;
|
||||||
}>(process.argv.slice(2), {
|
}>(process.argv.slice(2), {
|
||||||
string: ["nightly", "deb-custom-control", "signtool-thumbprint", "signtool-subject-name"],
|
string: [
|
||||||
|
"nightly",
|
||||||
|
"deb-custom-control",
|
||||||
|
"deb-changelog",
|
||||||
|
"signtool-thumbprint",
|
||||||
|
"signtool-subject-name",
|
||||||
|
"notarytool-team-id",
|
||||||
|
],
|
||||||
});
|
});
|
||||||
|
|
||||||
interface File {
|
type DeepWriteable<T> = { -readonly [P in keyof T]: DeepWriteable<T[P]> };
|
||||||
from: string;
|
|
||||||
to: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PackageBuild {
|
interface PackageBuild extends DeepWriteable<Omit<Configuration, "extraMetadata">> {
|
||||||
appId: string;
|
|
||||||
asarUnpack: string;
|
|
||||||
files: Array<string | File>;
|
|
||||||
extraResources: Array<string | File>;
|
|
||||||
linux: {
|
|
||||||
target: string;
|
|
||||||
category: string;
|
|
||||||
maintainer: string;
|
|
||||||
desktop: {
|
|
||||||
StartupWMClass: string;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
mac: {
|
|
||||||
category: string;
|
|
||||||
darkModeSupport: boolean;
|
|
||||||
};
|
|
||||||
win: {
|
|
||||||
target: {
|
|
||||||
target: string;
|
|
||||||
};
|
|
||||||
sign?: string;
|
|
||||||
signingHashAlgorithms?: string[];
|
|
||||||
certificateSubjectName?: string;
|
|
||||||
certificateSha1?: string;
|
|
||||||
};
|
|
||||||
deb?: {
|
|
||||||
fpm?: string[];
|
|
||||||
};
|
|
||||||
directories: {
|
|
||||||
output: string;
|
|
||||||
};
|
|
||||||
afterPack: string;
|
|
||||||
afterSign: string;
|
|
||||||
protocols: Array<{
|
|
||||||
name: string;
|
|
||||||
schemes: string[];
|
|
||||||
}>;
|
|
||||||
extraMetadata?: {
|
extraMetadata?: {
|
||||||
productName?: string;
|
productName?: string;
|
||||||
name?: string;
|
name?: string;
|
||||||
@ -114,10 +87,17 @@ async function main(): Promise<number | void> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (argv["signtool-thumbprint"] && argv["signtool-subject-name"]) {
|
if (argv["signtool-thumbprint"] && argv["signtool-subject-name"]) {
|
||||||
delete cfg.win.sign;
|
delete cfg.win!.sign;
|
||||||
cfg.win.signingHashAlgorithms = ["sha256"];
|
cfg.win!.signingHashAlgorithms = ["sha256"];
|
||||||
cfg.win.certificateSubjectName = argv["signtool-subject-name"];
|
cfg.win!.certificateSubjectName = argv["signtool-subject-name"];
|
||||||
cfg.win.certificateSha1 = argv["signtool-thumbprint"];
|
cfg.win!.certificateSha1 = argv["signtool-thumbprint"];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (argv["notarytool-team-id"]) {
|
||||||
|
delete cfg.afterSign;
|
||||||
|
cfg.mac!.notarize = {
|
||||||
|
teamId: argv["notarytool-team-id"],
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (os.platform() === "linux") {
|
if (os.platform() === "linux") {
|
||||||
@ -125,10 +105,15 @@ async function main(): Promise<number | void> {
|
|||||||
// https://github.com/vector-im/element-web/issues/13171
|
// https://github.com/vector-im/element-web/issues/13171
|
||||||
cfg.extraMetadata!.productName = cfg.extraMetadata!.productName!.replace(/ /g, "-");
|
cfg.extraMetadata!.productName = cfg.extraMetadata!.productName!.replace(/ /g, "-");
|
||||||
|
|
||||||
|
cfg.deb = {
|
||||||
|
fpm: [],
|
||||||
|
};
|
||||||
|
|
||||||
if (argv["deb-custom-control"]) {
|
if (argv["deb-custom-control"]) {
|
||||||
cfg.deb = {
|
cfg.deb.fpm!.push(`--deb-custom-control=${argv["deb-custom-control"]}`);
|
||||||
fpm: [`--deb-custom-control=${argv["deb-custom-control"]}`],
|
}
|
||||||
};
|
if (argv["deb-changelog"]) {
|
||||||
|
cfg.deb.fpm!.push(`--deb-changelog=${argv["deb-changelog"]}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user