1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

[MMI] Added code fencing in libs folder (#17929)

This commit is contained in:
Albert Olivé 2023-06-02 18:40:58 +02:00 committed by GitHub
parent 4f8c4820d2
commit 9195057136
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 408 additions and 1 deletions

View File

@ -7,6 +7,16 @@ import sendMetadata from './send-metadata';
import switchEthereumChain from './switch-ethereum-chain';
import watchAsset from './watch-asset';
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
import mmiSupported from './institutional/mmi-supported';
import mmiAuthenticate from './institutional/mmi-authenticate';
import mmiPortfolio from './institutional/mmi-portfolio';
import mmiOpenSwaps from './institutional/mmi-open-swaps';
import mmiCheckIfTokenIsPresent from './institutional/mmi-check-if-token-is-present';
import mmiSetAccountAndNetwork from './institutional/mmi-set-account-and-network';
import mmiOpenAddHardwareWallet from './institutional/mmi-open-add-hardware-wallet';
///: END:ONLY_INCLUDE_IN
const handlers = [
addEthereumChain,
ethAccounts,
@ -16,5 +26,14 @@ const handlers = [
sendMetadata,
switchEthereumChain,
watchAsset,
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
mmiAuthenticate,
mmiSupported,
mmiPortfolio,
mmiOpenSwaps,
mmiCheckIfTokenIsPresent,
mmiSetAccountAndNetwork,
mmiOpenAddHardwareWallet,
///: END:ONLY_INCLUDE_IN
];
export default handlers;

View File

@ -0,0 +1,43 @@
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiAuthenticate = {
methodNames: [MESSAGE_TYPE.MMI_AUTHENTICATE, MESSAGE_TYPE.MMI_REAUTHENTICATE],
implementation: mmiAuthenticateHandler,
hookNames: {
handleMmiAuthenticate: true,
},
};
export default mmiAuthenticate;
/**
* @typedef {object} MmiAuthenticateOptions
* @property {Function} handleWatchAssetRequest - The wallet_watchAsset method implementation.
*/
/**
* @typedef {object} MmiAuthenticateParam
* @property {string} service - The service to which we are authenticating, e.g. 'codefi-compliance'
* @property {object} token - The token used to authenticate
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest<WatchAssetParam>} req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
* @param {WatchAssetOptions} options
*/
async function mmiAuthenticateHandler(
req,
res,
_next,
end,
{ handleMmiAuthenticate },
) {
try {
res.result = await handleMmiAuthenticate(req);
return end();
} catch (error) {
return end(error);
}
}

View File

@ -0,0 +1,46 @@
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiAuthenticate = {
methodNames: [MESSAGE_TYPE.MMI_CHECK_IF_TOKEN_IS_PRESENT],
implementation: mmiCheckIfTokenIsPresentHandler,
hookNames: {
handleMmiCheckIfTokenIsPresent: true,
},
};
export default mmiAuthenticate;
/**
* @typedef {object} MmiAuthenticateOptions
* @property {Function} handleMmiCheckIfTokenIsPresent - The metamaskinstitutional_checkIfTokenIsPresent method implementation.
*/
/**
* @typedef {object} MmiCheckIfTokenIsPresentParam
* @property {string} service - The service to which we are authenticating, e.g. 'codefi-compliance'
* @property {object} environment - The environment in which we are authenticating, e.g. 'saturn-dev'
* @property {apiUrl} apiUrl - The API URL to which we are authenticating, e.g. 'https://saturn-custody.codefi.network/eth'
* @property {object} token - The token used to authenticate
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest<MmiCheckIfTokenIsPresentParam>} req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
* @param options0
* @param options0.handleMmiCheckIfTokenIsPresent
*/
async function mmiCheckIfTokenIsPresentHandler(
req,
res,
_next,
end,
{ handleMmiCheckIfTokenIsPresent },
) {
try {
res.result = await handleMmiCheckIfTokenIsPresent(req);
return end();
} catch (error) {
return end(error);
}
}

View File

@ -0,0 +1,50 @@
import { RPC_ALLOWED_ORIGINS } from '@metamask-institutional/rpc-allowlist';
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiOpenAddHardwareWallet = {
methodNames: [MESSAGE_TYPE.MMI_OPEN_ADD_HARDWARE_WALLET],
implementation: mmiOpenAddHardwareWalletHandler,
hookNames: {
handleMmiOpenAddHardwareWallet: true,
},
};
export default mmiOpenAddHardwareWallet;
/**
* @typedef {object} MmiOpenAddHardwareWalletOptions
* @property {Function} handleMmiOpenAddHardwareWallet - The metmaskinsititutional_openAddHardwareWallet method implementation.
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest} req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
* @param {WatchAssetOptions} options
*/
async function mmiOpenAddHardwareWalletHandler(
req,
res,
_next,
end,
{ handleMmiOpenAddHardwareWallet },
) {
try {
let validUrl = false;
// if (!RPC_ALLOWED_ORIGINS[MESSAGE_TYPE.MMI_PORTFOLIO].includes(req.origin)) {
RPC_ALLOWED_ORIGINS[MESSAGE_TYPE.MMI_PORTFOLIO].forEach((regexp) => {
// eslint-disable-next-line require-unicode-regexp
if (regexp.test(req.origin)) {
validUrl = true;
}
});
// eslint-disable-next-line no-negated-condition
if (!validUrl) {
throw new Error('Unauthorized');
}
res.result = await handleMmiOpenAddHardwareWallet();
return end();
} catch (error) {
return end(error);
}
}

View File

@ -0,0 +1,68 @@
import { ethErrors } from 'eth-rpc-errors';
import { RPC_ALLOWED_ORIGINS } from '@metamask-institutional/rpc-allowlist';
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiOpenSwaps = {
methodNames: [MESSAGE_TYPE.MMI_OPEN_SWAPS],
implementation: mmiOpenSwapsHandler,
hookNames: {
handleMmiOpenSwaps: true,
},
};
export default mmiOpenSwaps;
/**
* @typedef {object} MmiOpenSwapsOptions
* @property {Function} handleMmiOpenSwaps - The metmaskinsititutional_open_swaps method implementation.
*/
/**
* @typedef {object} MmiOpenSwapsParam
* @property {string} service - The service to which we are authenticating, e.g. 'codefi-compliance'
* @property {object} token - The token used to authenticate
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest<MmiOpenSwapsParam>} req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
* @param {WatchAssetOptions} options
*/
async function mmiOpenSwapsHandler(
req,
res,
_next,
end,
{ handleMmiOpenSwaps },
) {
try {
let validUrl = false;
// if (!RPC_ALLOWED_ORIGINS[MESSAGE_TYPE.MMI_PORTFOLIO].includes(req.origin)) {
RPC_ALLOWED_ORIGINS[MESSAGE_TYPE.MMI_PORTFOLIO].forEach((regexp) => {
// eslint-disable-next-line require-unicode-regexp
if (regexp.test(req.origin)) {
validUrl = true;
}
});
// eslint-disable-next-line no-negated-condition
if (!validUrl) {
throw new Error('Unauthorized');
}
if (!req.params?.[0] || typeof req.params[0] !== 'object') {
return end(
ethErrors.rpc.invalidParams({
message: `Expected single, object parameter. Received:\n${JSON.stringify(
req.params,
)}`,
}),
);
}
const { address, network } = req.params[0];
res.result = await handleMmiOpenSwaps(req.origin, address, network);
return end();
} catch (error) {
return end(error);
}
}

View File

@ -0,0 +1,56 @@
import { RPC_ALLOWED_ORIGINS } from '@metamask-institutional/rpc-allowlist';
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiPortfolio = {
methodNames: [MESSAGE_TYPE.MMI_PORTFOLIO],
implementation: mmiPortfolioHandler,
hookNames: {
handleMmiPortfolio: true,
},
};
export default mmiPortfolio;
/**
* @typedef {object} MmiPortfolioOptions
* @property {Function} handleMmiportfolio - The metmaskinsititutional_portfolio method implementation.
*/
/**
* @typedef {object} MmiPortfolioParam
* @property {string} service - The service to which we are authenticating, e.g. 'codefi-compliance'
* @property {object} token - The token used to authenticate
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest<MmiPortfolioParam>} req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
* @param {WatchAssetOptions} options
*/
async function mmiPortfolioHandler(
req,
res,
_next,
end,
{ handleMmiPortfolio },
) {
try {
let validUrl = false;
RPC_ALLOWED_ORIGINS[MESSAGE_TYPE.MMI_PORTFOLIO].forEach((regexp) => {
// eslint-disable-next-line require-unicode-regexp
if (regexp.test(req.origin)) {
validUrl = true;
}
});
// eslint-disable-next-line no-negated-condition
if (!validUrl) {
throw new Error('Unauthorized');
} else {
res.result = await handleMmiPortfolio(req);
return end();
}
} catch (error) {
return end(error);
}
}

View File

@ -0,0 +1,71 @@
import { ethErrors } from 'eth-rpc-errors';
import { RPC_ALLOWED_ORIGINS } from '@metamask-institutional/rpc-allowlist';
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiSetAccountAndNetwork = {
methodNames: [MESSAGE_TYPE.MMI_SET_ACCOUNT_AND_NETWORK],
implementation: mmiSetAccountAndNetworkHandler,
hookNames: {
handleMmiSetAccountAndNetwork: true,
},
};
export default mmiSetAccountAndNetwork;
/**
* @typedef {object} MmiSetAccountAndNetworkOptions
* @property {Function} handleMmiSetAccountAndNetwork - The metmaskinsititutional_set_account_and_network method implementation.
*/
/**
* @typedef {object} MmiSetAccountAndNetworkParam
* @property {string} account - Account address
* @property {number} network - Chain Id
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest<MmiSetAccountAndNetworkParam>} req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
* @param {WatchAssetOptions} options
*/
async function mmiSetAccountAndNetworkHandler(
req,
res,
_next,
end,
{ handleMmiSetAccountAndNetwork },
) {
try {
let validUrl = false;
RPC_ALLOWED_ORIGINS[MESSAGE_TYPE.MMI_PORTFOLIO].forEach((regexp) => {
// eslint-disable-next-line require-unicode-regexp
if (regexp.test(req.origin)) {
validUrl = true;
}
});
// eslint-disable-next-line no-negated-condition
if (!validUrl) {
throw new Error('Unauthorized');
}
if (!req.params?.[0] || typeof req.params[0] !== 'object') {
return end(
ethErrors.rpc.invalidParams({
message: `Expected single, object parameter. Received:\n${JSON.stringify(
req.params,
)}`,
}),
);
}
const { address, network } = req.params[0];
res.result = await handleMmiSetAccountAndNetwork(
req.origin,
address,
network,
);
return end();
} catch (error) {
return end(error);
}
}

View File

@ -0,0 +1,34 @@
import { MESSAGE_TYPE } from '../../../../../../shared/constants/app';
const mmiSupported = {
methodNames: [MESSAGE_TYPE.MMI_SUPPORTED],
implementation: mmiSupportedHandler,
hookNames: {},
};
export default mmiSupported;
/**
* @typedef {object} MmiAuthenticateOptions
* @property {Function} mmiSupportedHandler
* This method simply returns true if this is Metamask Institutional
*/
/**
* @typedef {object} MmiSupportedParam
* @property {string} mmiSupported No parameters
*/
/**
* @param {import('json-rpc-engine').JsonRpcRequest<WatchAssetParam>} _req - The JSON-RPC request object.
* @param {import('json-rpc-engine').JsonRpcResponse<true>} res - The JSON-RPC response object.
* @param {Function} _next - The json-rpc-engine 'next' callback.
* @param {Function} end - The json-rpc-engine 'end' callback.
*/
async function mmiSupportedHandler(_req, res, _next, end) {
try {
res.result = true;
return end();
} catch (error) {
return end(error);
}
}

View File

@ -223,6 +223,7 @@
"@metamask-institutional/extension": "^0.1.3",
"@metamask-institutional/institutional-features": "^1.1.8",
"@metamask-institutional/portfolio-dashboard": "^1.1.3",
"@metamask-institutional/rpc-allowlist": "^1.0.0",
"@metamask-institutional/sdk": "^0.1.17",
"@metamask-institutional/transaction-update": "^0.1.21",
"@metamask/address-book-controller": "^3.0.0",

View File

@ -209,7 +209,18 @@ export default class InfoTab extends PureComponent {
ref={this.settingsRefs[0]}
className="info-tab__version-header"
>
{isBeta() ? t('betaMetamaskVersion') : t('metamaskVersion')}
{
///: BEGIN:ONLY_INCLUDE_IN(build-main,build-beta,build-flask)
isBeta() ? t('betaMetamaskVersion') : t('metamaskVersion')
///: END:ONLY_INCLUDE_IN
}
{
///: BEGIN:ONLY_INCLUDE_IN(build-mmi)
isBeta()
? t('betaMetamaskInstitutionalVersion')
: t('metamaskInstitutionalVersion')
///: END:ONLY_INCLUDE_IN
}
</div>
<div className="info-tab__version-number">
{this.state.version}

View File

@ -3769,6 +3769,13 @@ __metadata:
languageName: node
linkType: hard
"@metamask-institutional/rpc-allowlist@npm:^1.0.0":
version: 1.0.0
resolution: "@metamask-institutional/rpc-allowlist@npm:1.0.0"
checksum: c1c15822271b56fc5aeb2b86ed2bebd8a158cd3d3bbdda3c4beb2c6e5edf12df61e5e458e7b80482e41e28d93986b516124ee887529e3c311e8bc358fb577428
languageName: node
linkType: hard
"@metamask-institutional/sdk@npm:^0.1.14, @metamask-institutional/sdk@npm:^0.1.15, @metamask-institutional/sdk@npm:^0.1.16, @metamask-institutional/sdk@npm:^0.1.17":
version: 0.1.17
resolution: "@metamask-institutional/sdk@npm:0.1.17"
@ -23922,6 +23929,7 @@ __metadata:
"@metamask-institutional/extension": ^0.1.3
"@metamask-institutional/institutional-features": ^1.1.8
"@metamask-institutional/portfolio-dashboard": ^1.1.3
"@metamask-institutional/rpc-allowlist": ^1.0.0
"@metamask-institutional/sdk": ^0.1.17
"@metamask-institutional/transaction-update": ^0.1.21
"@metamask/address-book-controller": ^3.0.0