Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding metrics events for EIP-1559 V2 flow #13329

Merged
merged 34 commits into from
Feb 1, 2022
Merged
Changes from 1 commit
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
921e33f
Capturing default gas estimates in txMeta and passing it to metrics
jpuri Jan 24, 2022
ea70667
Adding flag for V2 transactions in metrics
jpuri Jan 24, 2022
82468bc
Merge branch 'develop' of github.com:MetaMask/metamask-extension into…
jpuri Jan 24, 2022
3986a1b
Improvements
jpuri Jan 24, 2022
d075dac
Improvements
jpuri Jan 24, 2022
857065b
Improvements
jpuri Jan 24, 2022
bd89570
Improvements
jpuri Jan 24, 2022
dc13c98
Improvements
jpuri Jan 24, 2022
262ba46
Merge branch 'develop' of github.com:MetaMask/metamask-extension into…
jpuri Jan 25, 2022
4e2918e
fix
jpuri Jan 25, 2022
4cd7ae1
Merge branch 'develop' of github.com:MetaMask/metamask-extension into…
jpuri Jan 26, 2022
f405942
fix build
jpuri Jan 26, 2022
cac7841
fix build
jpuri Jan 26, 2022
91c6a7a
fix build
jpuri Jan 26, 2022
4b0f7a6
Merge branch 'develop' of github.com:MetaMask/metamask-extension into…
jpuri Jan 28, 2022
a2634dd
Adding metrics events for EIP-1559 V2 flow
jpuri Jan 17, 2022
c4a74f4
merge
jpuri Jan 24, 2022
28d6a71
fixes
jpuri Jan 24, 2022
f73e96b
fix
jpuri Jan 25, 2022
f1fbd45
Update app/scripts/controllers/transactions/index.js
jpuri Jan 24, 2022
fdbaeb4
Revert changes
jpuri Jan 27, 2022
6e29d04
Revert changes
jpuri Jan 27, 2022
0fe3280
fixes
jpuri Jan 27, 2022
547689f
fix
jpuri Jan 27, 2022
dfc5d46
fix
jpuri Jan 27, 2022
664e68a
fix
jpuri Jan 27, 2022
e326ca4
fix
jpuri Jan 27, 2022
05e5c15
fix
jpuri Jan 27, 2022
6196d5a
fixes
jpuri Jan 28, 2022
2bbcd62
fix build
jpuri Jan 28, 2022
0fa7ae5
merge
jpuri Jan 31, 2022
e8d554a
fix build
jpuri Jan 31, 2022
86ef58c
fix
jpuri Jan 31, 2022
bf06141
fix build
jpuri Feb 1, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Improvements
  • Loading branch information
jpuri committed Jan 24, 2022
commit 3986a1bd142b81f55d8101ce46f88d84632f4892
30 changes: 22 additions & 8 deletions app/scripts/controllers/transactions/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -544,6 +544,7 @@ export default class TransactionController extends EventEmitter {
txMeta.originalGasEstimate = defaultGasLimit;
}
txMeta.defaultGasEstimates = {
defaultEstimate: txMeta.userFeeLevel,
gas: txMeta.txParams.gas,
gasPrice: txMeta.txParams.gasPrice,
maxFeePerGas: txMeta.txParams.maxFeePerGas,
Expand Down Expand Up @@ -1480,7 +1481,7 @@ export default class TransactionController extends EventEmitter {
}
}

_buildEventFragmentProperties(txMeta, extraParams) {
async _buildEventFragmentProperties(txMeta, extraParams) {
const {
type,
time,
Expand Down Expand Up @@ -1510,9 +1511,18 @@ export default class TransactionController extends EventEmitter {
}

if (defaultGasEstimates) {
gasParams.defaultGasEstimates = this._getGasValuesInGWEI(
defaultGasEstimates,
);
const estimateType = defaultGasEstimates.defaultEstimate;
const { gasFeeEstimates } = await this._getEIP1559GasFeeEstimates();
gasParams.default_gas_estimates = this._getGasValuesInGWEI({
gas: txMeta.defaultGasEstimates.gas,
gas_price: txMeta.defaultGasEstimates.gasPrice,
max_fee_per_gas:
gasFeeEstimates[estimateType]?.suggestedMaxFeePerGas ||
txMeta.defaultGasEstimates.maxFeePerGas,
max_priority_fee_per_gas:
gasFeeEstimates[estimateType]?.suggestedMaxPriorityFeePerGas ||
txMeta.defaultGasEstimates.maxPriorityFeePerGas,
});
}

if (estimateSuggested) {
Expand All @@ -1525,15 +1535,19 @@ export default class TransactionController extends EventEmitter {

const gasParamsInGwei = this._getGasValuesInGWEI(gasParams);

const { eip1559V2Enabled: eip1559V2 } = this.preferencesStore.getState();
let eip1559Version = 'null';
if (txMeta.txParams.maxFeePerGas) {
const { eip1559V2Enabled } = this.preferencesStore.getState();
eip1559Version = eip1559V2Enabled ? '2' : '1';
}

const properties = {
chain_id: chainId,
referrer,
source,
network,
type,
eip1559V2,
eip_1559_version: eip1559Version,
};

const sensitiveProperties = {
Expand Down Expand Up @@ -1677,14 +1691,14 @@ export default class TransactionController extends EventEmitter {
* @param {TransactionMetaMetricsEventString} event - the name of the transaction event
* @param {Object} extraParams - optional props and values to include in sensitiveProperties
*/
_trackTransactionMetricsEvent(txMeta, event, extraParams = {}) {
async _trackTransactionMetricsEvent(txMeta, event, extraParams = {}) {
if (!txMeta) {
return;
}
const {
properties,
sensitiveProperties,
} = this._buildEventFragmentProperties(txMeta, extraParams);
} = await this._buildEventFragmentProperties(txMeta, extraParams);

// Create event fragments for event types that spawn fragments, and ensure
// existence of fragments for event types that act upon them.
Expand Down