mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-10 05:46:03 +00:00
fix: fix node connection test to use the endpoints correctly
This caused issues to connect to Infura for example, because we did not support HTTPS at all, nor WSS
This commit is contained in:
parent
1a7fc663b7
commit
0503bb24a3
@ -10,6 +10,7 @@ const constants = require('embark-core/constants');
|
|||||||
import { __ } from 'embark-i18n';
|
import { __ } from 'embark-i18n';
|
||||||
import {
|
import {
|
||||||
buildUrlFromConfig,
|
buildUrlFromConfig,
|
||||||
|
deconstructUrl,
|
||||||
canonicalHost,
|
canonicalHost,
|
||||||
dappPath,
|
dappPath,
|
||||||
defaultHost,
|
defaultHost,
|
||||||
@ -389,7 +390,18 @@ export class Config {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!this.blockchainConfig.endpoint) {
|
if (this.blockchainConfig.endpoint) {
|
||||||
|
const {type, host, port} = deconstructUrl(this.blockchainConfig.endpoint);
|
||||||
|
if (type === 'ws') {
|
||||||
|
this.blockchainConfig.wsHost = host;
|
||||||
|
this.blockchainConfig.wsPort = port;
|
||||||
|
this.blockchainConfig.wsRPC = true;
|
||||||
|
} else {
|
||||||
|
this.blockchainConfig.rpcHost = host;
|
||||||
|
this.blockchainConfig.rpcPort = port;
|
||||||
|
this.blockchainConfig.wsRPC = false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
const urlConfig = (this.blockchainConfig.wsHost) ? {
|
const urlConfig = (this.blockchainConfig.wsHost) ? {
|
||||||
host: this.blockchainConfig.wsHost,
|
host: this.blockchainConfig.wsHost,
|
||||||
port: this.blockchainConfig.wsPort,
|
port: this.blockchainConfig.wsPort,
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
const WebSocket = require("ws");
|
const WebSocket = require("ws");
|
||||||
const http = require("http");
|
const http = require("http");
|
||||||
|
const https = require("https");
|
||||||
|
|
||||||
const LIVENESS_CHECK = `{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":42}`;
|
const LIVENESS_CHECK = `{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":42}`;
|
||||||
|
|
||||||
@ -20,10 +21,8 @@ const parseAndRespond = (data, cb) => {
|
|||||||
cb(null, version);
|
cb(null, version);
|
||||||
};
|
};
|
||||||
|
|
||||||
const rpc = (host, port, cb) => {
|
const rpcWithEndpoint = (endpoint, cb) => {
|
||||||
const options = {
|
const options = {
|
||||||
hostname: host, // TODO(andremedeiros): get from config
|
|
||||||
port: port, // TODO(andremedeiros): get from config
|
|
||||||
method: "POST",
|
method: "POST",
|
||||||
timeout: 1000,
|
timeout: 1000,
|
||||||
headers: {
|
headers: {
|
||||||
@ -32,7 +31,12 @@ const rpc = (host, port, cb) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const req = http.request(options, (res) => {
|
let obj = http;
|
||||||
|
if (endpoint.startsWith('https')) {
|
||||||
|
obj = https;
|
||||||
|
}
|
||||||
|
|
||||||
|
const req = obj.request(endpoint, options, (res) => {
|
||||||
let data = "";
|
let data = "";
|
||||||
res.on("data", chunk => { data += chunk; });
|
res.on("data", chunk => { data += chunk; });
|
||||||
res.on("end", () => parseAndRespond(data, cb));
|
res.on("end", () => parseAndRespond(data, cb));
|
||||||
@ -42,8 +46,8 @@ const rpc = (host, port, cb) => {
|
|||||||
req.end();
|
req.end();
|
||||||
};
|
};
|
||||||
|
|
||||||
const ws = (host, port, cb) => {
|
const ws = (endpoint, cb) => {
|
||||||
const conn = new WebSocket("ws://" + host + ":" + port);
|
const conn = new WebSocket(endpoint);
|
||||||
conn.on("message", (data) => {
|
conn.on("message", (data) => {
|
||||||
parseAndRespond(data, cb);
|
parseAndRespond(data, cb);
|
||||||
conn.close();
|
conn.close();
|
||||||
@ -54,5 +58,5 @@ const ws = (host, port, cb) => {
|
|||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
ws,
|
ws,
|
||||||
rpc
|
rpcWithEndpoint
|
||||||
};
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { __ } from 'embark-i18n';
|
|||||||
const {normalizeInput} = require('embark-utils');
|
const {normalizeInput} = require('embark-utils');
|
||||||
import { BlockchainProcessLauncher } from './blockchainProcessLauncher';
|
import { BlockchainProcessLauncher } from './blockchainProcessLauncher';
|
||||||
import { BlockchainClient } from './blockchain';
|
import { BlockchainClient } from './blockchain';
|
||||||
import { ws, rpc } from './check.js';
|
import { ws, rpcWithEndpoint } from './check.js';
|
||||||
import DevTxs from "./devtxs";
|
import DevTxs from "./devtxs";
|
||||||
const constants = require('embark-core/constants');
|
const constants = require('embark-core/constants');
|
||||||
|
|
||||||
@ -82,21 +82,16 @@ class Geth {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_doCheck(cb) {
|
_doCheck(cb) {
|
||||||
const { rpcHost, rpcPort, wsRPC, wsHost, wsPort } = this.blockchainConfig;
|
if (this.blockchainConfig.endpoint.startsWith('ws')) {
|
||||||
if (wsRPC) {
|
return ws(this.blockchainConfig.endpoint, (err, version) => this._getNodeState(err, version, cb));
|
||||||
return ws(wsHost, wsPort, (err, version) => this._getNodeState(err, version, cb));
|
|
||||||
}
|
}
|
||||||
rpc(rpcHost, rpcPort, (err, version) => this._getNodeState(err, version, cb));
|
rpcWithEndpoint(this.blockchainConfig.endpoint, (err, version) => this._getNodeState(err, version, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: need to get correct port taking into account the proxy
|
// TODO: need to get correct port taking into account the proxy
|
||||||
registerServiceCheck() {
|
registerServiceCheck() {
|
||||||
this.events.request("services:register", 'Ethereum', (cb) => {
|
this.events.request("services:register", 'Ethereum', (cb) => {
|
||||||
const { rpcHost, rpcPort, wsRPC, wsHost, wsPort } = this.blockchainConfig;
|
this._doCheck(cb);
|
||||||
if (wsRPC) {
|
|
||||||
return ws(wsHost, wsPort, (err, version) => this._getNodeState(err, version, cb));
|
|
||||||
}
|
|
||||||
rpc(rpcHost, rpcPort, (err, version) => this._getNodeState(err, version, cb));
|
|
||||||
}, 5000, 'off');
|
}, 5000, 'off');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
const WebSocket = require("ws");
|
const WebSocket = require("ws");
|
||||||
const http = require("http");
|
const http = require("http");
|
||||||
|
const https = require("https");
|
||||||
|
|
||||||
const LIVENESS_CHECK=`{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":42}`;
|
const LIVENESS_CHECK=`{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":42}`;
|
||||||
|
|
||||||
@ -20,10 +21,8 @@ const parseAndRespond = (data, cb) => {
|
|||||||
cb(null, version);
|
cb(null, version);
|
||||||
};
|
};
|
||||||
|
|
||||||
const rpc = (host, port, cb) => {
|
const rpcWithEndpoint = (endpoint, cb) => {
|
||||||
const options = {
|
const options = {
|
||||||
hostname: host, // TODO(andremedeiros): get from config
|
|
||||||
port: port, // TODO(andremedeiros): get from config
|
|
||||||
method: "POST",
|
method: "POST",
|
||||||
timeout: 1000,
|
timeout: 1000,
|
||||||
headers: {
|
headers: {
|
||||||
@ -32,7 +31,12 @@ const rpc = (host, port, cb) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const req = http.request(options, (res) => {
|
let obj = http;
|
||||||
|
if (endpoint.startsWith('https')) {
|
||||||
|
obj = https;
|
||||||
|
}
|
||||||
|
|
||||||
|
const req = obj.request(endpoint, options, (res) => {
|
||||||
let data = "";
|
let data = "";
|
||||||
res.on("data", chunk => { data += chunk; });
|
res.on("data", chunk => { data += chunk; });
|
||||||
res.on("end", () => parseAndRespond(data, cb));
|
res.on("end", () => parseAndRespond(data, cb));
|
||||||
@ -42,8 +46,8 @@ const rpc = (host, port, cb) => {
|
|||||||
req.end();
|
req.end();
|
||||||
};
|
};
|
||||||
|
|
||||||
const ws = (host, port, cb) => {
|
const ws = (endpoint, cb) => {
|
||||||
const conn = new WebSocket("ws://" + host + ":" + port);
|
const conn = new WebSocket(endpoint);
|
||||||
conn.on("message", (data) => {
|
conn.on("message", (data) => {
|
||||||
parseAndRespond(data, cb);
|
parseAndRespond(data, cb);
|
||||||
conn.close();
|
conn.close();
|
||||||
@ -54,5 +58,5 @@ const ws = (host, port, cb) => {
|
|||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
ws,
|
ws,
|
||||||
rpc
|
rpcWithEndpoint
|
||||||
};
|
};
|
||||||
|
@ -2,7 +2,7 @@ import { __ } from 'embark-i18n';
|
|||||||
import {BlockchainClient} from "./blockchain";
|
import {BlockchainClient} from "./blockchain";
|
||||||
const {normalizeInput} = require('embark-utils');
|
const {normalizeInput} = require('embark-utils');
|
||||||
import {BlockchainProcessLauncher} from './blockchainProcessLauncher';
|
import {BlockchainProcessLauncher} from './blockchainProcessLauncher';
|
||||||
import {ws, rpc} from './check.js';
|
import {ws, rpcWithEndpoint} from './check.js';
|
||||||
const constants = require('embark-core/constants');
|
const constants = require('embark-core/constants');
|
||||||
|
|
||||||
class Parity {
|
class Parity {
|
||||||
@ -70,11 +70,10 @@ class Parity {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_doCheck(cb) {
|
_doCheck(cb) {
|
||||||
const { rpcHost, rpcPort, wsRPC, wsHost, wsPort } = this.blockchainConfig;
|
if (this.blockchainConfig.endpoint.startsWith('ws')) {
|
||||||
if (wsRPC) {
|
return ws(this.blockchainConfig.endpoint, (err, version) => this._getNodeState(err, version, cb));
|
||||||
return ws(wsHost, wsPort, (err, version) => this._getNodeState(err, version, cb));
|
|
||||||
}
|
}
|
||||||
rpc(rpcHost, rpcPort, (err, version) => this._getNodeState(err, version, cb));
|
rpcWithEndpoint(this.blockchainConfig.endpoint, (err, version) => this._getNodeState(err, version, cb));
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: need to get correct port taking into account the proxy
|
// TODO: need to get correct port taking into account the proxy
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
const WebSocket = require("ws");
|
const WebSocket = require("ws");
|
||||||
const http = require("http");
|
const http = require("http");
|
||||||
|
const https = require("https");
|
||||||
|
|
||||||
const LIVENESS_CHECK = JSON.stringify({
|
const LIVENESS_CHECK = JSON.stringify({
|
||||||
jsonrpc:'2.0',
|
jsonrpc:'2.0',
|
||||||
@ -25,10 +26,8 @@ const parseAndRespond = (data, cb) => {
|
|||||||
cb(null, resp.result);
|
cb(null, resp.result);
|
||||||
};
|
};
|
||||||
|
|
||||||
const rpc = (host, port, cb) => {
|
const rpcWithEndpoint = (endpoint, cb) => {
|
||||||
const options = {
|
const options = {
|
||||||
hostname: host, // TODO(andremedeiros): get from config
|
|
||||||
port, // TODO(andremedeiros): get from config
|
|
||||||
method: "POST",
|
method: "POST",
|
||||||
timeout: 1000,
|
timeout: 1000,
|
||||||
headers: {
|
headers: {
|
||||||
@ -37,9 +36,14 @@ const rpc = (host, port, cb) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const req = http.request(options, (res) => {
|
let obj = http;
|
||||||
|
if (endpoint.startsWith('https')) {
|
||||||
|
obj = https;
|
||||||
|
}
|
||||||
|
|
||||||
|
const req = obj.request(endpoint, options, (res) => {
|
||||||
let data = "";
|
let data = "";
|
||||||
res.on("data", (chunk) => { data += chunk; });
|
res.on("data", chunk => { data += chunk; });
|
||||||
res.on("end", () => parseAndRespond(data, cb));
|
res.on("end", () => parseAndRespond(data, cb));
|
||||||
});
|
});
|
||||||
req.on("error", (e) => cb(e));
|
req.on("error", (e) => cb(e));
|
||||||
@ -47,8 +51,8 @@ const rpc = (host, port, cb) => {
|
|||||||
req.end();
|
req.end();
|
||||||
};
|
};
|
||||||
|
|
||||||
const ws = (host, port, cb) => {
|
const ws = (endpoint, cb) => {
|
||||||
const conn = new WebSocket("ws://" + host + ":" + port);
|
const conn = new WebSocket(endpoint);
|
||||||
conn.on("message", (data) => {
|
conn.on("message", (data) => {
|
||||||
parseAndRespond(data, cb);
|
parseAndRespond(data, cb);
|
||||||
conn.close();
|
conn.close();
|
||||||
@ -59,5 +63,5 @@ const ws = (host, port, cb) => {
|
|||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
ws,
|
ws,
|
||||||
rpc
|
rpcWithEndpoint
|
||||||
};
|
};
|
||||||
|
@ -3,7 +3,7 @@ import { dappPath, canonicalHost, defaultHost } from "embark-utils";
|
|||||||
const constants = require("embark-core/constants");
|
const constants = require("embark-core/constants");
|
||||||
const API = require("./api.js");
|
const API = require("./api.js");
|
||||||
import { BlockchainProcessLauncher } from "./blockchainProcessLauncher";
|
import { BlockchainProcessLauncher } from "./blockchainProcessLauncher";
|
||||||
import { ws, rpc } from "./check.js";
|
import { ws, rpcWithEndpoint } from "./check.js";
|
||||||
const { normalizeInput } = require("embark-utils");
|
const { normalizeInput } = require("embark-utils");
|
||||||
|
|
||||||
class Whisper {
|
class Whisper {
|
||||||
@ -64,12 +64,10 @@ class Whisper {
|
|||||||
|
|
||||||
registerServiceCheck() {
|
registerServiceCheck() {
|
||||||
this.events.request("services:register", "Whisper", (cb) => {
|
this.events.request("services:register", "Whisper", (cb) => {
|
||||||
const { host, port, type } = this.communicationConfig.connection;
|
if (this.blockchainConfig.endpoint.startsWith('ws')) {
|
||||||
if (type === "ws") {
|
return ws(this.blockchainConfig.endpoint, (err, version) => this._getNodeState(err, version, cb));
|
||||||
return ws(host, port, (err, version) => this._getNodeState(err, version, cb));
|
|
||||||
}
|
}
|
||||||
rpc(host, port, (err, version) => this._getNodeState(err, version, cb));
|
rpcWithEndpoint(this.blockchainConfig.endpoint, (err, version) => this._getNodeState(err, version, cb));
|
||||||
|
|
||||||
}, 5000, "off");
|
}, 5000, "off");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,8 +92,13 @@ export default class ProxyManager {
|
|||||||
}
|
}
|
||||||
this.inited = true;
|
this.inited = true;
|
||||||
|
|
||||||
|
let port = this.embark.config.blockchainConfig.rpcPort;
|
||||||
|
if (!port && port !== 0) {
|
||||||
|
port = 8545;
|
||||||
|
}
|
||||||
|
|
||||||
// setup ports
|
// setup ports
|
||||||
const rpcPort = await findNextPort(this.embark.config.blockchainConfig.rpcPort + constants.blockchain.servicePortOnProxy);
|
const rpcPort = await findNextPort(port + constants.blockchain.servicePortOnProxy);
|
||||||
const wsPort = await findNextPort(rpcPort + 1);
|
const wsPort = await findNextPort(rpcPort + 1);
|
||||||
this.rpcPort = rpcPort;
|
this.rpcPort = rpcPort;
|
||||||
this.wsPort = wsPort;
|
this.wsPort = wsPort;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user