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

feat: enable Security Alerts API #11770

Merged
merged 5 commits into from
Oct 30, 2024
Merged

Conversation

vinistevam
Copy link
Contributor

@vinistevam vinistevam commented Oct 14, 2024

Description

This PR aims to enable the Security Alerts API. The environment variable SECURITY_ALERTS_API_ENABLED will be maintained and removed in a separate PR in a future release.
There is a fallback mechanism that uses the local PPOM to validate the request in the case of an issue with the API. This safeguard is designed to prevent any disruption or impact on the user experience.

Related issues

Fixes: https://github.com/MetaMask/mobile-planning/issues/1878

Manual testing steps

  1. Go to this test dapp
  2. trigger malicious transfer | malicious permit

Screenshots/Recordings

securty.alerts.api.webm

Before

After

Pre-merge author checklist

Pre-merge reviewer checklist

  • I've manually tested the PR (e.g. pull and build branch, run the app, test code being changed).
  • I confirm that this PR addresses all acceptance criteria described in the ticket it closes and includes the necessary testing evidence such as recordings and or screenshots.

Copy link
Contributor

CLA Signature Action: All authors have signed the CLA. You may need to manually re-run the blocking PR check if it doesn't pass in a few minutes.

@github-actions github-actions bot added the team-confirmations Push issues to confirmations team label Oct 14, 2024
@vinistevam vinistevam force-pushed the feat/enable-security-alerts-api branch from 32fbfce to cfbaf46 Compare October 14, 2024 09:19
@vinistevam vinistevam marked this pull request as ready for review October 16, 2024 09:26
@vinistevam vinistevam requested review from a team as code owners October 16, 2024 09:26
@vinistevam vinistevam added the Run Smoke E2E Triggers smoke e2e on Bitrise label Oct 16, 2024
Copy link
Contributor

github-actions bot commented Oct 16, 2024

https://bitrise.io/ Bitrise

✅✅✅ pr_smoke_e2e_pipeline passed on Bitrise! ✅✅✅

Commit hash: 74270bd
Build link: https://app.bitrise.io/app/be69d4368ee7e86d/pipelines/fcf153ed-59a8-4018-bf18-681716023e00

Note

  • You can kick off another pr_smoke_e2e_pipeline on Bitrise by removing and re-applying the Run Smoke E2E label on the pull request

matthewwalsh0
matthewwalsh0 previously approved these changes Oct 23, 2024
jpuri
jpuri previously approved these changes Oct 23, 2024
@sleepytanya
Copy link
Contributor

sleepytanya commented Oct 24, 2024

@vinistevam Just posting an update so you know what's happening!

  1. iOS builds for some reason fail on current branch so I haven't been able to verify iOS yet
    https://app.bitrise.io/build/7c0e66dc-ea96-4e1a-a271-ed184067e581
    https://app.bitrise.io/app/be69d4368ee7e86d/installable-artifacts/90117534d8213616

  2. Android:

    I'm seeing 'unable to find conversion rate' and it seems like on prod this error doesn't occur (I will re-check this):

Screenshot 2024-10-23 at 21 10 16
PPOM:
  • Everything works on Ethereum
1.mp4
2.mp4
3.mov
  • BNB - Malicious Transfer (USDC) not flagged
  • Arbitrum - Sign Permit, Malicious Set Approval for All not flagged
  • zkSync - Sign Permit, Malicious Permit and Malicious Seaport not flagged (some of them could be ignored as they are not supported on zkSync yet?)
Screenshot 2024-10-23 at 21 21 26

@sleepytanya
Copy link
Contributor

iOS build https://app.bitrise.io/app/be69d4368ee7e86d/installable-artifacts/612c067798c34679

Same PPOM functionality as on Android:

BNB - Malicious Transfer (USDC) not flagged
Arbitrum - Sign Permit, Malicious Set Approval for All not flagged
zkSync - Sign Permit, Malicious Permit and Malicious Seaport not flagged (some of them could be ignored as they are not supported on zkSync yet?)

@vinistevam vinistevam dismissed stale reviews from matthewwalsh0 and jpuri via 162e4cd October 24, 2024 11:10
@vinistevam vinistevam added Run Smoke E2E Triggers smoke e2e on Bitrise and removed Run Smoke E2E Triggers smoke e2e on Bitrise labels Oct 25, 2024
Copy link
Contributor

github-actions bot commented Oct 25, 2024

https://bitrise.io/ Bitrise

✅✅✅ pr_smoke_e2e_pipeline passed on Bitrise! ✅✅✅

Commit hash: 28c22cb
Build link: https://app.bitrise.io/app/be69d4368ee7e86d/pipelines/61ab869d-9073-4448-85b7-819062e826da

Note

  • You can kick off another pr_smoke_e2e_pipeline on Bitrise by removing and re-applying the Run Smoke E2E label on the pull request

Copy link

@vinistevam
Copy link
Contributor Author

Tests on main:
BNB: Malicious Transfer (USDC) not flagged

ppom_main_bnb.webm

zkSync: Malicious Permit and Malicious Seaport not flagged (Same as on my branch)

ppom_zksync.webm

Tests on feat/enable-security-alerts-api branch:
Arbitrum - Malicious Set Approval for All - flagged

ppom_arbitrum_branch.webm

Sign Permit is not working on main as well
cc. @sleepytanya

@vinistevam vinistevam added this pull request to the merge queue Oct 30, 2024
Merged via the queue into main with commit 1bebdb6 Oct 30, 2024
43 checks passed
@vinistevam vinistevam deleted the feat/enable-security-alerts-api branch October 30, 2024 15:02
@github-actions github-actions bot locked and limited conversation to collaborators Oct 30, 2024
@metamaskbot metamaskbot added the release-7.35.0 Issue or pull request that will be included in release 7.35.0 label Oct 30, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
release-7.35.0 Issue or pull request that will be included in release 7.35.0 Run Smoke E2E Triggers smoke e2e on Bitrise team-confirmations Push issues to confirmations team
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants