Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@solana/rpc-transport

Package Overview
Dependencies
Maintainers
14
Versions
602
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@solana/rpc-transport - npm Package Compare versions

Comparing version 2.0.0-experimental.e0b865d to 2.0.0-experimental.e1ca396

dist/types/index.d.ts.map

14

dist/index.browser.js

@@ -6,2 +6,4 @@ // ../build-scripts/env-shim.ts

var SolanaJsonRpcError = class extends Error {
code;
data;
constructor(details) {

@@ -177,2 +179,3 @@ super(`JSON-RPC 2.0 error (${details.code}): ${details.message}`);

var SolanaHttpError = class extends Error {
statusCode;
constructor(details) {

@@ -239,12 +242,6 @@ super(`HTTP error (${details.statusCode}): ${details.message}`);

// src/transports/http/http-transport.ts
function createHttpTransport({ httpAgentNodeOnly, headers, url }) {
function createHttpTransport({ headers, url }) {
if (__DEV__ && headers) {
assertIsAllowedHttpRequestHeaders(headers);
}
const agent = void 0;
if (__DEV__ && httpAgentNodeOnly != null) {
console.warn(
"createHttpTransport(): The `httpAgentNodeOnly` config you supplied has been ignored; HTTP agents are only usable in Node environments."
);
}
const customHeaders = headers && normalizeHeaders(headers);

@@ -257,3 +254,2 @@ return async function makeHttpRequest({

const requestInfo = {
agent,
body,

@@ -286,3 +282,3 @@ headers: {

var EXPLICIT_ABORT_TOKEN = Symbol(
__DEV__ ? "This symbol is thrown from a socket's iterator when the connection is explicity aborted by the user" : void 0
__DEV__ ? "This symbol is thrown from a socket's iterator when the connection is explicitly aborted by the user" : void 0
);

@@ -289,0 +285,0 @@ async function createWebSocketConnection({

@@ -6,2 +6,4 @@ // ../build-scripts/env-shim.ts

var SolanaJsonRpcError = class extends Error {
code;
data;
constructor(details) {

@@ -177,2 +179,3 @@ super(`JSON-RPC 2.0 error (${details.code}): ${details.message}`);

var SolanaHttpError = class extends Error {
statusCode;
constructor(details) {

@@ -239,12 +242,6 @@ super(`HTTP error (${details.statusCode}): ${details.message}`);

// src/transports/http/http-transport.ts
function createHttpTransport({ httpAgentNodeOnly, headers, url }) {
function createHttpTransport({ headers, url }) {
if (__DEV__ && headers) {
assertIsAllowedHttpRequestHeaders(headers);
}
const agent = void 0;
if (__DEV__ && httpAgentNodeOnly != null) {
console.warn(
"createHttpTransport(): The `httpAgentNodeOnly` config you supplied has been ignored; HTTP agents are only usable in Node environments."
);
}
const customHeaders = headers && normalizeHeaders(headers);

@@ -257,3 +254,2 @@ return async function makeHttpRequest({

const requestInfo = {
agent,
body,

@@ -286,3 +282,3 @@ headers: {

var EXPLICIT_ABORT_TOKEN = Symbol(
__DEV__ ? "This symbol is thrown from a socket's iterator when the connection is explicity aborted by the user" : void 0
__DEV__ ? "This symbol is thrown from a socket's iterator when the connection is explicitly aborted by the user" : void 0
);

@@ -289,0 +285,0 @@ async function createWebSocketConnection({

@@ -1,3 +0,2 @@

import t from 'node-fetch';
import e from 'ws';
import e2 from 'ws';

@@ -9,2 +8,4 @@ // ../build-scripts/env-shim.ts

var SolanaJsonRpcError = class extends Error {
code;
data;
constructor(details) {

@@ -174,6 +175,9 @@ super(`JSON-RPC 2.0 error (${details.code}): ${details.message}`);

}
var o = typeof globalThis.fetch == "function" ? globalThis.fetch : t;
// ../fetch-impl/dist/index.node.js
var e = globalThis.fetch;
// src/transports/http/http-transport-errors.ts
var SolanaHttpError = class extends Error {
statusCode;
constructor(details) {

@@ -240,12 +244,6 @@ super(`HTTP error (${details.statusCode}): ${details.message}`);

// src/transports/http/http-transport.ts
function createHttpTransport({ httpAgentNodeOnly, headers, url }) {
function createHttpTransport({ headers, url }) {
if (__DEV__ && headers) {
assertIsAllowedHttpRequestHeaders(headers);
}
const agent = httpAgentNodeOnly ;
if (__DEV__ && httpAgentNodeOnly != null) {
console.warn(
"createHttpTransport(): The `httpAgentNodeOnly` config you supplied has been ignored; HTTP agents are only usable in Node environments."
);
}
const customHeaders = headers && normalizeHeaders(headers);

@@ -258,3 +256,2 @@ return async function makeHttpRequest({

const requestInfo = {
agent,
body,

@@ -271,3 +268,3 @@ headers: {

};
const response = await o(url, requestInfo);
const response = await e(url, requestInfo);
if (!response.ok) {

@@ -282,7 +279,7 @@ throw new SolanaHttpError({

}
var t2 = e;
var t = e2;
// src/transports/websocket/websocket-connection.ts
var EXPLICIT_ABORT_TOKEN = Symbol(
__DEV__ ? "This symbol is thrown from a socket's iterator when the connection is explicity aborted by the user" : void 0
__DEV__ ? "This symbol is thrown from a socket's iterator when the connection is explicitly aborted by the user" : void 0
);

@@ -309,3 +306,3 @@ async function createWebSocketConnection({

errorAndClearAllIteratorStates(EXPLICIT_ABORT_TOKEN);
if (webSocket.readyState !== t2.CLOSED && webSocket.readyState !== t2.CLOSING) {
if (webSocket.readyState !== t.CLOSED && webSocket.readyState !== t.CLOSING) {
webSocket.close(1e3);

@@ -338,7 +335,7 @@ }

const message = JSON.stringify(payload);
if (!bufferDrainWatcher && webSocket.readyState === t2.OPEN && webSocket.bufferedAmount > sendBufferHighWatermark) {
if (!bufferDrainWatcher && webSocket.readyState === t.OPEN && webSocket.bufferedAmount > sendBufferHighWatermark) {
let onCancel;
const promise = new Promise((resolve2, reject2) => {
const intervalId = setInterval(() => {
if (webSocket.readyState !== t2.OPEN || !(webSocket.bufferedAmount > sendBufferHighWatermark)) {
if (webSocket.readyState !== t.OPEN || !(webSocket.bufferedAmount > sendBufferHighWatermark)) {
clearInterval(intervalId);

@@ -397,7 +394,7 @@ bufferDrainWatcher = void 0;

});
} catch (e2) {
if (e2 === EXPLICIT_ABORT_TOKEN) {
} catch (e3) {
if (e3 === EXPLICIT_ABORT_TOKEN) {
return;
} else {
throw new Error("WebSocket connection closed", { cause: e2 });
throw new Error("WebSocket connection closed", { cause: e3 });
}

@@ -425,3 +422,3 @@ }

}
const webSocket = new t2(url);
const webSocket = new t(url);
webSocket.addEventListener("close", handleClose);

@@ -428,0 +425,0 @@ webSocket.addEventListener("error", handleError);

export * from './json-rpc';
export type { SolanaJsonRpcErrorCode } from './json-rpc-errors';
export * from './json-rpc-subscription';
export type { IRpcApi, IRpcSubscriptionsApi, IRpcWebSocketTransport, PendingRpcSubscription, Rpc, RpcRequest, RpcSubscription, RpcSubscriptions, } from './json-rpc-types';
export * from './transports/http/http-transport';
export * from './transports/websocket/websocket-transport';
export type { IRpcTransport } from './transports/transport-types';
export * from './transports/websocket/websocket-transport';
//# sourceMappingURL=index.d.ts.map

@@ -6,6 +6,6 @@ import { IRpcTransport, IRpcWebSocketTransport } from './transports/transport-types';

export type IRpcApi<TRpcMethods> = {
[MethodName in keyof TRpcMethods]: TRpcMethods[MethodName] extends Callable ? (...rawParams: unknown[]) => RpcRequest<ReturnType<TRpcMethods[MethodName]>> : never;
[MethodName in keyof TRpcMethods]: RpcReturnTypeMapper<TRpcMethods[MethodName]>;
};
export type IRpcSubscriptionsApi<TRpcMethods> = {
[MethodName in keyof TRpcMethods]: TRpcMethods[MethodName] extends Callable ? (...rawParams: unknown[]) => RpcSubscription<ReturnType<TRpcMethods[MethodName]>> : never;
export type IRpcSubscriptionsApi<TRpcSubscriptionMethods> = {
[MethodName in keyof TRpcSubscriptionMethods]: RpcSubscriptionReturnTypeMapper<TRpcSubscriptionMethods[MethodName]>;
};

@@ -51,2 +51,4 @@ export type Rpc<TRpcMethods> = RpcMethods<TRpcMethods>;

*/
type RpcReturnTypeMapper<TRpcMethod> = TRpcMethod extends Callable ? (...rawParams: unknown[]) => RpcRequest<ReturnType<TRpcMethod>> : never;
type RpcSubscriptionReturnTypeMapper<TRpcMethod> = TRpcMethod extends Callable ? (...rawParams: unknown[]) => RpcSubscription<ReturnType<TRpcMethod>> : never;
type RpcMethods<TRpcMethods> = {

@@ -59,7 +61,9 @@ [TMethodName in keyof TRpcMethods]: PendingRpcRequestBuilder<ApiMethodImplementations<TRpcMethods, TMethodName>>;

type ApiMethodImplementations<TRpcMethods, TMethod extends keyof TRpcMethods> = Overloads<TRpcMethods[TMethod]>;
type PendingRpcRequestReturnTypeMapper<TMethodImplementation> = TMethodImplementation extends Callable ? (...args: Parameters<TMethodImplementation>) => PendingRpcRequest<ReturnType<TMethodImplementation>> : never;
type PendingRpcRequestBuilder<TMethodImplementations> = UnionToIntersection<Flatten<{
[P in keyof TMethodImplementations]: TMethodImplementations[P] extends Callable ? (...args: Parameters<TMethodImplementations[P]>) => PendingRpcRequest<ReturnType<TMethodImplementations[P]>> : never;
[P in keyof TMethodImplementations]: PendingRpcRequestReturnTypeMapper<TMethodImplementations[P]>;
}>>;
type PendingRpcSubscriptionReturnTypeMapper<TSubscriptionMethodImplementation> = TSubscriptionMethodImplementation extends Callable ? (...args: Parameters<TSubscriptionMethodImplementation>) => PendingRpcSubscription<ReturnType<TSubscriptionMethodImplementation>> : never;
type PendingRpcSubscriptionBuilder<TSubscriptionMethodImplementations> = UnionToIntersection<Flatten<{
[P in keyof TSubscriptionMethodImplementations]: TSubscriptionMethodImplementations[P] extends Callable ? (...args: Parameters<TSubscriptionMethodImplementations[P]>) => PendingRpcSubscription<ReturnType<TSubscriptionMethodImplementations[P]>> : never;
[P in keyof TSubscriptionMethodImplementations]: PendingRpcSubscriptionReturnTypeMapper<TSubscriptionMethodImplementations[P]>;
}>>;

@@ -71,3 +75,4 @@ /**

type Flatten<T> = T extends (infer Item)[] ? Item : never;
type Overloads<T> = T extends {
type Overloads<T> = Overloads24<T>;
type Overloads24<T> = T extends {
(...args: infer A1): infer R1;

@@ -122,3 +127,4 @@ (...args: infer A2): infer R2;

(...args: A24) => R24
] : T extends {
] : Overloads23<T>;
type Overloads23<T> = T extends {
(...args: infer A1): infer R1;

@@ -171,3 +177,4 @@ (...args: infer A2): infer R2;

(...args: A23) => R23
] : T extends {
] : Overloads22<T>;
type Overloads22<T> = T extends {
(...args: infer A1): infer R1;

@@ -218,3 +225,4 @@ (...args: infer A2): infer R2;

(...args: A22) => R22
] : T extends {
] : Overloads21<T>;
type Overloads21<T> = T extends {
(...args: infer A1): infer R1;

@@ -263,3 +271,4 @@ (...args: infer A2): infer R2;

(...args: A21) => R21
] : T extends {
] : Overloads20<T>;
type Overloads20<T> = T extends {
(...args: infer A1): infer R1;

@@ -306,3 +315,4 @@ (...args: infer A2): infer R2;

(...args: A20) => R20
] : T extends {
] : Overloads19<T>;
type Overloads19<T> = T extends {
(...args: infer A1): infer R1;

@@ -347,3 +357,4 @@ (...args: infer A2): infer R2;

(...args: A19) => R19
] : T extends {
] : Overloads18<T>;
type Overloads18<T> = T extends {
(...args: infer A1): infer R1;

@@ -386,3 +397,4 @@ (...args: infer A2): infer R2;

(...args: A18) => R18
] : T extends {
] : Overloads17<T>;
type Overloads17<T> = T extends {
(...args: infer A1): infer R1;

@@ -423,3 +435,4 @@ (...args: infer A2): infer R2;

(...args: A17) => R17
] : T extends {
] : Overloads16<T>;
type Overloads16<T> = T extends {
(...args: infer A1): infer R1;

@@ -458,3 +471,4 @@ (...args: infer A2): infer R2;

(...args: A16) => R16
] : T extends {
] : Overloads15<T>;
type Overloads15<T> = T extends {
(...args: infer A1): infer R1;

@@ -491,3 +505,4 @@ (...args: infer A2): infer R2;

(...args: A15) => R15
] : T extends {
] : Overloads14<T>;
type Overloads14<T> = T extends {
(...args: infer A1): infer R1;

@@ -522,3 +537,4 @@ (...args: infer A2): infer R2;

(...args: A14) => R14
] : T extends {
] : Overloads13<T>;
type Overloads13<T> = T extends {
(...args: infer A1): infer R1;

@@ -551,3 +567,4 @@ (...args: infer A2): infer R2;

(...args: A13) => R13
] : T extends {
] : Overloads12<T>;
type Overloads12<T> = T extends {
(...args: infer A1): infer R1;

@@ -578,3 +595,4 @@ (...args: infer A2): infer R2;

(...args: A12) => R12
] : T extends {
] : Overloads11<T>;
type Overloads11<T> = T extends {
(...args: infer A1): infer R1;

@@ -603,3 +621,4 @@ (...args: infer A2): infer R2;

(...args: A11) => R11
] : T extends {
] : Overloads10<T>;
type Overloads10<T> = T extends {
(...args: infer A1): infer R1;

@@ -626,3 +645,4 @@ (...args: infer A2): infer R2;

(...args: A10) => R10
] : T extends {
] : Overloads9<T>;
type Overloads9<T> = T extends {
(...args: infer A1): infer R1;

@@ -647,3 +667,4 @@ (...args: infer A2): infer R2;

(...args: A9) => R9
] : T extends {
] : Overloads8<T>;
type Overloads8<T> = T extends {
(...args: infer A1): infer R1;

@@ -666,3 +687,4 @@ (...args: infer A2): infer R2;

(...args: A8) => R8
] : T extends {
] : Overloads7<T>;
type Overloads7<T> = T extends {
(...args: infer A1): infer R1;

@@ -683,3 +705,4 @@ (...args: infer A2): infer R2;

(...args: A7) => R7
] : T extends {
] : Overloads6<T>;
type Overloads6<T> = T extends {
(...args: infer A1): infer R1;

@@ -698,3 +721,4 @@ (...args: infer A2): infer R2;

(...args: A6) => R6
] : T extends {
] : Overloads5<T>;
type Overloads5<T> = T extends {
(...args: infer A1): infer R1;

@@ -705,3 +729,4 @@ (...args: infer A2): infer R2;

(...args: infer A5): infer R5;
} ? [(...args: A1) => R1, (...args: A2) => R2, (...args: A3) => R3, (...args: A4) => R4, (...args: A5) => R5] : T extends {
} ? [(...args: A1) => R1, (...args: A2) => R2, (...args: A3) => R3, (...args: A4) => R4, (...args: A5) => R5] : Overloads4<T>;
type Overloads4<T> = T extends {
(...args: infer A1): infer R1;

@@ -711,14 +736,17 @@ (...args: infer A2): infer R2;

(...args: infer A4): infer R4;
} ? [(...args: A1) => R1, (...args: A2) => R2, (...args: A3) => R3, (...args: A4) => R4] : T extends {
} ? [(...args: A1) => R1, (...args: A2) => R2, (...args: A3) => R3, (...args: A4) => R4] : Overloads3<T>;
type Overloads3<T> = T extends {
(...args: infer A1): infer R1;
(...args: infer A2): infer R2;
(...args: infer A3): infer R3;
} ? [(...args: A1) => R1, (...args: A2) => R2, (...args: A3) => R3] : T extends {
} ? [(...args: A1) => R1, (...args: A2) => R2, (...args: A3) => R3] : Overloads2<T>;
type Overloads2<T> = T extends {
(...args: infer A1): infer R1;
(...args: infer A2): infer R2;
} ? [(...args: A1) => R1, (...args: A2) => R2] : T extends {
} ? [(...args: A1) => R1, (...args: A2) => R2] : Overloads1<T>;
type Overloads1<T> = T extends {
(...args: infer A1): infer R1;
} ? [(...args: A1) => R1] : unknown;
type UnionToIntersection<T> = (T extends unknown ? (x: T) => unknown : never) extends (x: infer R) => unknown ? R : never;
export {};
export type { IRpcWebSocketTransport };
//# sourceMappingURL=json-rpc-types.d.ts.map

@@ -1,5 +0,1 @@

/// <reference types="node" />
/// <reference types="node" />
import type { Agent as NodeHttpAgent } from 'node:http';
import type { Agent as NodeHttpsAgent } from 'node:https';
import { IRpcTransport } from '../transport-types';

@@ -9,7 +5,6 @@ import { AllowedHttpRequestHeaders } from './http-transport-headers';

headers?: AllowedHttpRequestHeaders;
httpAgentNodeOnly?: NodeHttpAgent | NodeHttpsAgent | ((parsedUrl: URL) => NodeHttpAgent | NodeHttpsAgent);
url: string;
}>;
export declare function createHttpTransport({ httpAgentNodeOnly, headers, url }: Config): IRpcTransport;
export declare function createHttpTransport({ headers, url }: Config): IRpcTransport;
export {};
//# sourceMappingURL=http-transport.d.ts.map
{
"name": "@solana/rpc-transport",
"version": "2.0.0-experimental.e0b865d",
"version": "2.0.0-experimental.e1ca396",
"description": "Network transports for accessing the Solana JSON RPC API",

@@ -50,5 +50,5 @@ "exports": {

"@solana/eslint-config-solana": "^1.0.2",
"@swc/jest": "^0.2.28",
"@types/jest": "^29.5.5",
"@types/node": "^20",
"@swc/jest": "^0.2.29",
"@types/jest": "^29.5.6",
"@types/node": "18.11.19",
"@typescript-eslint/eslint-plugin": "^6.7.0",

@@ -58,13 +58,13 @@ "@typescript-eslint/parser": "^6.3.0",

"eslint": "^8.45.0",
"eslint-plugin-jest": "^27.2.3",
"eslint-plugin-jest": "^27.4.2",
"eslint-plugin-sort-keys-fix": "^1.1.2",
"fast-stable-stringify": "^1.0.0",
"jest": "^29.7.0",
"jest-environment-jsdom": "^29.6.4",
"jest-environment-jsdom": "^29.7.0",
"jest-fetch-mock-fork": "^3.0.4",
"jest-runner-eslint": "^2.1.0",
"jest-runner-eslint": "^2.1.2",
"jest-runner-prettier": "^1.0.0",
"jest-websocket-mock": "^2.4.1",
"prettier": "^2.8",
"tsup": "7.2.0",
"jest-websocket-mock": "^2.5.0",
"prettier": "^3.1",
"tsup": "^8.0.1",
"typescript": "^5.2.2",

@@ -79,3 +79,2 @@ "version-from-git": "^1.1.1",

"peerDependencies": {
"node-fetch": "^2.6.7",
"ws": "^8.14.0"

@@ -96,8 +95,8 @@ },

"publish-packages": "pnpm publish --tag experimental --access public --no-git-checks",
"style:fix": "pnpm eslint --fix src/* && pnpm prettier -w src/*",
"style:fix": "pnpm eslint --fix src/* && pnpm prettier -w src/* package.json",
"test:lint": "jest -c node_modules/test-config/jest-lint.config.ts --rootDir . --silent",
"test:prettier": "jest -c node_modules/test-config/jest-prettier.config.ts --rootDir . --silent",
"test:treeshakability:browser": "agadoo dist/index.browser.js",
"test:treeshakability:native": "agadoo dist/index.node.js",
"test:treeshakability:node": "agadoo dist/index.native.js",
"test:treeshakability:native": "agadoo dist/index.native.js",
"test:treeshakability:node": "agadoo dist/index.node.js",
"test:typecheck": "tsc --noEmit",

@@ -104,0 +103,0 @@ "test:unit:browser": "jest -c node_modules/test-config/jest-unit.config.browser.ts --rootDir . --silent",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc