@pipeit/fastlane 0.1.0

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.
package/browser.js ADDED
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Browser stub for @pipeit/fastlane.
3
+ *
4
+ * This module provides empty exports for browser environments
5
+ * where the native QUIC client cannot run.
6
+ *
7
+ * In the browser, TPU submission routes through the /api/tpu endpoint
8
+ * which uses the real native client on the server.
9
+ */
10
+
11
+ // Stub TpuClient that throws helpful error if accidentally used in browser
12
+ export class TpuClient {
13
+ constructor() {
14
+ throw new Error(
15
+ '@pipeit/fastlane cannot be used in the browser. ' +
16
+ 'TPU submission should route through the API endpoint. ' +
17
+ 'Configure tpu.apiRoute in your execution config.',
18
+ );
19
+ }
20
+ }
21
+
22
+ export default { TpuClient };
Binary file
Binary file
Binary file
package/index.d.ts ADDED
@@ -0,0 +1,40 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+
4
+ /* auto-generated by NAPI-RS */
5
+
6
+ /** Configuration for the TPU client. */
7
+ export interface TpuClientConfig {
8
+ /** RPC URL for fetching leader schedule and cluster info. */
9
+ rpcUrl: string
10
+ /** WebSocket URL for slot update subscriptions. */
11
+ wsUrl: string
12
+ /** Number of upcoming leaders to send transactions to (default: 2). */
13
+ fanout?: number
14
+ /** Whether to pre-warm connections to upcoming leaders (default: true). */
15
+ prewarmConnections?: boolean
16
+ }
17
+ /** Result from sending a transaction. */
18
+ export interface SendResult {
19
+ /** Whether the transaction was successfully delivered. */
20
+ delivered: boolean
21
+ /** Latency in milliseconds. */
22
+ latencyMs: number
23
+ /** Number of leaders the transaction was sent to. */
24
+ leaderCount: number
25
+ }
26
+ /** Native QUIC client for direct Solana TPU transaction submission. */
27
+ export declare class TpuClient {
28
+ /** Creates a new TPU client instance. */
29
+ constructor(config: TpuClientConfig)
30
+ /** Sends a serialized transaction to TPU endpoints. */
31
+ sendTransaction(transaction: Buffer): Promise<SendResult>
32
+ /** Gets the current estimated slot number. */
33
+ getCurrentSlot(): number
34
+ /** Gets the number of active QUIC connections. */
35
+ getConnectionCount(): Promise<number>
36
+ /** Waits for the client to be fully initialized. */
37
+ waitReady(): Promise<void>
38
+ /** Shuts down the client and closes all connections. */
39
+ shutdown(): void
40
+ }
package/index.js ADDED
@@ -0,0 +1,315 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+ /* prettier-ignore */
4
+
5
+ /* auto-generated by NAPI-RS */
6
+
7
+ const { existsSync, readFileSync } = require('fs')
8
+ const { join } = require('path')
9
+
10
+ const { platform, arch } = process
11
+
12
+ let nativeBinding = null
13
+ let localFileExisted = false
14
+ let loadError = null
15
+
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) {
23
+ return true
24
+ }
25
+ } else {
26
+ const { glibcVersionRuntime } = process.report.getReport().header
27
+ return !glibcVersionRuntime
28
+ }
29
+ }
30
+
31
+ switch (platform) {
32
+ case 'android':
33
+ switch (arch) {
34
+ case 'arm64':
35
+ localFileExisted = existsSync(join(__dirname, 'fastlane.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./fastlane.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('@pipeit/fastlane-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'fastlane.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./fastlane.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('@pipeit/fastlane-android-arm-eabi')
53
+ }
54
+ } catch (e) {
55
+ loadError = e
56
+ }
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, 'fastlane.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./fastlane.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('@pipeit/fastlane-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'fastlane.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./fastlane.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('@pipeit/fastlane-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'fastlane.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./fastlane.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('@pipeit/fastlane-win32-arm64-msvc')
101
+ }
102
+ } catch (e) {
103
+ loadError = e
104
+ }
105
+ break
106
+ default:
107
+ throw new Error(`Unsupported architecture on Windows: ${arch}`)
108
+ }
109
+ break
110
+ case 'darwin':
111
+ localFileExisted = existsSync(join(__dirname, 'fastlane.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./fastlane.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('@pipeit/fastlane-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'fastlane.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./fastlane.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('@pipeit/fastlane-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'fastlane.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./fastlane.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('@pipeit/fastlane-darwin-arm64')
142
+ }
143
+ } catch (e) {
144
+ loadError = e
145
+ }
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, 'fastlane.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./fastlane.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('@pipeit/fastlane-freebsd-x64')
161
+ }
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, 'fastlane.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./fastlane.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('@pipeit/fastlane-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'fastlane.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./fastlane.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('@pipeit/fastlane-linux-x64-gnu')
191
+ }
192
+ } catch (e) {
193
+ loadError = e
194
+ }
195
+ }
196
+ break
197
+ case 'arm64':
198
+ if (isMusl()) {
199
+ localFileExisted = existsSync(
200
+ join(__dirname, 'fastlane.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./fastlane.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('@pipeit/fastlane-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'fastlane.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./fastlane.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('@pipeit/fastlane-linux-arm64-gnu')
220
+ }
221
+ } catch (e) {
222
+ loadError = e
223
+ }
224
+ }
225
+ break
226
+ case 'arm':
227
+ if (isMusl()) {
228
+ localFileExisted = existsSync(
229
+ join(__dirname, 'fastlane.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./fastlane.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('@pipeit/fastlane-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'fastlane.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./fastlane.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('@pipeit/fastlane-linux-arm-gnueabihf')
249
+ }
250
+ } catch (e) {
251
+ loadError = e
252
+ }
253
+ }
254
+ break
255
+ case 'riscv64':
256
+ if (isMusl()) {
257
+ localFileExisted = existsSync(
258
+ join(__dirname, 'fastlane.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./fastlane.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('@pipeit/fastlane-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'fastlane.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./fastlane.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('@pipeit/fastlane-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'fastlane.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./fastlane.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('@pipeit/fastlane-linux-s390x-gnu')
293
+ }
294
+ } catch (e) {
295
+ loadError = e
296
+ }
297
+ break
298
+ default:
299
+ throw new Error(`Unsupported architecture on Linux: ${arch}`)
300
+ }
301
+ break
302
+ default:
303
+ throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
304
+ }
305
+
306
+ if (!nativeBinding) {
307
+ if (loadError) {
308
+ throw loadError
309
+ }
310
+ throw new Error(`Failed to load native binding`)
311
+ }
312
+
313
+ const { TpuClient } = nativeBinding
314
+
315
+ module.exports.TpuClient = TpuClient
package/package.json ADDED
@@ -0,0 +1,53 @@
1
+ {
2
+ "name": "@pipeit/fastlane",
3
+ "version": "0.1.0",
4
+ "description": "Native QUIC client for direct Solana TPU transaction submission",
5
+ "main": "index.js",
6
+ "types": "index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "browser": "./browser.js",
10
+ "default": "./index.js"
11
+ },
12
+ "./browser": "./browser.js"
13
+ },
14
+ "browser": "./browser.js",
15
+ "napi": {
16
+ "name": "fastlane",
17
+ "triples": {
18
+ "defaults": false,
19
+ "additional": [
20
+ "aarch64-apple-darwin",
21
+ "x86_64-unknown-linux-gnu",
22
+ "x86_64-pc-windows-msvc"
23
+ ]
24
+ }
25
+ },
26
+ "license": "MIT",
27
+ "repository": {
28
+ "type": "git",
29
+ "url": "git+https://github.com/stevesarmiento/pipeit.git",
30
+ "directory": "packages/fastlane"
31
+ },
32
+ "files": [
33
+ "index.js",
34
+ "index.d.ts",
35
+ "browser.js",
36
+ "*.node"
37
+ ],
38
+ "scripts": {
39
+ "artifacts": "napi artifacts",
40
+ "build": "which cargo > /dev/null 2>&1 && napi build --platform --release || echo 'Skipping native build (cargo not found)'",
41
+ "build:debug": "napi build --platform",
42
+ "build:native": "napi build --platform --release",
43
+ "test": "node --test test.mjs",
44
+ "universal": "napi universal",
45
+ "version": "napi version"
46
+ },
47
+ "devDependencies": {
48
+ "@napi-rs/cli": "^2.18.0"
49
+ },
50
+ "engines": {
51
+ "node": ">= 18"
52
+ }
53
+ }