@mainsail/evm 0.0.1-evm.5 → 0.0.1-evm.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/index.d.ts +265 -60
  2. package/index.js +523 -256
  3. package/package.json +20 -24
package/index.d.ts CHANGED
@@ -1,101 +1,306 @@
1
- /* tslint:disable */
1
+ /* auto-generated by NAPI-RS */
2
2
  /* eslint-disable */
3
+ export declare class Evm {
4
+ constructor(opts: JsEvmOptions)
5
+ preverifyTransaction(txCtx: JsPreverifyTransactionContext): Promise<JsPreverifyTransactionResult>
6
+ view(viewCtx: JsTransactionViewContext): Promise<JsViewResult>
7
+ process(txCtx: JsTransactionContext): Promise<JsProcessResult>
8
+ simulate(txCtx: JsTransactionSimulateContext): Promise<JsSimulateResult>
9
+ initializeGenesis(genesisCtx: JsGenesisContext): Promise<undefined>
10
+ prepareNextCommit(ctx: JsPrepareNextCommitContext): Promise<undefined>
11
+ calculateRoundValidators(ctx: JsCalculateRoundValidatorsContext): Promise<undefined>
12
+ updateRewardsAndVotes(ctx: JsUpdateRewardsAndVotesContext): Promise<undefined>
13
+ getAccountInfo(address: string, blockNumber?: bigint | undefined | null): Promise<JsAccountInfo>
14
+ getAccountInfoExtended(address: string, legacyAddress?: string | undefined | null): Promise<JsAccountInfoExtended>
15
+ importAccountInfos(infos: Array<JsAccountInfoExtended>): Promise<undefined>
16
+ importLegacyColdWallets(infos: Array<JsLegacyColdWallet>): Promise<undefined>
17
+ getAccounts(offset: bigint, limit: bigint): Promise<JsGetAccounts>
18
+ getLegacyAttributes(address: string, legacyAddress?: string | undefined | null): Promise<JsLegacyAttributes | undefined | null>
19
+ getLegacyColdWallets(offset: bigint, limit: bigint): Promise<JsGetLegacyColdWallets>
20
+ getReceipts(offset: bigint, limit: bigint): Promise<JsGetReceipts>
21
+ getReceiptsByBlockNumber(blockNumber: bigint): Promise<Record<string, JsTransactionReceipt>>
22
+ getReceipt(blockNumber: bigint, txHash: string): Promise<JsGetReceipt>
23
+ codeAt(address: string, blockNumber?: bigint | undefined | null): Promise<string>
24
+ storageAt(address: string, slot: bigint): Promise<string>
25
+ commit(commitKey: JsCommitKey, commitData?: JsCommitData | undefined | null): Promise<JsCommitResult>
26
+ stateRoot(commitKey: JsCommitKey, currentHash: string): Promise<string>
27
+ logsBloom(commitKey: JsCommitKey): Promise<string>
28
+ isEmpty(): Promise<boolean>
29
+ getState(): Promise<JsGetState>
30
+ getBlockHeaderData(blockNumber: bigint): Promise<JsBlockHeaderData | undefined | null>
31
+ getBlockNumberByHash(blockHash: string): Promise<bigint | undefined | null>
32
+ getCommitData(blockNumber: bigint): Promise<JsCommitData | undefined | null>
33
+ getTransactionData(key: string): Promise<JsTransactionData | undefined | null>
34
+ getTransactionKeyByHash(txHash: string): Promise<string | undefined | null>
35
+ snapshot(commitKey: JsCommitKey): Promise<undefined>
36
+ rollback(commitKey: JsCommitKey): Promise<undefined>
37
+ dispose(): Promise<undefined>
38
+ }
39
+ export type JsEvmWrapper = Evm
3
40
 
4
- /* auto-generated by NAPI-RS */
41
+ export interface JsAccountInfo {
42
+ balance: bigint
43
+ nonce: bigint
44
+ }
5
45
 
6
- export interface JsTransactionContext {
7
- caller: string
8
- /** Omit recipient when deploying a contract */
9
- recipient?: string
10
- gasLimit: bigint
11
- gasPrice?: bigint
12
- value: bigint
46
+ export interface JsAccountInfoExtended {
47
+ address: string
48
+ balance: bigint
13
49
  nonce: bigint
14
- data: Buffer
50
+ legacyAttributes: JsLegacyAttributes
51
+ }
52
+
53
+ export interface JsAccountMergeInfo {
54
+ address: string
15
55
  txHash: string
16
- blockContext: JsBlockContext
17
- specId: string
18
56
  }
19
- export interface JsTransactionViewContext {
20
- caller: string
21
- recipient: string
22
- data: Buffer
23
- specId: string
57
+
58
+ export interface JsAccountUpdate {
59
+ address: string
60
+ balance: bigint
61
+ nonce: bigint
62
+ vote?: string
63
+ unvote?: string
64
+ username?: string
65
+ usernameResigned: boolean
66
+ legacyMergeInfo?: JsAccountMergeInfo
24
67
  }
68
+
25
69
  export interface JsBlockContext {
26
70
  commitKey: JsCommitKey
27
71
  gasLimit: bigint
28
72
  timestamp: bigint
29
73
  validatorAddress: string
30
74
  }
31
- export interface JsGenesisContext {
32
- account: string
33
- deployerAccount: string
34
- validatorContract: string
35
- initialSupply: bigint
36
- }
37
- export interface JsCalculateTopValidatorsContext {
38
- commitKey: JsCommitKey
75
+
76
+ export interface JsBlockHeaderData {
77
+ version: number
39
78
  timestamp: bigint
40
- activeValidators: bigint
41
- validatorAddress: string
42
- specId: string
79
+ number: number
80
+ round: number
81
+ hash: string
82
+ parentHash: string
83
+ stateRoot: string
84
+ logsBloom: string
85
+ transactionsRoot: string
86
+ transactionsCount: number
87
+ gasUsed: number
88
+ fee: bigint
89
+ reward: bigint
90
+ payloadSize: number
91
+ proposer: string
43
92
  }
44
- export interface JsUpdateRewardsAndVotesContext {
93
+
94
+ export interface JsCalculateRoundValidatorsContext {
45
95
  commitKey: JsCommitKey
46
96
  timestamp: bigint
47
- blockReward: bigint
97
+ roundValidators: bigint
48
98
  validatorAddress: string
49
99
  specId: string
50
100
  }
101
+
102
+ export interface JsCommitData {
103
+ proof: JsProofData
104
+ header: JsBlockHeaderData
105
+ transactions: Array<JsTransactionData>
106
+ }
107
+
51
108
  export interface JsCommitKey {
52
- height: bigint
109
+ blockNumber: bigint
53
110
  round: bigint
111
+ blockHash?: string
112
+ }
113
+
114
+ export interface JsCommitResult {
115
+ dirtyAccounts: Array<JsAccountUpdate>
116
+ }
117
+
118
+ export interface JsEvmOptions {
119
+ path: string
120
+ logger?: (arg: JsLogMessage) => void
121
+ historySize?: bigint
122
+ }
123
+
124
+ export interface JsGenesisContext {
125
+ account: string
126
+ deployerAccount: string
127
+ validatorContract: string
128
+ usernameContract: string
129
+ initialBlockNumber: bigint
130
+ initialSupply: bigint
131
+ }
132
+
133
+ export interface JsGetAccounts {
134
+ nextOffset?: bigint
135
+ accounts: Array<JsAccountInfoExtended>
136
+ }
137
+
138
+ export interface JsGetLegacyColdWallets {
139
+ nextOffset?: bigint
140
+ wallets: Array<JsLegacyColdWallet>
141
+ }
142
+
143
+ export interface JsGetReceipt {
144
+ receipt?: JsTransactionReceipt
145
+ }
146
+
147
+ export interface JsGetReceipts {
148
+ nextOffset?: bigint
149
+ receipts: Array<JsTransactionReceipt>
150
+ }
151
+
152
+ export interface JsGetState {
153
+ blockNumber: bigint
154
+ totalRound: bigint
155
+ }
156
+
157
+ export interface JsLegacyAttributes {
158
+ legacyNonce?: bigint
159
+ secondPublicKey?: string
160
+ multiSignature?: JsLegacyMultiSignatureAttribute
161
+ }
162
+
163
+ export interface JsLegacyColdWallet {
164
+ address: string
165
+ balance: bigint
166
+ legacyAttributes: JsLegacyAttributes
167
+ mergeInfo?: JsAccountMergeInfo
168
+ }
169
+
170
+ export interface JsLegacyMultiSignatureAttribute {
171
+ min: number
172
+ publicKeys: Array<string>
54
173
  }
174
+
175
+ export interface JsLogMessage {
176
+ level: LogLevel
177
+ message: string
178
+ }
179
+
55
180
  export interface JsPrepareNextCommitContext {
56
181
  commitKey: JsCommitKey
57
182
  }
183
+
184
+ export interface JsPreverifyTransactionContext {
185
+ from: string
186
+ legacyAddress?: string
187
+ /** Omit recipient when deploying a contract */
188
+ to?: string
189
+ gasLimit: bigint
190
+ gasPrice: bigint
191
+ value: bigint
192
+ nonce: bigint
193
+ data: Buffer
194
+ txHash: string
195
+ specId: string
196
+ blockGasLimit: bigint
197
+ }
198
+
199
+ export interface JsPreverifyTransactionResult {
200
+ success: boolean
201
+ initialGasUsed: bigint
202
+ error?: string
203
+ }
204
+
58
205
  export interface JsProcessResult {
59
206
  receipt: JsTransactionReceipt
60
207
  }
61
- export interface JsCommitResult {
62
- dirtyAccounts: Array<JsAccountUpdate>
208
+
209
+ export interface JsProofData {
210
+ round: number
211
+ signature: string
212
+ validatorSet: bigint
63
213
  }
64
- export interface JsViewResult {
65
- success: boolean
66
- output?: Buffer
214
+
215
+ export interface JsSimulateResult {
216
+ receipt: JsTransactionReceipt
217
+ }
218
+
219
+ export interface JsTransactionContext {
220
+ from: string
221
+ legacyAddress?: string
222
+ /** Omit recipient when deploying a contract */
223
+ to?: string
224
+ gasLimit: bigint
225
+ gasPrice: bigint
226
+ value: bigint
227
+ nonce: bigint
228
+ data: Buffer
229
+ txHash: string
230
+ index?: number
231
+ blockContext: JsBlockContext
232
+ specId: string
233
+ }
234
+
235
+ export interface JsTransactionData {
236
+ from: string
237
+ senderPublicKey: string
238
+ legacyAddress?: string
239
+ to?: string
240
+ gasLimit: bigint
241
+ gasPrice: bigint
242
+ value: bigint
243
+ nonce: bigint
244
+ data: Buffer
245
+ v: number
246
+ r: string
247
+ s: string
248
+ legacySecondSignature?: string
249
+ txHash: string
250
+ blockNumber: number
251
+ index: number
67
252
  }
253
+
68
254
  export interface JsTransactionReceipt {
255
+ blockNumber?: bigint
256
+ txHash?: string
69
257
  gasUsed: bigint
258
+ cumulativeGasUsed: bigint
70
259
  gasRefunded: bigint
71
- success: boolean
72
- deployedContractAddress?: string
260
+ status: number
261
+ contractAddress?: string
73
262
  logs: any
74
263
  output?: Buffer
75
264
  }
76
- export interface JsAccountInfo {
77
- balance: bigint
265
+
266
+ export interface JsTransactionSimulateContext {
267
+ from: string
268
+ /** Omit recipient when deploying a contract */
269
+ to?: string
270
+ gasLimit: bigint
271
+ gasPrice: bigint
272
+ value: bigint
78
273
  nonce: bigint
274
+ data: Buffer
275
+ blockContext: JsBlockContext
276
+ specId: string
79
277
  }
80
- export interface JsAccountUpdate {
81
- address: string
82
- balance: bigint
83
- nonce: bigint
84
- vote?: string
85
- unvote?: string
278
+
279
+ export interface JsTransactionViewContext {
280
+ from: string
281
+ to: string
282
+ data: Buffer
283
+ specId: string
284
+ gasLimit?: bigint
86
285
  }
87
- export type JsEvmWrapper = Evm
88
- export declare class Evm {
89
- constructor(path: string)
90
- view(viewCtx: JsTransactionViewContext): Promise<JsViewResult>
91
- process(txCtx: JsTransactionContext): Promise<JsProcessResult>
92
- initializeGenesis(genesisCtx: JsGenesisContext): Promise<void>
93
- prepareNextCommit(ctx: JsPrepareNextCommitContext): Promise<void>
94
- calculateTopValidators(ctx: JsCalculateTopValidatorsContext): Promise<void>
95
- updateRewardsAndVotes(ctx: JsUpdateRewardsAndVotesContext): Promise<void>
96
- getAccountInfo(address: string): Promise<JsAccountInfo>
97
- codeAt(address: string): Promise<string>
98
- storageAt(address: string, slot: bigint): Promise<string>
99
- commit(commitKey: JsCommitKey): Promise<JsCommitResult>
100
- stateHash(commitKey: JsCommitKey, currentHash: string): Promise<string>
286
+
287
+ export interface JsUpdateRewardsAndVotesContext {
288
+ commitKey: JsCommitKey
289
+ timestamp: bigint
290
+ blockReward: bigint
291
+ validatorAddress: string
292
+ specId: string
293
+ }
294
+
295
+ export interface JsViewResult {
296
+ success: boolean
297
+ output?: Buffer
298
+ }
299
+
300
+ export declare const enum LogLevel {
301
+ Info = 0,
302
+ Debug = 1,
303
+ Notice = 2,
304
+ Alert = 3,
305
+ Warn = 4
101
306
  }
package/index.js CHANGED
@@ -1,315 +1,582 @@
1
- /* tslint:disable */
1
+ // prettier-ignore
2
2
  /* eslint-disable */
3
- /* prettier-ignore */
4
-
3
+ // @ts-nocheck
5
4
  /* auto-generated by NAPI-RS */
6
5
 
7
- const { existsSync, readFileSync } = require('fs')
8
- const { join } = require('path')
6
+ const { readFileSync } = require('node:fs')
7
+ let nativeBinding = null
8
+ const loadErrors = []
9
9
 
10
- const { platform, arch } = process
10
+ const isMusl = () => {
11
+ let musl = false
12
+ if (process.platform === 'linux') {
13
+ musl = isMuslFromFilesystem()
14
+ if (musl === null) {
15
+ musl = isMuslFromReport()
16
+ }
17
+ if (musl === null) {
18
+ musl = isMuslFromChildProcess()
19
+ }
20
+ }
21
+ return musl
22
+ }
11
23
 
12
- let nativeBinding = null
13
- let localFileExisted = false
14
- let loadError = null
24
+ const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-')
15
25
 
16
- function isMusl() {
17
- // For Node 10
18
- if (!process.report || typeof process.report.getReport !== 'function') {
19
- try {
20
- const lddPath = require('child_process').execSync('which ldd').toString().trim()
21
- return readFileSync(lddPath, 'utf8').includes('musl')
22
- } catch (e) {
26
+ const isMuslFromFilesystem = () => {
27
+ try {
28
+ return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl')
29
+ } catch {
30
+ return null
31
+ }
32
+ }
33
+
34
+ const isMuslFromReport = () => {
35
+ let report = null
36
+ if (typeof process.report?.getReport === 'function') {
37
+ process.report.excludeNetwork = true
38
+ report = process.report.getReport()
39
+ }
40
+ if (!report) {
41
+ return null
42
+ }
43
+ if (report.header && report.header.glibcVersionRuntime) {
44
+ return false
45
+ }
46
+ if (Array.isArray(report.sharedObjects)) {
47
+ if (report.sharedObjects.some(isFileMusl)) {
23
48
  return true
24
49
  }
25
- } else {
26
- const { glibcVersionRuntime } = process.report.getReport().header
27
- return !glibcVersionRuntime
28
50
  }
51
+ return false
29
52
  }
30
53
 
31
- switch (platform) {
32
- case 'android':
33
- switch (arch) {
34
- case 'arm64':
35
- localFileExisted = existsSync(join(__dirname, 'evm.android-arm64.node'))
54
+ const isMuslFromChildProcess = () => {
55
+ try {
56
+ return require('child_process').execSync('ldd --version', { encoding: 'utf8' }).includes('musl')
57
+ } catch (e) {
58
+ // If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false
59
+ return false
60
+ }
61
+ }
62
+
63
+ function requireNative() {
64
+ if (process.env.NAPI_RS_NATIVE_LIBRARY_PATH) {
65
+ try {
66
+ return require(process.env.NAPI_RS_NATIVE_LIBRARY_PATH);
67
+ } catch (err) {
68
+ loadErrors.push(err)
69
+ }
70
+ } else if (process.platform === 'android') {
71
+ if (process.arch === 'arm64') {
72
+ try {
73
+ return require('./evm.android-arm64.node')
74
+ } catch (e) {
75
+ loadErrors.push(e)
76
+ }
77
+ try {
78
+ const binding = require('@mainsail/evm-android-arm64')
79
+ const bindingPackageVersion = require('@mainsail/evm-android-arm64/package.json').version
80
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
81
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
82
+ }
83
+ return binding
84
+ } catch (e) {
85
+ loadErrors.push(e)
86
+ }
87
+ } else if (process.arch === 'arm') {
88
+ try {
89
+ return require('./evm.android-arm-eabi.node')
90
+ } catch (e) {
91
+ loadErrors.push(e)
92
+ }
93
+ try {
94
+ const binding = require('@mainsail/evm-android-arm-eabi')
95
+ const bindingPackageVersion = require('@mainsail/evm-android-arm-eabi/package.json').version
96
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
97
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
98
+ }
99
+ return binding
100
+ } catch (e) {
101
+ loadErrors.push(e)
102
+ }
103
+ } else {
104
+ loadErrors.push(new Error(`Unsupported architecture on Android ${process.arch}`))
105
+ }
106
+ } else if (process.platform === 'win32') {
107
+ if (process.arch === 'x64') {
108
+ if (process.config?.variables?.shlib_suffix === 'dll.a' || process.config?.variables?.node_target_type === 'shared_library') {
36
109
  try {
37
- if (localFileExisted) {
38
- nativeBinding = require('./evm.android-arm64.node')
39
- } else {
40
- nativeBinding = require('@mainsail/evm-android-arm64')
41
- }
110
+ return require('./evm.win32-x64-gnu.node')
111
+ } catch (e) {
112
+ loadErrors.push(e)
113
+ }
114
+ try {
115
+ const binding = require('@mainsail/evm-win32-x64-gnu')
116
+ const bindingPackageVersion = require('@mainsail/evm-win32-x64-gnu/package.json').version
117
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
118
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
119
+ }
120
+ return binding
121
+ } catch (e) {
122
+ loadErrors.push(e)
123
+ }
124
+ } else {
125
+ try {
126
+ return require('./evm.win32-x64-msvc.node')
127
+ } catch (e) {
128
+ loadErrors.push(e)
129
+ }
130
+ try {
131
+ const binding = require('@mainsail/evm-win32-x64-msvc')
132
+ const bindingPackageVersion = require('@mainsail/evm-win32-x64-msvc/package.json').version
133
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
134
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
135
+ }
136
+ return binding
137
+ } catch (e) {
138
+ loadErrors.push(e)
139
+ }
140
+ }
141
+ } else if (process.arch === 'ia32') {
142
+ try {
143
+ return require('./evm.win32-ia32-msvc.node')
144
+ } catch (e) {
145
+ loadErrors.push(e)
146
+ }
147
+ try {
148
+ const binding = require('@mainsail/evm-win32-ia32-msvc')
149
+ const bindingPackageVersion = require('@mainsail/evm-win32-ia32-msvc/package.json').version
150
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
151
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
152
+ }
153
+ return binding
154
+ } catch (e) {
155
+ loadErrors.push(e)
156
+ }
157
+ } else if (process.arch === 'arm64') {
158
+ try {
159
+ return require('./evm.win32-arm64-msvc.node')
160
+ } catch (e) {
161
+ loadErrors.push(e)
162
+ }
163
+ try {
164
+ const binding = require('@mainsail/evm-win32-arm64-msvc')
165
+ const bindingPackageVersion = require('@mainsail/evm-win32-arm64-msvc/package.json').version
166
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
167
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
168
+ }
169
+ return binding
170
+ } catch (e) {
171
+ loadErrors.push(e)
172
+ }
173
+ } else {
174
+ loadErrors.push(new Error(`Unsupported architecture on Windows: ${process.arch}`))
175
+ }
176
+ } else if (process.platform === 'darwin') {
177
+ try {
178
+ return require('./evm.darwin-universal.node')
179
+ } catch (e) {
180
+ loadErrors.push(e)
181
+ }
182
+ try {
183
+ const binding = require('@mainsail/evm-darwin-universal')
184
+ const bindingPackageVersion = require('@mainsail/evm-darwin-universal/package.json').version
185
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
186
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
187
+ }
188
+ return binding
189
+ } catch (e) {
190
+ loadErrors.push(e)
191
+ }
192
+ if (process.arch === 'x64') {
193
+ try {
194
+ return require('./evm.darwin-x64.node')
195
+ } catch (e) {
196
+ loadErrors.push(e)
197
+ }
198
+ try {
199
+ const binding = require('@mainsail/evm-darwin-x64')
200
+ const bindingPackageVersion = require('@mainsail/evm-darwin-x64/package.json').version
201
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
202
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
203
+ }
204
+ return binding
205
+ } catch (e) {
206
+ loadErrors.push(e)
207
+ }
208
+ } else if (process.arch === 'arm64') {
209
+ try {
210
+ return require('./evm.darwin-arm64.node')
211
+ } catch (e) {
212
+ loadErrors.push(e)
213
+ }
214
+ try {
215
+ const binding = require('@mainsail/evm-darwin-arm64')
216
+ const bindingPackageVersion = require('@mainsail/evm-darwin-arm64/package.json').version
217
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
218
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
219
+ }
220
+ return binding
221
+ } catch (e) {
222
+ loadErrors.push(e)
223
+ }
224
+ } else {
225
+ loadErrors.push(new Error(`Unsupported architecture on macOS: ${process.arch}`))
226
+ }
227
+ } else if (process.platform === 'freebsd') {
228
+ if (process.arch === 'x64') {
229
+ try {
230
+ return require('./evm.freebsd-x64.node')
231
+ } catch (e) {
232
+ loadErrors.push(e)
233
+ }
234
+ try {
235
+ const binding = require('@mainsail/evm-freebsd-x64')
236
+ const bindingPackageVersion = require('@mainsail/evm-freebsd-x64/package.json').version
237
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
238
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
239
+ }
240
+ return binding
241
+ } catch (e) {
242
+ loadErrors.push(e)
243
+ }
244
+ } else if (process.arch === 'arm64') {
245
+ try {
246
+ return require('./evm.freebsd-arm64.node')
247
+ } catch (e) {
248
+ loadErrors.push(e)
249
+ }
250
+ try {
251
+ const binding = require('@mainsail/evm-freebsd-arm64')
252
+ const bindingPackageVersion = require('@mainsail/evm-freebsd-arm64/package.json').version
253
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
254
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
255
+ }
256
+ return binding
257
+ } catch (e) {
258
+ loadErrors.push(e)
259
+ }
260
+ } else {
261
+ loadErrors.push(new Error(`Unsupported architecture on FreeBSD: ${process.arch}`))
262
+ }
263
+ } else if (process.platform === 'linux') {
264
+ if (process.arch === 'x64') {
265
+ if (isMusl()) {
266
+ try {
267
+ return require('./evm.linux-x64-musl.node')
42
268
  } catch (e) {
43
- loadError = e
269
+ loadErrors.push(e)
44
270
  }
45
- break
46
- case 'arm':
47
- localFileExisted = existsSync(join(__dirname, 'evm.android-arm-eabi.node'))
48
271
  try {
49
- if (localFileExisted) {
50
- nativeBinding = require('./evm.android-arm-eabi.node')
51
- } else {
52
- nativeBinding = require('@mainsail/evm-android-arm-eabi')
272
+ const binding = require('@mainsail/evm-linux-x64-musl')
273
+ const bindingPackageVersion = require('@mainsail/evm-linux-x64-musl/package.json').version
274
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
275
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
53
276
  }
277
+ return binding
54
278
  } catch (e) {
55
- loadError = e
279
+ loadErrors.push(e)
56
280
  }
57
- break
58
- default:
59
- throw new Error(`Unsupported architecture on Android ${arch}`)
60
- }
61
- break
62
- case 'win32':
63
- switch (arch) {
64
- case 'x64':
65
- localFileExisted = existsSync(
66
- join(__dirname, 'evm.win32-x64-msvc.node')
67
- )
281
+ } else {
68
282
  try {
69
- if (localFileExisted) {
70
- nativeBinding = require('./evm.win32-x64-msvc.node')
71
- } else {
72
- nativeBinding = require('@mainsail/evm-win32-x64-msvc')
73
- }
283
+ return require('./evm.linux-x64-gnu.node')
74
284
  } catch (e) {
75
- loadError = e
285
+ loadErrors.push(e)
76
286
  }
77
- break
78
- case 'ia32':
79
- localFileExisted = existsSync(
80
- join(__dirname, 'evm.win32-ia32-msvc.node')
81
- )
82
287
  try {
83
- if (localFileExisted) {
84
- nativeBinding = require('./evm.win32-ia32-msvc.node')
85
- } else {
86
- nativeBinding = require('@mainsail/evm-win32-ia32-msvc')
288
+ const binding = require('@mainsail/evm-linux-x64-gnu')
289
+ const bindingPackageVersion = require('@mainsail/evm-linux-x64-gnu/package.json').version
290
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
291
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
87
292
  }
293
+ return binding
88
294
  } catch (e) {
89
- loadError = e
295
+ loadErrors.push(e)
90
296
  }
91
- break
92
- case 'arm64':
93
- localFileExisted = existsSync(
94
- join(__dirname, 'evm.win32-arm64-msvc.node')
95
- )
297
+ }
298
+ } else if (process.arch === 'arm64') {
299
+ if (isMusl()) {
96
300
  try {
97
- if (localFileExisted) {
98
- nativeBinding = require('./evm.win32-arm64-msvc.node')
99
- } else {
100
- nativeBinding = require('@mainsail/evm-win32-arm64-msvc')
301
+ return require('./evm.linux-arm64-musl.node')
302
+ } catch (e) {
303
+ loadErrors.push(e)
304
+ }
305
+ try {
306
+ const binding = require('@mainsail/evm-linux-arm64-musl')
307
+ const bindingPackageVersion = require('@mainsail/evm-linux-arm64-musl/package.json').version
308
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
309
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
101
310
  }
311
+ return binding
102
312
  } catch (e) {
103
- loadError = e
313
+ loadErrors.push(e)
104
314
  }
105
- break
106
- default:
107
- throw new Error(`Unsupported architecture on Windows: ${arch}`)
108
- }
109
- break
110
- case 'darwin':
111
- localFileExisted = existsSync(join(__dirname, 'evm.darwin-universal.node'))
112
- try {
113
- if (localFileExisted) {
114
- nativeBinding = require('./evm.darwin-universal.node')
115
315
  } else {
116
- nativeBinding = require('@mainsail/evm-darwin-universal')
117
- }
118
- break
119
- } catch {}
120
- switch (arch) {
121
- case 'x64':
122
- localFileExisted = existsSync(join(__dirname, 'evm.darwin-x64.node'))
123
316
  try {
124
- if (localFileExisted) {
125
- nativeBinding = require('./evm.darwin-x64.node')
126
- } else {
127
- nativeBinding = require('@mainsail/evm-darwin-x64')
128
- }
317
+ return require('./evm.linux-arm64-gnu.node')
129
318
  } catch (e) {
130
- loadError = e
319
+ loadErrors.push(e)
131
320
  }
132
- break
133
- case 'arm64':
134
- localFileExisted = existsSync(
135
- join(__dirname, 'evm.darwin-arm64.node')
136
- )
137
321
  try {
138
- if (localFileExisted) {
139
- nativeBinding = require('./evm.darwin-arm64.node')
140
- } else {
141
- nativeBinding = require('@mainsail/evm-darwin-arm64')
322
+ const binding = require('@mainsail/evm-linux-arm64-gnu')
323
+ const bindingPackageVersion = require('@mainsail/evm-linux-arm64-gnu/package.json').version
324
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
325
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
142
326
  }
327
+ return binding
143
328
  } catch (e) {
144
- loadError = e
329
+ loadErrors.push(e)
145
330
  }
146
- break
147
- default:
148
- throw new Error(`Unsupported architecture on macOS: ${arch}`)
149
- }
150
- break
151
- case 'freebsd':
152
- if (arch !== 'x64') {
153
- throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
154
- }
155
- localFileExisted = existsSync(join(__dirname, 'evm.freebsd-x64.node'))
156
- try {
157
- if (localFileExisted) {
158
- nativeBinding = require('./evm.freebsd-x64.node')
159
- } else {
160
- nativeBinding = require('@mainsail/evm-freebsd-x64')
161
331
  }
162
- } catch (e) {
163
- loadError = e
164
- }
165
- break
166
- case 'linux':
167
- switch (arch) {
168
- case 'x64':
169
- if (isMusl()) {
170
- localFileExisted = existsSync(
171
- join(__dirname, 'evm.linux-x64-musl.node')
172
- )
173
- try {
174
- if (localFileExisted) {
175
- nativeBinding = require('./evm.linux-x64-musl.node')
176
- } else {
177
- nativeBinding = require('@mainsail/evm-linux-x64-musl')
178
- }
179
- } catch (e) {
180
- loadError = e
181
- }
182
- } else {
183
- localFileExisted = existsSync(
184
- join(__dirname, 'evm.linux-x64-gnu.node')
185
- )
186
- try {
187
- if (localFileExisted) {
188
- nativeBinding = require('./evm.linux-x64-gnu.node')
189
- } else {
190
- nativeBinding = require('@mainsail/evm-linux-x64-gnu')
191
- }
192
- } catch (e) {
193
- loadError = e
194
- }
332
+ } else if (process.arch === 'arm') {
333
+ if (isMusl()) {
334
+ try {
335
+ return require('./evm.linux-arm-musleabihf.node')
336
+ } catch (e) {
337
+ loadErrors.push(e)
195
338
  }
196
- break
197
- case 'arm64':
198
- if (isMusl()) {
199
- localFileExisted = existsSync(
200
- join(__dirname, 'evm.linux-arm64-musl.node')
201
- )
202
- try {
203
- if (localFileExisted) {
204
- nativeBinding = require('./evm.linux-arm64-musl.node')
205
- } else {
206
- nativeBinding = require('@mainsail/evm-linux-arm64-musl')
207
- }
208
- } catch (e) {
209
- loadError = e
210
- }
211
- } else {
212
- localFileExisted = existsSync(
213
- join(__dirname, 'evm.linux-arm64-gnu.node')
214
- )
215
- try {
216
- if (localFileExisted) {
217
- nativeBinding = require('./evm.linux-arm64-gnu.node')
218
- } else {
219
- nativeBinding = require('@mainsail/evm-linux-arm64-gnu')
220
- }
221
- } catch (e) {
222
- loadError = e
339
+ try {
340
+ const binding = require('@mainsail/evm-linux-arm-musleabihf')
341
+ const bindingPackageVersion = require('@mainsail/evm-linux-arm-musleabihf/package.json').version
342
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
343
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
223
344
  }
345
+ return binding
346
+ } catch (e) {
347
+ loadErrors.push(e)
348
+ }
349
+ } else {
350
+ try {
351
+ return require('./evm.linux-arm-gnueabihf.node')
352
+ } catch (e) {
353
+ loadErrors.push(e)
224
354
  }
225
- break
226
- case 'arm':
227
- if (isMusl()) {
228
- localFileExisted = existsSync(
229
- join(__dirname, 'evm.linux-arm-musleabihf.node')
230
- )
231
- try {
232
- if (localFileExisted) {
233
- nativeBinding = require('./evm.linux-arm-musleabihf.node')
234
- } else {
235
- nativeBinding = require('@mainsail/evm-linux-arm-musleabihf')
236
- }
237
- } catch (e) {
238
- loadError = e
355
+ try {
356
+ const binding = require('@mainsail/evm-linux-arm-gnueabihf')
357
+ const bindingPackageVersion = require('@mainsail/evm-linux-arm-gnueabihf/package.json').version
358
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
359
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
239
360
  }
240
- } else {
241
- localFileExisted = existsSync(
242
- join(__dirname, 'evm.linux-arm-gnueabihf.node')
243
- )
244
- try {
245
- if (localFileExisted) {
246
- nativeBinding = require('./evm.linux-arm-gnueabihf.node')
247
- } else {
248
- nativeBinding = require('@mainsail/evm-linux-arm-gnueabihf')
249
- }
250
- } catch (e) {
251
- loadError = e
361
+ return binding
362
+ } catch (e) {
363
+ loadErrors.push(e)
364
+ }
365
+ }
366
+ } else if (process.arch === 'loong64') {
367
+ if (isMusl()) {
368
+ try {
369
+ return require('./evm.linux-loong64-musl.node')
370
+ } catch (e) {
371
+ loadErrors.push(e)
372
+ }
373
+ try {
374
+ const binding = require('@mainsail/evm-linux-loong64-musl')
375
+ const bindingPackageVersion = require('@mainsail/evm-linux-loong64-musl/package.json').version
376
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
377
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
252
378
  }
379
+ return binding
380
+ } catch (e) {
381
+ loadErrors.push(e)
253
382
  }
254
- break
255
- case 'riscv64':
256
- if (isMusl()) {
257
- localFileExisted = existsSync(
258
- join(__dirname, 'evm.linux-riscv64-musl.node')
259
- )
260
- try {
261
- if (localFileExisted) {
262
- nativeBinding = require('./evm.linux-riscv64-musl.node')
263
- } else {
264
- nativeBinding = require('@mainsail/evm-linux-riscv64-musl')
265
- }
266
- } catch (e) {
267
- loadError = e
383
+ } else {
384
+ try {
385
+ return require('./evm.linux-loong64-gnu.node')
386
+ } catch (e) {
387
+ loadErrors.push(e)
388
+ }
389
+ try {
390
+ const binding = require('@mainsail/evm-linux-loong64-gnu')
391
+ const bindingPackageVersion = require('@mainsail/evm-linux-loong64-gnu/package.json').version
392
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
393
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
268
394
  }
269
- } else {
270
- localFileExisted = existsSync(
271
- join(__dirname, 'evm.linux-riscv64-gnu.node')
272
- )
273
- try {
274
- if (localFileExisted) {
275
- nativeBinding = require('./evm.linux-riscv64-gnu.node')
276
- } else {
277
- nativeBinding = require('@mainsail/evm-linux-riscv64-gnu')
278
- }
279
- } catch (e) {
280
- loadError = e
395
+ return binding
396
+ } catch (e) {
397
+ loadErrors.push(e)
398
+ }
399
+ }
400
+ } else if (process.arch === 'riscv64') {
401
+ if (isMusl()) {
402
+ try {
403
+ return require('./evm.linux-riscv64-musl.node')
404
+ } catch (e) {
405
+ loadErrors.push(e)
406
+ }
407
+ try {
408
+ const binding = require('@mainsail/evm-linux-riscv64-musl')
409
+ const bindingPackageVersion = require('@mainsail/evm-linux-riscv64-musl/package.json').version
410
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
411
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
281
412
  }
413
+ return binding
414
+ } catch (e) {
415
+ loadErrors.push(e)
416
+ }
417
+ } else {
418
+ try {
419
+ return require('./evm.linux-riscv64-gnu.node')
420
+ } catch (e) {
421
+ loadErrors.push(e)
282
422
  }
283
- break
284
- case 's390x':
285
- localFileExisted = existsSync(
286
- join(__dirname, 'evm.linux-s390x-gnu.node')
287
- )
288
423
  try {
289
- if (localFileExisted) {
290
- nativeBinding = require('./evm.linux-s390x-gnu.node')
291
- } else {
292
- nativeBinding = require('@mainsail/evm-linux-s390x-gnu')
424
+ const binding = require('@mainsail/evm-linux-riscv64-gnu')
425
+ const bindingPackageVersion = require('@mainsail/evm-linux-riscv64-gnu/package.json').version
426
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
427
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
293
428
  }
429
+ return binding
294
430
  } catch (e) {
295
- loadError = e
431
+ loadErrors.push(e)
432
+ }
433
+ }
434
+ } else if (process.arch === 'ppc64') {
435
+ try {
436
+ return require('./evm.linux-ppc64-gnu.node')
437
+ } catch (e) {
438
+ loadErrors.push(e)
439
+ }
440
+ try {
441
+ const binding = require('@mainsail/evm-linux-ppc64-gnu')
442
+ const bindingPackageVersion = require('@mainsail/evm-linux-ppc64-gnu/package.json').version
443
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
444
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
296
445
  }
297
- break
298
- default:
299
- throw new Error(`Unsupported architecture on Linux: ${arch}`)
446
+ return binding
447
+ } catch (e) {
448
+ loadErrors.push(e)
449
+ }
450
+ } else if (process.arch === 's390x') {
451
+ try {
452
+ return require('./evm.linux-s390x-gnu.node')
453
+ } catch (e) {
454
+ loadErrors.push(e)
455
+ }
456
+ try {
457
+ const binding = require('@mainsail/evm-linux-s390x-gnu')
458
+ const bindingPackageVersion = require('@mainsail/evm-linux-s390x-gnu/package.json').version
459
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
460
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
461
+ }
462
+ return binding
463
+ } catch (e) {
464
+ loadErrors.push(e)
465
+ }
466
+ } else {
467
+ loadErrors.push(new Error(`Unsupported architecture on Linux: ${process.arch}`))
300
468
  }
301
- break
302
- default:
303
- throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
469
+ } else if (process.platform === 'openharmony') {
470
+ if (process.arch === 'arm64') {
471
+ try {
472
+ return require('./evm.openharmony-arm64.node')
473
+ } catch (e) {
474
+ loadErrors.push(e)
475
+ }
476
+ try {
477
+ const binding = require('@mainsail/evm-openharmony-arm64')
478
+ const bindingPackageVersion = require('@mainsail/evm-openharmony-arm64/package.json').version
479
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
480
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
481
+ }
482
+ return binding
483
+ } catch (e) {
484
+ loadErrors.push(e)
485
+ }
486
+ } else if (process.arch === 'x64') {
487
+ try {
488
+ return require('./evm.openharmony-x64.node')
489
+ } catch (e) {
490
+ loadErrors.push(e)
491
+ }
492
+ try {
493
+ const binding = require('@mainsail/evm-openharmony-x64')
494
+ const bindingPackageVersion = require('@mainsail/evm-openharmony-x64/package.json').version
495
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
496
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
497
+ }
498
+ return binding
499
+ } catch (e) {
500
+ loadErrors.push(e)
501
+ }
502
+ } else if (process.arch === 'arm') {
503
+ try {
504
+ return require('./evm.openharmony-arm.node')
505
+ } catch (e) {
506
+ loadErrors.push(e)
507
+ }
508
+ try {
509
+ const binding = require('@mainsail/evm-openharmony-arm')
510
+ const bindingPackageVersion = require('@mainsail/evm-openharmony-arm/package.json').version
511
+ if (bindingPackageVersion !== '0.0.1-evm.50' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
512
+ throw new Error(`Native binding package version mismatch, expected 0.0.1-evm.50 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
513
+ }
514
+ return binding
515
+ } catch (e) {
516
+ loadErrors.push(e)
517
+ }
518
+ } else {
519
+ loadErrors.push(new Error(`Unsupported architecture on OpenHarmony: ${process.arch}`))
520
+ }
521
+ } else {
522
+ loadErrors.push(new Error(`Unsupported OS: ${process.platform}, architecture: ${process.arch}`))
523
+ }
524
+ }
525
+
526
+ nativeBinding = requireNative()
527
+
528
+ if (!nativeBinding || process.env.NAPI_RS_FORCE_WASI) {
529
+ let wasiBinding = null
530
+ let wasiBindingError = null
531
+ try {
532
+ wasiBinding = require('./evm.wasi.cjs')
533
+ nativeBinding = wasiBinding
534
+ } catch (err) {
535
+ if (process.env.NAPI_RS_FORCE_WASI) {
536
+ wasiBindingError = err
537
+ }
538
+ }
539
+ if (!nativeBinding || process.env.NAPI_RS_FORCE_WASI) {
540
+ try {
541
+ wasiBinding = require('@mainsail/evm-wasm32-wasi')
542
+ nativeBinding = wasiBinding
543
+ } catch (err) {
544
+ if (process.env.NAPI_RS_FORCE_WASI) {
545
+ if (!wasiBindingError) {
546
+ wasiBindingError = err
547
+ } else {
548
+ wasiBindingError.cause = err
549
+ }
550
+ loadErrors.push(err)
551
+ }
552
+ }
553
+ }
554
+ if (process.env.NAPI_RS_FORCE_WASI === 'error' && !wasiBinding) {
555
+ const error = new Error('WASI binding not found and NAPI_RS_FORCE_WASI is set to error')
556
+ error.cause = wasiBindingError
557
+ throw error
558
+ }
304
559
  }
305
560
 
306
561
  if (!nativeBinding) {
307
- if (loadError) {
308
- throw loadError
562
+ if (loadErrors.length > 0) {
563
+ throw new Error(
564
+ `Cannot find native binding. ` +
565
+ `npm has a bug related to optional dependencies (https://github.com/npm/cli/issues/4828). ` +
566
+ 'Please try `npm i` again after removing both package-lock.json and node_modules directory.',
567
+ {
568
+ cause: loadErrors.reduce((err, cur) => {
569
+ cur.cause = err
570
+ return cur
571
+ }),
572
+ },
573
+ )
309
574
  }
310
575
  throw new Error(`Failed to load native binding`)
311
576
  }
312
577
 
313
- const { Evm } = nativeBinding
314
-
315
- module.exports.Evm = Evm
578
+ module.exports = nativeBinding
579
+ module.exports.Evm = nativeBinding.Evm
580
+ module.exports.JsEvmWrapper = nativeBinding.JsEvmWrapper
581
+ module.exports.LogLevel = nativeBinding.LogLevel
582
+ module.exports.JsLogLevel = nativeBinding.JsLogLevel
package/package.json CHANGED
@@ -1,43 +1,39 @@
1
1
  {
2
2
  "name": "@mainsail/evm",
3
- "version": "0.0.1-evm.5",
3
+ "version": "0.0.1-evm.50",
4
4
  "description": "EVM for the Mainsail blockchain",
5
5
  "license": "GPL-3.0-only",
6
6
  "contributors": [],
7
7
  "main": "index.js",
8
8
  "types": "index.d.ts",
9
9
  "devDependencies": {
10
- "@napi-rs/cli": "^2.18.4"
10
+ "@napi-rs/cli": "3.6.2"
11
+ },
12
+ "optionalDependencies": {
13
+ "@mainsail/evm-linux-arm64-gnu": "0.0.1-evm.50",
14
+ "@mainsail/evm-linux-x64-gnu": "0.0.1-evm.50"
11
15
  },
12
16
  "engines": {
13
- "node": ">=20.x"
17
+ "node": ">=24"
14
18
  },
15
19
  "napi": {
16
- "name": "evm",
17
- "triples": {
18
- "defaults": false,
19
- "additional": [
20
- "aarch64-unknown-linux-gnu",
21
- "aarch64-unknown-linux-musl",
22
- "x86_64-unknown-linux-gnu",
23
- "x86_64-unknown-linux-musl"
24
- ]
25
- }
26
- },
27
- "optionalDependencies": {
28
- "@mainsail/evm-linux-arm64-gnu": "0.0.1-evm.5",
29
- "@mainsail/evm-linux-arm64-musl": "0.0.1-evm.5",
30
- "@mainsail/evm-linux-x64-gnu": "0.0.1-evm.5",
31
- "@mainsail/evm-linux-x64-musl": "0.0.1-evm.5"
20
+ "binaryName": "evm",
21
+ "targets": [
22
+ "aarch64-unknown-linux-gnu",
23
+ "x86_64-unknown-linux-gnu"
24
+ ]
32
25
  },
33
26
  "scripts": {
34
27
  "artifacts": "napi artifacts",
35
- "build": "pnpm run clean && pnpm run build-napi",
36
- "build-napi": "napi build --platform --cargo-cwd bindings --release",
37
- "build-napi:debug": "napi build --platform --cargo-cwd bindings",
38
- "clean": "del index.js index.d.ts evm.*.node target",
28
+ "build-napi": "napi build --platform --output-dir ./ --manifest-path bindings/Cargo.toml --release",
29
+ "build-napi:debug": "napi build --platform --output-dir ./ --manifest-path bindings/Cargo.toml",
30
+ "build-rs": "pnpm run clean && pnpm run build-napi",
31
+ "clean": "rm -f index.js && rm -f index.d.ts && rm -f evm.*.node && rm -rf target",
39
32
  "release": "pnpm publish --access public",
33
+ "release:prepare": "napi prepublish -t pnpm --skip-optional-publish --no-gh-release",
40
34
  "test": "cargo test --release",
41
- "version": "napi version "
35
+ "test:coverage": "mkdir -p coverage && cargo llvm-cov --lcov --output-path coverage/lcov.info --remap-path-prefix",
36
+ "test:coverage:html": "mkdir -p coverage && cargo llvm-cov --html --output-dir coverage/ --remap-path-prefix",
37
+ "version": "napi version"
42
38
  }
43
39
  }