mirror of
https://github.com/bitwarden/browser
synced 2025-12-11 13:53:34 +00:00
Cleanup destkop native loader and support gnu fallback loading (#12498)
This commit is contained in:
@@ -1,209 +1,132 @@
|
|||||||
const { existsSync, readFileSync } = require('fs')
|
const { existsSync } = require("fs");
|
||||||
const { join } = require('path')
|
const { join } = require("path");
|
||||||
|
|
||||||
const { platform, arch } = process
|
const { platform, arch } = process;
|
||||||
|
|
||||||
let nativeBinding = null
|
let nativeBinding = null;
|
||||||
let localFileExisted = false
|
let localFileExisted = false;
|
||||||
let loadError = null
|
let loadError = null;
|
||||||
|
|
||||||
function isMusl() {
|
function loadFirstAvailable(localFiles, nodeModule) {
|
||||||
// For Node 10
|
for (const localFile of localFiles) {
|
||||||
if (!process.report || typeof process.report.getReport !== 'function') {
|
if (existsSync(join(__dirname, localFile))) {
|
||||||
try {
|
return require(`./${localFile}`);
|
||||||
return readFileSync('/usr/bin/ldd', 'utf8').includes('musl')
|
|
||||||
} catch (e) {
|
|
||||||
return true
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
const { glibcVersionRuntime } = process.report.getReport().header
|
|
||||||
return !glibcVersionRuntime
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
require(nodeModule);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (platform) {
|
switch (platform) {
|
||||||
case 'android':
|
case "android":
|
||||||
switch (arch) {
|
switch (arch) {
|
||||||
case 'arm64':
|
case "arm64":
|
||||||
localFileExisted = existsSync(join(__dirname, 'desktop_napi.android-arm64.node'))
|
nativeBinding = loadFirstAvailable(
|
||||||
try {
|
["desktop_napi.android-arm64.node"],
|
||||||
if (localFileExisted) {
|
"@bitwarden/desktop-napi-android-arm64",
|
||||||
nativeBinding = require('./desktop_napi.android-arm64.node')
|
);
|
||||||
} else {
|
break;
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-android-arm64')
|
case "arm":
|
||||||
}
|
nativeBinding = loadFirstAvailable(
|
||||||
} catch (e) {
|
["desktop_napi.android-arm.node"],
|
||||||
loadError = e
|
"@bitwarden/desktop-napi-android-arm",
|
||||||
}
|
);
|
||||||
break
|
break;
|
||||||
case 'arm':
|
|
||||||
localFileExisted = existsSync(join(__dirname, 'desktop_napi.android-arm-eabi.node'))
|
|
||||||
try {
|
|
||||||
if (localFileExisted) {
|
|
||||||
nativeBinding = require('./desktop_napi.android-arm-eabi.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-android-arm-eabi')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
default:
|
default:
|
||||||
throw new Error(`Unsupported architecture on Android ${arch}`)
|
throw new Error(`Unsupported architecture on Android ${arch}`);
|
||||||
}
|
}
|
||||||
break
|
break;
|
||||||
case 'win32':
|
case "win32":
|
||||||
switch (arch) {
|
switch (arch) {
|
||||||
case 'x64':
|
case "x64":
|
||||||
localFileExisted = existsSync(
|
nativeBinding = loadFirstAvailable(
|
||||||
join(__dirname, 'desktop_napi.win32-x64-msvc.node')
|
["desktop_napi.win32-x64-msvc.node"],
|
||||||
)
|
"@bitwarden/desktop-napi-win32-x64-msvc",
|
||||||
try {
|
);
|
||||||
if (localFileExisted) {
|
break;
|
||||||
nativeBinding = require('./desktop_napi.win32-x64-msvc.node')
|
case "ia32":
|
||||||
} else {
|
nativeBinding = loadFirstAvailable(
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-win32-x64-msvc')
|
["desktop_napi.win32-ia32-msvc.node"],
|
||||||
}
|
"@bitwarden/desktop-napi-win32-ia32-msvc",
|
||||||
} catch (e) {
|
);
|
||||||
loadError = e
|
break;
|
||||||
}
|
case "arm64":
|
||||||
break
|
nativeBinding = loadFirstAvailable(
|
||||||
case 'ia32':
|
["desktop_napi.win32-arm64-msvc.node"],
|
||||||
localFileExisted = existsSync(
|
"@bitwarden/desktop-napi-win32-arm64-msvc",
|
||||||
join(__dirname, 'desktop_napi.win32-ia32-msvc.node')
|
);
|
||||||
)
|
break;
|
||||||
try {
|
|
||||||
if (localFileExisted) {
|
|
||||||
nativeBinding = require('./desktop_napi.win32-ia32-msvc.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-win32-ia32-msvc')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
case 'arm64':
|
|
||||||
localFileExisted = existsSync(
|
|
||||||
join(__dirname, 'desktop_napi.win32-arm64-msvc.node')
|
|
||||||
)
|
|
||||||
try {
|
|
||||||
if (localFileExisted) {
|
|
||||||
nativeBinding = require('./desktop_napi.win32-arm64-msvc.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-win32-arm64-msvc')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
default:
|
default:
|
||||||
throw new Error(`Unsupported architecture on Windows: ${arch}`)
|
throw new Error(`Unsupported architecture on Windows: ${arch}`);
|
||||||
}
|
}
|
||||||
break
|
break;
|
||||||
case 'darwin':
|
case "darwin":
|
||||||
switch (arch) {
|
switch (arch) {
|
||||||
case 'x64':
|
case "x64":
|
||||||
localFileExisted = existsSync(join(__dirname, 'desktop_napi.darwin-x64.node'))
|
nativeBinding = loadFirstAvailable(
|
||||||
try {
|
["desktop_napi.darwin-x64.node"],
|
||||||
if (localFileExisted) {
|
"@bitwarden/desktop-napi-darwin-x64",
|
||||||
nativeBinding = require('./desktop_napi.darwin-x64.node')
|
);
|
||||||
} else {
|
break;
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-darwin-x64')
|
case "arm64":
|
||||||
}
|
nativeBinding = loadFirstAvailable(
|
||||||
} catch (e) {
|
["desktop_napi.darwin-arm64.node"],
|
||||||
loadError = e
|
"@bitwarden/desktop-napi-darwin-arm64",
|
||||||
}
|
);
|
||||||
break
|
break;
|
||||||
case 'arm64':
|
|
||||||
localFileExisted = existsSync(
|
|
||||||
join(__dirname, 'desktop_napi.darwin-arm64.node')
|
|
||||||
)
|
|
||||||
try {
|
|
||||||
if (localFileExisted) {
|
|
||||||
nativeBinding = require('./desktop_napi.darwin-arm64.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-darwin-arm64')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
default:
|
default:
|
||||||
throw new Error(`Unsupported architecture on macOS: ${arch}`)
|
throw new Error(`Unsupported architecture on macOS: ${arch}`);
|
||||||
}
|
}
|
||||||
break
|
break;
|
||||||
case 'freebsd':
|
case "freebsd":
|
||||||
if (arch !== 'x64') {
|
nativeBinding = loadFirstAvailable(
|
||||||
throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
|
["desktop_napi.freebsd-x64.node"],
|
||||||
}
|
"@bitwarden/desktop-napi-freebsd-x64",
|
||||||
localFileExisted = existsSync(join(__dirname, 'desktop_napi.freebsd-x64.node'))
|
);
|
||||||
try {
|
break;
|
||||||
if (localFileExisted) {
|
case "linux":
|
||||||
nativeBinding = require('./desktop_napi.freebsd-x64.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-freebsd-x64')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
case 'linux':
|
|
||||||
switch (arch) {
|
switch (arch) {
|
||||||
case 'x64':
|
case "x64":
|
||||||
localFileExisted = existsSync(
|
nativeBinding = loadFirstAvailable(
|
||||||
join(__dirname, 'desktop_napi.linux-x64-musl.node')
|
["desktop_napi.linux-x64-musl.node", "desktop_napi.linux-x64-gnu.node"],
|
||||||
)
|
"@bitwarden/desktop-napi-linux-x64-musl",
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
case "arm64":
|
||||||
|
nativeBinding = loadFirstAvailable(
|
||||||
|
["desktop_napi.linux-arm64-musl.node", "desktop_napi.linux-arm64-gnu.node"],
|
||||||
|
"@bitwarden/desktop-napi-linux-arm64-musl",
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
case "arm":
|
||||||
|
nativeBinding = loadFirstAvailable(
|
||||||
|
["desktop_napi.linux-arm-musl.node", "desktop_napi.linux-arm-gnu.node"],
|
||||||
|
"@bitwarden/desktop-napi-linux-arm-musl",
|
||||||
|
);
|
||||||
|
localFileExisted = existsSync(join(__dirname, "desktop_napi.linux-arm-gnueabihf.node"));
|
||||||
try {
|
try {
|
||||||
if (localFileExisted) {
|
if (localFileExisted) {
|
||||||
nativeBinding = require('./desktop_napi.linux-x64-musl.node')
|
nativeBinding = require("./desktop_napi.linux-arm-gnueabihf.node");
|
||||||
} else {
|
} else {
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-linux-x64-musl')
|
nativeBinding = require("@bitwarden/desktop-napi-linux-arm-gnueabihf");
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
loadError = e
|
loadError = e;
|
||||||
}
|
}
|
||||||
break
|
break;
|
||||||
case 'arm64':
|
|
||||||
localFileExisted = existsSync(
|
|
||||||
join(__dirname, 'desktop_napi.linux-arm64-musl.node')
|
|
||||||
)
|
|
||||||
try {
|
|
||||||
if (localFileExisted) {
|
|
||||||
nativeBinding = require('./desktop_napi.linux-arm64-musl.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-linux-arm64-musl')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
case 'arm':
|
|
||||||
localFileExisted = existsSync(
|
|
||||||
join(__dirname, 'desktop_napi.linux-arm-gnueabihf.node')
|
|
||||||
)
|
|
||||||
try {
|
|
||||||
if (localFileExisted) {
|
|
||||||
nativeBinding = require('./desktop_napi.linux-arm-gnueabihf.node')
|
|
||||||
} else {
|
|
||||||
nativeBinding = require('@bitwarden/desktop-napi-linux-arm-gnueabihf')
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
loadError = e
|
|
||||||
}
|
|
||||||
break
|
|
||||||
default:
|
default:
|
||||||
throw new Error(`Unsupported architecture on Linux: ${arch}`)
|
throw new Error(`Unsupported architecture on Linux: ${arch}`);
|
||||||
}
|
}
|
||||||
break
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
|
throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!nativeBinding) {
|
if (!nativeBinding) {
|
||||||
if (loadError) {
|
if (loadError) {
|
||||||
throw loadError
|
throw loadError;
|
||||||
}
|
}
|
||||||
throw new Error(`Failed to load native binding`)
|
throw new Error(`Failed to load native binding`);
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = nativeBinding
|
module.exports = nativeBinding;
|
||||||
|
|||||||
Reference in New Issue
Block a user