Added EIP-1193 support to Web3Provider.
This commit is contained in:
parent
427a78b258
commit
56af4413b1
@ -29,7 +29,7 @@ import { NodesmithProvider } from "./nodesmith-provider";
|
|||||||
import { Web3Provider } from "./web3-provider";
|
import { Web3Provider } from "./web3-provider";
|
||||||
import { WebSocketProvider } from "./websocket-provider";
|
import { WebSocketProvider } from "./websocket-provider";
|
||||||
|
|
||||||
import { AsyncSendable } from "./web3-provider";
|
import { ExternalProvider, JsonRpcFetchFunc } from "./web3-provider";
|
||||||
|
|
||||||
import { Formatter } from "./formatter";
|
import { Formatter } from "./formatter";
|
||||||
|
|
||||||
@ -124,7 +124,8 @@ export {
|
|||||||
TransactionRequest,
|
TransactionRequest,
|
||||||
TransactionResponse,
|
TransactionResponse,
|
||||||
|
|
||||||
AsyncSendable,
|
ExternalProvider,
|
||||||
|
JsonRpcFetchFunc,
|
||||||
|
|
||||||
Network,
|
Network,
|
||||||
Networkish
|
Networkish
|
||||||
|
@ -277,7 +277,7 @@ export class JsonRpcProvider extends BaseProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static defaultUrl(): string {
|
static defaultUrl(): string {
|
||||||
return "http:/" + "/localhost:8545";
|
return "http:/\/localhost:8545";
|
||||||
}
|
}
|
||||||
|
|
||||||
getSigner(addressOrIndex?: string | number): JsonRpcSigner {
|
getSigner(addressOrIndex?: string | number): JsonRpcSigner {
|
||||||
|
@ -9,71 +9,48 @@ const logger = new Logger(version);
|
|||||||
|
|
||||||
import { JsonRpcProvider } from "./json-rpc-provider";
|
import { JsonRpcProvider } from "./json-rpc-provider";
|
||||||
|
|
||||||
|
|
||||||
// Exported Types
|
// Exported Types
|
||||||
export type AsyncSendable = {
|
export type ExternalProvider = {
|
||||||
isMetaMask?: boolean;
|
isMetaMask?: boolean;
|
||||||
host?: string;
|
host?: string;
|
||||||
path?: string;
|
path?: string;
|
||||||
sendAsync?: (request: any, callback: (error: any, response: any) => void) => void
|
sendAsync?: (request: { method: string, params?: Array<any> }, callback: (error: any, response: any) => void) => void
|
||||||
send?: (request: any, callback: (error: any, response: any) => void) => void
|
send?: (request: { method: string, params?: Array<any> }, callback: (error: any, response: any) => void) => void
|
||||||
|
request?: (request: { method: string, params?: Array<any> }) => Promise<any>
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Web3Provider extends JsonRpcProvider {
|
let _nextId = 1;
|
||||||
readonly provider: AsyncSendable;
|
|
||||||
private _sendAsync: (request: any, callback: (error: any, response: any) => void) => void;
|
|
||||||
|
|
||||||
constructor(web3Provider: AsyncSendable, network?: Networkish) {
|
export type JsonRpcFetchFunc = (method: string, params?: Array<any>) => Promise<any>;
|
||||||
logger.checkNew(new.target, Web3Provider);
|
|
||||||
|
|
||||||
// HTTP has a host; IPC has a path.
|
type Web3LegacySend = (request: any, callback: (error: Error, response: any) => void) => void;
|
||||||
super(web3Provider.host || web3Provider.path || "", network);
|
|
||||||
|
|
||||||
if (web3Provider) {
|
function buildWeb3LegacyFetcher(provider: ExternalProvider, sendFunc: Web3LegacySend) : JsonRpcFetchFunc {
|
||||||
if (web3Provider.sendAsync) {
|
return function(method: string, params: Array<any>): Promise<any> {
|
||||||
this._sendAsync = web3Provider.sendAsync.bind(web3Provider);
|
|
||||||
} else if (web3Provider.send) {
|
|
||||||
this._sendAsync = web3Provider.send.bind(web3Provider);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!this._sendAsync) {
|
|
||||||
logger.throwArgumentError("invalid web3Provider", "web3Provider", web3Provider);
|
|
||||||
}
|
|
||||||
|
|
||||||
defineReadOnly(this, "provider", web3Provider);
|
|
||||||
}
|
|
||||||
|
|
||||||
send(method: string, params: Array<any>): Promise<any> {
|
|
||||||
|
|
||||||
// Metamask complains about eth_sign (and on some versions hangs)
|
// Metamask complains about eth_sign (and on some versions hangs)
|
||||||
if (method == "eth_sign" && this.provider.isMetaMask) {
|
if (method == "eth_sign" && provider.isMetaMask) {
|
||||||
// https://github.com/ethereum/go-ethereum/wiki/Management-APIs#personal_sign
|
// https://github.com/ethereum/go-ethereum/wiki/Management-APIs#personal_sign
|
||||||
method = "personal_sign";
|
method = "personal_sign";
|
||||||
params = [ params[1], params[0] ];
|
params = [ params[1], params[0] ];
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
const request = {
|
const request = {
|
||||||
method: method,
|
method: method,
|
||||||
params: params,
|
params: params,
|
||||||
id: (this._nextId++),
|
id: (_nextId++),
|
||||||
jsonrpc: "2.0"
|
jsonrpc: "2.0"
|
||||||
};
|
};
|
||||||
|
|
||||||
this._sendAsync(request, function(error, result) {
|
return new Promise((resolve, reject) => {
|
||||||
if (error) {
|
sendFunc(request, function(error, result) {
|
||||||
reject(error);
|
if (error) { return reject(error); }
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result.error) {
|
if (result.error) {
|
||||||
// @TODO: not any
|
const error = new Error(result.error.message);
|
||||||
const error: any = new Error(result.error.message);
|
(<any>error).code = result.error.code;
|
||||||
error.code = result.error.code;
|
(<any>error).data = result.error.data;
|
||||||
error.data = result.error.data;
|
return reject(error);
|
||||||
reject(error);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
resolve(result.result);
|
resolve(result.result);
|
||||||
@ -81,3 +58,70 @@ export class Web3Provider extends JsonRpcProvider {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function buildEip1193Fetcher(provider: ExternalProvider): JsonRpcFetchFunc {
|
||||||
|
return function(method: string, params: Array<any>): Promise<any> {
|
||||||
|
if (params == null) { params = [ ]; }
|
||||||
|
|
||||||
|
// Metamask complains about eth_sign (and on some versions hangs)
|
||||||
|
if (method == "eth_sign" && provider.isMetaMask) {
|
||||||
|
// https://github.com/ethereum/go-ethereum/wiki/Management-APIs#personal_sign
|
||||||
|
method = "personal_sign";
|
||||||
|
params = [ params[1], params[0] ];
|
||||||
|
}
|
||||||
|
|
||||||
|
return provider.request({ method, params });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export class Web3Provider extends JsonRpcProvider {
|
||||||
|
readonly provider: ExternalProvider;
|
||||||
|
readonly jsonRpcFetchFunc: JsonRpcFetchFunc;
|
||||||
|
|
||||||
|
constructor(provider: ExternalProvider | JsonRpcFetchFunc, network?: Networkish) {
|
||||||
|
logger.checkNew(new.target, Web3Provider);
|
||||||
|
|
||||||
|
if (provider == null) {
|
||||||
|
logger.throwArgumentError("missing provider", "provider", provider);
|
||||||
|
}
|
||||||
|
|
||||||
|
let path: string = null;
|
||||||
|
let jsonRpcFetchFunc: JsonRpcFetchFunc = null;
|
||||||
|
let subprovider: ExternalProvider = null;
|
||||||
|
|
||||||
|
if (typeof(provider) === "function") {
|
||||||
|
path = "unknown:";
|
||||||
|
jsonRpcFetchFunc = provider;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
path = provider.host || provider.path || "";
|
||||||
|
if (!path && provider.isMetaMask) {
|
||||||
|
path = "metamask";
|
||||||
|
}
|
||||||
|
|
||||||
|
subprovider = provider;
|
||||||
|
|
||||||
|
if (provider.request) {
|
||||||
|
if (path === "") { path = "eip-1193:"; }
|
||||||
|
jsonRpcFetchFunc = buildEip1193Fetcher(provider);
|
||||||
|
} else if (provider.sendAsync) {
|
||||||
|
jsonRpcFetchFunc = buildWeb3LegacyFetcher(provider, provider.sendAsync.bind(provider));
|
||||||
|
} else if (provider.send) {
|
||||||
|
jsonRpcFetchFunc = buildWeb3LegacyFetcher(provider, provider.send.bind(provider));
|
||||||
|
} else {
|
||||||
|
logger.throwArgumentError("unsupported provider", "provider", provider);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!path) { path = "unknown:"; }
|
||||||
|
}
|
||||||
|
|
||||||
|
super(path, network);
|
||||||
|
|
||||||
|
defineReadOnly(this, "jsonRpcFetchFunc", jsonRpcFetchFunc);
|
||||||
|
defineReadOnly(this, "provider", subprovider);
|
||||||
|
}
|
||||||
|
|
||||||
|
send(method: string, params: Array<any>): Promise<any> {
|
||||||
|
return this.jsonRpcFetchFunc(method, params);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user