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

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 +266 -60
  2. package/index.js +523 -256
  3. package/package.json +20 -24
package/index.d.ts CHANGED
@@ -1,101 +1,307 @@
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
+ getCommitsByBlockRange(fromBlockNumber: bigint, toBlockNumber: bigint, maxBytes: bigint): Promise<Array<JsCommitData>>
34
+ getTransactionData(key: string): Promise<JsTransactionData | undefined | null>
35
+ getTransactionKeyByHash(txHash: string): Promise<string | undefined | null>
36
+ snapshot(commitKey: JsCommitKey): Promise<undefined>
37
+ rollback(commitKey: JsCommitKey): Promise<undefined>
38
+ dispose(): Promise<undefined>
39
+ }
40
+ export type JsEvmWrapper = Evm
3
41
 
4
- /* auto-generated by NAPI-RS */
42
+ export interface JsAccountInfo {
43
+ balance: bigint
44
+ nonce: bigint
45
+ }
5
46
 
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
47
+ export interface JsAccountInfoExtended {
48
+ address: string
49
+ balance: bigint
13
50
  nonce: bigint
14
- data: Buffer
51
+ legacyAttributes: JsLegacyAttributes
52
+ }
53
+
54
+ export interface JsAccountMergeInfo {
55
+ address: string
15
56
  txHash: string
16
- blockContext: JsBlockContext
17
- specId: string
18
57
  }
19
- export interface JsTransactionViewContext {
20
- caller: string
21
- recipient: string
22
- data: Buffer
23
- specId: string
58
+
59
+ export interface JsAccountUpdate {
60
+ address: string
61
+ balance: bigint
62
+ nonce: bigint
63
+ vote?: string
64
+ unvote?: string
65
+ username?: string
66
+ usernameResigned: boolean
67
+ legacyMergeInfo?: JsAccountMergeInfo
24
68
  }
69
+
25
70
  export interface JsBlockContext {
26
71
  commitKey: JsCommitKey
27
72
  gasLimit: bigint
28
73
  timestamp: bigint
29
74
  validatorAddress: string
30
75
  }
31
- export interface JsGenesisContext {
32
- account: string
33
- deployerAccount: string
34
- validatorContract: string
35
- initialSupply: bigint
36
- }
37
- export interface JsCalculateTopValidatorsContext {
38
- commitKey: JsCommitKey
76
+
77
+ export interface JsBlockHeaderData {
78
+ version: number
39
79
  timestamp: bigint
40
- activeValidators: bigint
41
- validatorAddress: string
42
- specId: string
80
+ number: number
81
+ round: number
82
+ hash: string
83
+ parentHash: string
84
+ stateRoot: string
85
+ logsBloom: string
86
+ transactionsRoot: string
87
+ transactionsCount: number
88
+ gasUsed: number
89
+ fee: bigint
90
+ reward: bigint
91
+ payloadSize: number
92
+ proposer: string
43
93
  }
44
- export interface JsUpdateRewardsAndVotesContext {
94
+
95
+ export interface JsCalculateRoundValidatorsContext {
45
96
  commitKey: JsCommitKey
46
97
  timestamp: bigint
47
- blockReward: bigint
98
+ roundValidators: bigint
48
99
  validatorAddress: string
49
100
  specId: string
50
101
  }
102
+
103
+ export interface JsCommitData {
104
+ proof: JsProofData
105
+ header: JsBlockHeaderData
106
+ transactions: Array<JsTransactionData>
107
+ }
108
+
51
109
  export interface JsCommitKey {
52
- height: bigint
110
+ blockNumber: bigint
53
111
  round: bigint
112
+ blockHash?: string
113
+ }
114
+
115
+ export interface JsCommitResult {
116
+ dirtyAccounts: Array<JsAccountUpdate>
117
+ }
118
+
119
+ export interface JsEvmOptions {
120
+ path: string
121
+ logger?: (arg: JsLogMessage) => void
122
+ historySize?: bigint
123
+ }
124
+
125
+ export interface JsGenesisContext {
126
+ account: string
127
+ deployerAccount: string
128
+ validatorContract: string
129
+ usernameContract: string
130
+ initialBlockNumber: bigint
131
+ initialSupply: bigint
132
+ }
133
+
134
+ export interface JsGetAccounts {
135
+ nextOffset?: bigint
136
+ accounts: Array<JsAccountInfoExtended>
137
+ }
138
+
139
+ export interface JsGetLegacyColdWallets {
140
+ nextOffset?: bigint
141
+ wallets: Array<JsLegacyColdWallet>
142
+ }
143
+
144
+ export interface JsGetReceipt {
145
+ receipt?: JsTransactionReceipt
146
+ }
147
+
148
+ export interface JsGetReceipts {
149
+ nextOffset?: bigint
150
+ receipts: Array<JsTransactionReceipt>
151
+ }
152
+
153
+ export interface JsGetState {
154
+ blockNumber: bigint
155
+ totalRound: bigint
156
+ }
157
+
158
+ export interface JsLegacyAttributes {
159
+ legacyNonce?: bigint
160
+ secondPublicKey?: string
161
+ multiSignature?: JsLegacyMultiSignatureAttribute
162
+ }
163
+
164
+ export interface JsLegacyColdWallet {
165
+ address: string
166
+ balance: bigint
167
+ legacyAttributes: JsLegacyAttributes
168
+ mergeInfo?: JsAccountMergeInfo
169
+ }
170
+
171
+ export interface JsLegacyMultiSignatureAttribute {
172
+ min: number
173
+ publicKeys: Array<string>
54
174
  }
175
+
176
+ export interface JsLogMessage {
177
+ level: LogLevel
178
+ message: string
179
+ }
180
+
55
181
  export interface JsPrepareNextCommitContext {
56
182
  commitKey: JsCommitKey
57
183
  }
184
+
185
+ export interface JsPreverifyTransactionContext {
186
+ from: string
187
+ legacyAddress?: string
188
+ /** Omit recipient when deploying a contract */
189
+ to?: string
190
+ gasLimit: bigint
191
+ gasPrice: bigint
192
+ value: bigint
193
+ nonce: bigint
194
+ data: Buffer
195
+ txHash: string
196
+ specId: string
197
+ blockGasLimit: bigint
198
+ }
199
+
200
+ export interface JsPreverifyTransactionResult {
201
+ success: boolean
202
+ initialGasUsed: bigint
203
+ error?: string
204
+ }
205
+
58
206
  export interface JsProcessResult {
59
207
  receipt: JsTransactionReceipt
60
208
  }
61
- export interface JsCommitResult {
62
- dirtyAccounts: Array<JsAccountUpdate>
209
+
210
+ export interface JsProofData {
211
+ round: number
212
+ signature: string
213
+ validatorSet: bigint
63
214
  }
64
- export interface JsViewResult {
65
- success: boolean
66
- output?: Buffer
215
+
216
+ export interface JsSimulateResult {
217
+ receipt: JsTransactionReceipt
218
+ }
219
+
220
+ export interface JsTransactionContext {
221
+ from: string
222
+ legacyAddress?: string
223
+ /** Omit recipient when deploying a contract */
224
+ to?: string
225
+ gasLimit: bigint
226
+ gasPrice: bigint
227
+ value: bigint
228
+ nonce: bigint
229
+ data: Buffer
230
+ txHash: string
231
+ index?: number
232
+ blockContext: JsBlockContext
233
+ specId: string
234
+ }
235
+
236
+ export interface JsTransactionData {
237
+ from: string
238
+ senderPublicKey: string
239
+ legacyAddress?: string
240
+ to?: string
241
+ gasLimit: bigint
242
+ gasPrice: bigint
243
+ value: bigint
244
+ nonce: bigint
245
+ data: Buffer
246
+ v: number
247
+ r: string
248
+ s: string
249
+ legacySecondSignature?: string
250
+ txHash: string
251
+ blockNumber: number
252
+ index: number
67
253
  }
254
+
68
255
  export interface JsTransactionReceipt {
256
+ blockNumber?: bigint
257
+ txHash?: string
69
258
  gasUsed: bigint
259
+ cumulativeGasUsed: bigint
70
260
  gasRefunded: bigint
71
- success: boolean
72
- deployedContractAddress?: string
261
+ status: number
262
+ contractAddress?: string
73
263
  logs: any
74
264
  output?: Buffer
75
265
  }
76
- export interface JsAccountInfo {
77
- balance: bigint
266
+
267
+ export interface JsTransactionSimulateContext {
268
+ from: string
269
+ /** Omit recipient when deploying a contract */
270
+ to?: string
271
+ gasLimit: bigint
272
+ gasPrice: bigint
273
+ value: bigint
78
274
  nonce: bigint
275
+ data: Buffer
276
+ blockContext: JsBlockContext
277
+ specId: string
79
278
  }
80
- export interface JsAccountUpdate {
81
- address: string
82
- balance: bigint
83
- nonce: bigint
84
- vote?: string
85
- unvote?: string
279
+
280
+ export interface JsTransactionViewContext {
281
+ from: string
282
+ to: string
283
+ data: Buffer
284
+ specId: string
285
+ gasLimit?: bigint
86
286
  }
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>
287
+
288
+ export interface JsUpdateRewardsAndVotesContext {
289
+ commitKey: JsCommitKey
290
+ timestamp: bigint
291
+ blockReward: bigint
292
+ validatorAddress: string
293
+ specId: string
294
+ }
295
+
296
+ export interface JsViewResult {
297
+ success: boolean
298
+ output?: Buffer
299
+ }
300
+
301
+ export declare const enum LogLevel {
302
+ Info = 0,
303
+ Debug = 1,
304
+ Notice = 2,
305
+ Alert = 3,
306
+ Warn = 4
101
307
  }
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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51' && 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.51 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.51",
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-x64-gnu": "0.0.1-evm.51",
14
+ "@mainsail/evm-linux-arm64-gnu": "0.0.1-evm.51"
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
  }