Snap and Dapp Permissions - MetaMask/metamask-snaps-beta GitHub Wiki

The MetaMask Snaps version of the extension uses our EIP 2255 wallet permissions system to its full extent.

This means that, in order to use any sensitive method/API — i.e. a restricted method — an untrusted domain must request and be granted the permission for it first. Code belongs to an untrusted domain if it can communicate with MetaMask and is not in the MetaMask background or UI. This includes:

  • Snaps - i.e. a plugin running in a SES container in the MetaMask background
  • Dapps

Requesting Permissions

If your Snap needs any permissions by default on install, they must be specified in the Snap manifest under web3Wallet.initialPermissions.

It is the Snap developer's responsibility to populate this object and format it per the IRequestedPermissions interface.

The Snap can request further permissions dynamically after install using wallet_requestPermissions as specified in EIP 2255.

See the examples in the snaps-cli repository for further details.

A Note on Dapps

As a dapp, calling ethereum.send('eth_requestAccounts') (or its deprecated alias, ethereum.enable()) will only get you the eth_accounts permission. We encourage you to skip this method completely in your connection flow, and request eth_accounts plus whatever plugins/other methods you need.

Getting Permissions

To know whether you possess a certain permission, send a wallet_getPermissions request and search over the returned array of permissions objects. The permission name is indicated by the parentCapability field.

You can also attempt to call the corresponding method. If you don't have the permission, an EIP 1193 Unauthorized error will be returned, with error.code === 4001. You can catch that error, then try to request the necessary permissions.

  • Keep in mind that some permissions are contingent. For example, eth_accounts is required for any method that makes use of a user account.
  • All of MetaMask's RPC errors are standardized per JSON RPC 2.0 and EIP 1193, and we try to make them as useful as possible. See this library for more details.

If an untrusted domain needs to know if it's previously been granted a permission at all - even if it's been removed - it has to keep track of that information itself.

Adding Additional Restricted Methods to MetaMask

To add additional permissions you can request to your custom fork of MetaMask, you will need to add them to the restrictedMethods object in the permissions controller. These entries follow the format specified by rpc-cap.