mirror of
https://github.com/bitwarden/desktop.git
synced 2025-01-13 19:41:32 +01:00
Ensure safari extension is included in mas and not only darwin (#1128)
* Ensure safari extension is included in mas and not only darwin * Add support for re-signing mas * Add support for mas-dev
This commit is contained in:
parent
59bed9b12e
commit
05470b489c
@ -2,6 +2,7 @@ require('dotenv').config();
|
||||
const path = require('path');
|
||||
const fse = require('fs-extra');
|
||||
const { notarize } = require('electron-notarize');
|
||||
const { deepAssign } = require('builder-util');
|
||||
|
||||
exports.default = run;
|
||||
|
||||
@ -12,18 +13,33 @@ async function run(context) {
|
||||
const appName = context.packager.appInfo.productFilename;
|
||||
const appPath = `${context.appOutDir}/${appName}.app`;
|
||||
const macBuild = context.electronPlatformName === 'darwin';
|
||||
const copyPlugIn = ['darwin', 'mas'].includes(context.electronPlatformName);
|
||||
|
||||
if (macBuild) {
|
||||
if (copyPlugIn) {
|
||||
// Copy Safari plugin to work-around https://github.com/electron-userland/electron-builder/issues/5552
|
||||
const plugIn = path.join(__dirname, '../PlugIns');
|
||||
if (fse.existsSync(plugIn)) {
|
||||
fse.mkdirSync(path.join(appPath, 'Contents/PlugIns'));
|
||||
fse.copySync(path.join(plugIn, 'safari.appex'), path.join(appPath, 'Contents/PlugIns/safari.appex'));
|
||||
|
||||
// Resign to sign safari extension
|
||||
await context.packager.signApp(context, true);
|
||||
}
|
||||
|
||||
// Resign to sign safari extension
|
||||
if (context.electronPlatformName === 'mas') {
|
||||
const masBuildOptions = deepAssign({}, context.packager.platformSpecificBuildOptions, context.packager.config.mas);
|
||||
if (context.targets.some(e => e.name === 'mas-dev')) {
|
||||
deepAssign(masBuildOptions, {
|
||||
type: 'development',
|
||||
});
|
||||
}
|
||||
if (context.packager.packagerOptions.prepackaged == null) {
|
||||
await context.packager.sign(appPath, context.appOutDir, masBuildOptions, context.arch);
|
||||
}
|
||||
} else {
|
||||
await context.packager.signApp(context, true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (macBuild) {
|
||||
console.log('### Notarizing ' + appPath);
|
||||
const appleId = process.env.APPLE_ID_USERNAME || process.env.APPLEID;
|
||||
const appleIdPassword = process.env.APPLE_ID_PASSWORD || `@keychain:AC_PASSWORD`;
|
||||
|
Loading…
Reference in New Issue
Block a user