@chainsafe/libp2p-quic
Version:
A QUIC transport for libp2p
429 lines • 13.3 kB
JavaScript
// prettier-ignore
/* eslint-disable */
// @ts-nocheck
/* auto-generated by NAPI-RS */
var __rewriteRelativeImportExtension = (this && this.__rewriteRelativeImportExtension) || function (path, preserveJsx) {
if (typeof path === "string" && /^\.\.?\//.test(path)) {
return path.replace(/\.(tsx)$|((?:\.d)?)((?:\.[^./]+?)?)\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {
return tsx ? preserveJsx ? ".jsx" : ".js" : d && (!ext || !cm) ? m : (d + ext + "." + cm.toLowerCase() + "js");
});
}
return path;
};
import { createRequire } from 'node:module';
const require = createRequire(import.meta.url);
const __dirname = new URL('.', import.meta.url).pathname;
const { readFileSync } = require('node:fs');
let nativeBinding = null;
const loadErrors = [];
const isMusl = () => {
let musl = false;
if (process.platform === 'linux') {
musl = isMuslFromFilesystem();
if (musl === null) {
musl = isMuslFromReport();
}
if (musl === null) {
musl = isMuslFromChildProcess();
}
}
return musl;
};
const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-');
const isMuslFromFilesystem = () => {
try {
return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl');
}
catch {
return null;
}
};
const isMuslFromReport = () => {
const report = typeof process.report.getReport === 'function' ? process.report.getReport() : null;
if (!report) {
return null;
}
if (report.header && report.header.glibcVersionRuntime) {
return false;
}
if (Array.isArray(report.sharedObjects)) {
if (report.sharedObjects.some(isFileMusl)) {
return true;
}
}
return false;
};
const isMuslFromChildProcess = () => {
try {
return require('child_process').execSync('ldd --version', { encoding: 'utf8' }).includes('musl');
}
catch (e) {
// If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false
return false;
}
};
function requireNative() {
if (process.env.NAPI_RS_NATIVE_LIBRARY_PATH) {
try {
nativeBinding = require(__rewriteRelativeImportExtension(process.env.NAPI_RS_NATIVE_LIBRARY_PATH));
}
catch (err) {
loadErrors.push(err);
}
}
else if (process.platform === 'android') {
if (process.arch === 'arm64') {
try {
return require('./libp2p-quic.android-arm64.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-android-arm64');
}
catch (e) {
loadErrors.push(e);
}
}
else if (process.arch === 'arm') {
try {
return require('./libp2p-quic.android-arm-eabi.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-android-arm-eabi');
}
catch (e) {
loadErrors.push(e);
}
}
else {
loadErrors.push(new Error(`Unsupported architecture on Android ${process.arch}`));
}
}
else if (process.platform === 'win32') {
if (process.arch === 'x64') {
try {
return require('./libp2p-quic.win32-x64-msvc.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-win32-x64-msvc');
}
catch (e) {
loadErrors.push(e);
}
}
else if (process.arch === 'ia32') {
try {
return require('./libp2p-quic.win32-ia32-msvc.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-win32-ia32-msvc');
}
catch (e) {
loadErrors.push(e);
}
}
else if (process.arch === 'arm64') {
try {
return require('./libp2p-quic.win32-arm64-msvc.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-win32-arm64-msvc');
}
catch (e) {
loadErrors.push(e);
}
}
else {
loadErrors.push(new Error(`Unsupported architecture on Windows: ${process.arch}`));
}
}
else if (process.platform === 'darwin') {
try {
return require('./libp2p-quic.darwin-universal.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-darwin-universal');
}
catch (e) {
loadErrors.push(e);
}
if (process.arch === 'x64') {
try {
return require('./libp2p-quic.darwin-x64.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-darwin-x64');
}
catch (e) {
loadErrors.push(e);
}
}
else if (process.arch === 'arm64') {
try {
return require('./libp2p-quic.darwin-arm64.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-darwin-arm64');
}
catch (e) {
loadErrors.push(e);
}
}
else {
loadErrors.push(new Error(`Unsupported architecture on macOS: ${process.arch}`));
}
}
else if (process.platform === 'freebsd') {
if (process.arch === 'x64') {
try {
return require('./libp2p-quic.freebsd-x64.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-freebsd-x64');
}
catch (e) {
loadErrors.push(e);
}
}
else if (process.arch === 'arm64') {
try {
return require('./libp2p-quic.freebsd-arm64.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-freebsd-arm64');
}
catch (e) {
loadErrors.push(e);
}
}
else {
loadErrors.push(new Error(`Unsupported architecture on FreeBSD: ${process.arch}`));
}
}
else if (process.platform === 'linux') {
if (process.arch === 'x64') {
if (isMusl()) {
try {
return require('./libp2p-quic.linux-x64-musl.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-x64-musl');
}
catch (e) {
loadErrors.push(e);
}
}
else {
try {
return require('./libp2p-quic.linux-x64-gnu.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-x64-gnu');
}
catch (e) {
loadErrors.push(e);
}
}
}
else if (process.arch === 'arm64') {
if (isMusl()) {
try {
return require('./libp2p-quic.linux-arm64-musl.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-arm64-musl');
}
catch (e) {
loadErrors.push(e);
}
}
else {
try {
return require('./libp2p-quic.linux-arm64-gnu.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-arm64-gnu');
}
catch (e) {
loadErrors.push(e);
}
}
}
else if (process.arch === 'arm') {
if (isMusl()) {
try {
return require('./libp2p-quic.linux-arm-musleabihf.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-arm-musleabihf');
}
catch (e) {
loadErrors.push(e);
}
}
else {
try {
return require('./libp2p-quic.linux-arm-gnueabihf.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-arm-gnueabihf');
}
catch (e) {
loadErrors.push(e);
}
}
}
else if (process.arch === 'riscv64') {
if (isMusl()) {
try {
return require('./libp2p-quic.linux-riscv64-musl.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-riscv64-musl');
}
catch (e) {
loadErrors.push(e);
}
}
else {
try {
return require('./libp2p-quic.linux-riscv64-gnu.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-riscv64-gnu');
}
catch (e) {
loadErrors.push(e);
}
}
}
else if (process.arch === 'ppc64') {
try {
return require('./libp2p-quic.linux-ppc64-gnu.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-ppc64-gnu');
}
catch (e) {
loadErrors.push(e);
}
}
else if (process.arch === 's390x') {
try {
return require('./libp2p-quic.linux-s390x-gnu.node');
}
catch (e) {
loadErrors.push(e);
}
try {
return require('@chainsafe/libp2p-quic-linux-s390x-gnu');
}
catch (e) {
loadErrors.push(e);
}
}
else {
loadErrors.push(new Error(`Unsupported architecture on Linux: ${process.arch}`));
}
}
else {
loadErrors.push(new Error(`Unsupported OS: ${process.platform}, architecture: ${process.arch}`));
}
}
nativeBinding = requireNative();
if (!nativeBinding || process.env.NAPI_RS_FORCE_WASI) {
try {
nativeBinding = require('./libp2p-quic.wasi.cjs');
}
catch (err) {
if (process.env.NAPI_RS_FORCE_WASI) {
loadErrors.push(err);
}
}
if (!nativeBinding) {
try {
nativeBinding = require('@chainsafe/libp2p-quic-wasm32-wasi');
}
catch (err) {
if (process.env.NAPI_RS_FORCE_WASI) {
loadErrors.push(err);
}
}
}
}
if (!nativeBinding) {
if (loadErrors.length > 0) {
// TODO Link to documentation with potential fixes
// - The package owner could build/publish bindings for this arch
// - The user may need to bundle the correct files
// - The user may need to re-install node_modules to get new packages
throw new Error('Failed to load native binding', { cause: loadErrors });
}
throw new Error(`Failed to load native binding`);
}
const { Client, Connection, ConnectionStats, EndpointStats, QuinnConfig, Server, Stream, SocketFamily } = nativeBinding;
export { Client };
export { Connection };
export { ConnectionStats };
export { EndpointStats };
export { QuinnConfig };
export { Server };
export { Stream };
export { SocketFamily };
//# sourceMappingURL=napi.js.map