Re-validating chain id when rpc url changes [custom network form] (#10982)

feature/default_network_editable
ryanml 4 years ago committed by GitHub
parent 29fa00a97b
commit 10e91e975a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 42
      ui/pages/settings/networks-tab/network-form/network-form.component.js

@ -139,6 +139,20 @@ export default class NetworkForm extends PureComponent {
return parseInt(chainId, 16).toString(10); return parseInt(chainId, 16).toString(10);
} }
/**
* Prefixes a given id with '0x' if the prefix does not exist
*
* @param {string} chainId - The chainId to prefix
* @returns {string} The chainId, prefixed with '0x'
*/
prefixChainId(chainId) {
let prefixedChainId = chainId;
if (!chainId.startsWith('0x')) {
prefixedChainId = `0x${parseInt(chainId, 10).toString(16)}`;
}
return prefixedChainId;
}
onSubmit = async () => { onSubmit = async () => {
this.setState({ this.setState({
isSubmitting: true, isSubmitting: true,
@ -162,11 +176,7 @@ export default class NetworkForm extends PureComponent {
} = this.state; } = this.state;
const formChainId = stateChainId.trim().toLowerCase(); const formChainId = stateChainId.trim().toLowerCase();
// Ensure chainId is a 0x-prefixed, lowercase hex string const chainId = this.prefixChainId(formChainId);
let chainId = formChainId;
if (!chainId.startsWith('0x')) {
chainId = `0x${parseInt(chainId, 10).toString(16)}`;
}
if (!(await this.validateChainIdOnSubmit(formChainId, chainId, rpcUrl))) { if (!(await this.validateChainIdOnSubmit(formChainId, chainId, rpcUrl))) {
this.setState({ this.setState({
@ -317,6 +327,10 @@ export default class NetworkForm extends PureComponent {
}); });
}; };
hasError = (errorKey, errorVal) => {
return this.state.errors[errorKey] === errorVal;
};
validateChainIdOnChange = (chainIdArg = '') => { validateChainIdOnChange = (chainIdArg = '') => {
const chainId = chainIdArg.trim(); const chainId = chainIdArg.trim();
let errorMessage = ''; let errorMessage = '';
@ -392,6 +406,8 @@ export default class NetworkForm extends PureComponent {
this.setErrorTo('chainId', errorMessage); this.setErrorTo('chainId', errorMessage);
return false; return false;
} }
this.setErrorTo('chainId', '');
return true; return true;
}; };
@ -416,9 +432,16 @@ export default class NetworkForm extends PureComponent {
}; };
validateUrlRpcUrl = (url, stateKey) => { validateUrlRpcUrl = (url, stateKey) => {
const { t } = this.context;
const { rpcUrls } = this.props; const { rpcUrls } = this.props;
const { chainId: stateChainId } = this.state;
const isValidUrl = validUrl.isWebUri(url) && url !== '';
const chainIdFetchFailed = this.hasError(
'chainId',
t('failedToFetchChainId'),
);
if (!validUrl.isWebUri(url) && url !== '') { if (!isValidUrl) {
this.setErrorTo( this.setErrorTo(
stateKey, stateKey,
this.context.t( this.context.t(
@ -430,6 +453,13 @@ export default class NetworkForm extends PureComponent {
} else { } else {
this.setErrorTo(stateKey, ''); this.setErrorTo(stateKey, '');
} }
// Re-validate the chain id if it could not be found with previous rpc url
if (stateChainId && isValidUrl && chainIdFetchFailed) {
const formChainId = stateChainId.trim().toLowerCase();
const chainId = this.prefixChainId(formChainId);
this.validateChainIdOnSubmit(formChainId, chainId, url);
}
}; };
renderWarning() { renderWarning() {

Loading…
Cancel
Save