mirror of
https://git.sanhost.net/sanasol/hytale-f2p.git
synced 2026-02-26 06:41:47 -03:00
Changes: - Add 30 minute timeout for notarization (fail fast) - Add SKIP_NOTARIZE=true env var to skip notarization entirely - Don't fail build if notarization fails (app still code-signed) - Add NOTARIZE_FAIL_ON_ERROR=true to fail build on notarization error - Add forceCodeSigning, strictVerify, type=distribution to mac config - Disable electron-builder built-in notarize (using custom script) This prevents CI from hanging forever waiting for Apple's notarization service and reduces wasted GitHub Actions minutes. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
93 lines
2.8 KiB
JavaScript
93 lines
2.8 KiB
JavaScript
console.log('[Notarize] Script loaded');
|
|
|
|
let notarize;
|
|
try {
|
|
notarize = require('@electron/notarize').notarize;
|
|
console.log('[Notarize] @electron/notarize loaded successfully');
|
|
} catch (err) {
|
|
console.error('[Notarize] Failed to load @electron/notarize:', err.message);
|
|
throw err;
|
|
}
|
|
|
|
const path = require('path');
|
|
|
|
// Timeout for notarization (30 minutes max)
|
|
const NOTARIZE_TIMEOUT_MS = 30 * 60 * 1000;
|
|
|
|
function withTimeout(promise, ms, message) {
|
|
return Promise.race([
|
|
promise,
|
|
new Promise((_, reject) =>
|
|
setTimeout(() => reject(new Error(message)), ms)
|
|
)
|
|
]);
|
|
}
|
|
|
|
exports.default = async function notarizing(context) {
|
|
console.log('[Notarize] afterSign hook called');
|
|
console.log('[Notarize] Context:', JSON.stringify({
|
|
platform: context.electronPlatformName,
|
|
appOutDir: context.appOutDir,
|
|
outDir: context.outDir
|
|
}, null, 2));
|
|
|
|
const { electronPlatformName, appOutDir } = context;
|
|
|
|
// Only notarize macOS builds
|
|
if (electronPlatformName !== 'darwin') {
|
|
console.log('[Notarize] Skipping: not macOS');
|
|
return;
|
|
}
|
|
|
|
// Check if notarization is disabled via env var
|
|
if (process.env.SKIP_NOTARIZE === 'true') {
|
|
console.log('[Notarize] Skipping: SKIP_NOTARIZE=true');
|
|
return;
|
|
}
|
|
|
|
// Check credentials
|
|
const hasAppleId = !!process.env.APPLE_ID;
|
|
const hasPassword = !!process.env.APPLE_APP_SPECIFIC_PASSWORD;
|
|
const hasTeamId = !!process.env.APPLE_TEAM_ID;
|
|
|
|
console.log('[Notarize] Credentials check:', { hasAppleId, hasPassword, hasTeamId });
|
|
|
|
if (!hasAppleId || !hasPassword || !hasTeamId) {
|
|
console.log('[Notarize] Skipping: missing credentials');
|
|
return;
|
|
}
|
|
|
|
const appName = context.packager.appInfo.productFilename;
|
|
const appPath = path.join(appOutDir, `${appName}.app`);
|
|
|
|
console.log('[Notarize] Starting notarization...');
|
|
console.log('[Notarize] App path:', appPath);
|
|
console.log('[Notarize] Team ID:', process.env.APPLE_TEAM_ID);
|
|
console.log('[Notarize] Timeout:', NOTARIZE_TIMEOUT_MS / 1000, 'seconds');
|
|
|
|
try {
|
|
await withTimeout(
|
|
notarize({
|
|
appPath,
|
|
appleId: process.env.APPLE_ID,
|
|
appleIdPassword: process.env.APPLE_APP_SPECIFIC_PASSWORD,
|
|
teamId: process.env.APPLE_TEAM_ID,
|
|
}),
|
|
NOTARIZE_TIMEOUT_MS,
|
|
`Notarization timed out after ${NOTARIZE_TIMEOUT_MS / 1000} seconds`
|
|
);
|
|
console.log('[Notarize] Notarization complete!');
|
|
} catch (error) {
|
|
console.error('[Notarize] Notarization failed:', error.message);
|
|
|
|
// Don't fail the build if notarization times out or fails
|
|
// The app will still be code-signed, just not notarized
|
|
if (process.env.NOTARIZE_FAIL_ON_ERROR !== 'true') {
|
|
console.warn('[Notarize] Continuing build without notarization (set NOTARIZE_FAIL_ON_ERROR=true to fail)');
|
|
return;
|
|
}
|
|
|
|
throw error;
|
|
}
|
|
};
|