From ff2c3126600932c6193711c319de5df95b9cd9b4 Mon Sep 17 00:00:00 2001 From: leo42 Date: Wed, 26 Jun 2024 11:44:31 +0300 Subject: [PATCH] CIP-0106? | Web-Wallet Bridge - Multisig wallets (#617) * Initial draft completed * Update CIP-130/README.md Co-authored-by: Adam Dean <63186174+Crypto2099@users.noreply.github.com> * Update CIP-130/README.md Co-authored-by: Adam Dean <63186174+Crypto2099@users.noreply.github.com> * renaming CPI folder * Update CIP-XXXX/README.md Co-authored-by: Robert Phair * remove exes whitespaces Co-authored-by: Robert Phair * Rework as a CIP-30 Extension * small improvment * standardising title with wallet extension CIPs * applying official CIP number 106 * Rename and mark reference implementation as complete * rename * Update CIP-0106/README.md Co-authored-by: Ryan <44342099+Ryun1@users.noreply.github.com> * Update CIP-0106/README.md Co-authored-by: Ryan <44342099+Ryun1@users.noreply.github.com> * Update CIP-0106/README.md Co-authored-by: Ryan <44342099+Ryun1@users.noreply.github.com> * remove duplicate sections * Update README.md * Update README.md * add namespacing * Update README.md * needs seminal pull request as Discussion Co-authored-by: Ryan <44342099+Ryun1@users.noreply.github.com> * Add implementors , remove rational for required data * Update CIP-0106/README.md Co-authored-by: Robert Phair * Update README.md * Changed Removed Endpoints to Disabled Endpoints * very minor formatting: white space justification * fix spelling mistake in CIP title --------- Co-authored-by: Adam Dean <63186174+Crypto2099@users.noreply.github.com> Co-authored-by: Robert Phair Co-authored-by: Ryan <44342099+Ryun1@users.noreply.github.com> --- CIP-0106/README.md | 146 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 146 insertions(+) create mode 100644 CIP-0106/README.md diff --git a/CIP-0106/README.md b/CIP-0106/README.md new file mode 100644 index 0000000000..a6289c366d --- /dev/null +++ b/CIP-0106/README.md @@ -0,0 +1,146 @@ +--- +CIP: 106 +Title: Web-Wallet Bridge - Multisig wallets +Status: Proposed +Category: Wallets +Authors: + - Leo +Implementors: + - BroClanWallet +Discussions: + - https://github.com/cardano-foundation/CIPs/pull/617 +Created: 2023-10-12 +License: CC-BY-4.0 +--- + +## Abstract + +This document describes a CIP-30 extension allowing webpages (i.e. dApps) to interface with Cardano Multisig-wallets. This document is a work in progress and is not yet finalized. It is expected to be updated as the ecosystem evolves. + +## Motivation: why is this CIP necessary? + +In order to facilitate future dApp development, we will need a way for dApps to communicate with multisig wallets, given the unique complexities of native script based addresses. Special provisions need to be made to make the connector compatible with them. + +Specifically, apps building transactions need to be able to get the following information from the wallet: +- Script descriptor + - Any transaction consuming a UTXO from a Plutus-based address must attach the corresponding script. +- `ScriptRequirements` + - The `TxContext` that is required to be able to validate the transaction. It encompasses all the possible combinations of requirements for the transaction to be valid, as such it is represented by an array of `ScriptRequirement` objects. +- Change Datum + - The datum that will be used as the change output for the transaction. This is required for wallets based on Plutus V2 and before, as the change output must contain a datum to be valid and spendable. + +Additionally, apps need to be able to submit a transaction to the wallet for signing in an asynchronous manner, as gathering of signatures can take a long time and each wallet provider will have its own way of handling this process. + +Finally, the signTx() and signData() endpoints will have to be disabled when using this extension since they are not compatible with native script based addresses. + +## Specification + +### Data Types + +#### KeyHash + +A hex-encoded string of the corresponding bytes. This represents the hash of the public key used to sign transactions. + +```ts +type KeyHash = String +``` + +#### ScriptRequirements + +```ts +type ScriptRequirementsCode = { + Signer: 1, + Before: 2, + After: 3, +} +type ScriptRequirement = { + code: ScriptRequirementsCode, + value: KeyHash|number, +} +``` + +### Aditional Error Types + +#### CompletedTxError + +```ts +CompletedTxErrorCode = { + NotFound: 1, + NotReady: 2 +} +``` + +* NotFound - The transaction with the given id was not found. +* NotReady - The transaction with the given id is not ready yet. + +### Additional API Endpoints + +#### api.cip106.getCollateralAddress(): Promise\
+ +For Plutus V2 and later, partial collateral is supported. This function returns an address that can be used to add collateral to a transaction. The address returned must be owned by one of the signers in the list of signers returned by `api.getScriptRequirements()`. + +dApp developers can choose to use this address to add collateral to a transaction, or they can choose to use the `api.getCollateral()` function to get a list of UTXOs that can be used as collateral. If the dApp chooses to use this address, they must ensure that the address is not used for any other purpose, as the wallet may be using it to track collateral, and that the collateral return address is the same one. + +#### api.cip106.getScriptRequirements: Promise\ + +Errors: `APIError` + +Returns a list of ScriptRequirements that will be used to validate any transaction sent to the wallet. + +#### api.cip106.getScript(): Promise\> + +Errors: `APIError` + +Returns the CBOR-encoded native script that controls this wallet. + +#### api.cip106.submitUnsignedTx(tx: cbor\): Promise\ + +Errors: `APIError`, `TxError` + +Submits a transaction to the wallet for signing. The wallet should check that the transaction is valid, gather the required signatures, compose the finalized transaction, and submit the transaction to the network. If the transaction is valid and the wallet is able to sign it, the wallet should return the transaction hash. If the transaction is invalid or the wallet is unable to sign it, the wallet should throw a `TxError` with the appropriate error code. The wallet should not submit the transaction to the network if it is invalid or the wallet is unable to sign it. + +If the transaction contains hidden metadata, the wallet should not submit the transaction when it is ready, but return it to the dApp when the dApp calls the `getCompletedTx` function. + +#### api.cip106.getCompletedTx(txId: hash32): Promise\[,cbor>] + +Errors: `APIError`, `CompletedTxError` + +If the transaction is not ready, the wallet should throw a `CompletedTxError` with the appropriate error code. If the transaction is ready, the wallet should return the CBOR-encoded transaction and the signatures. + +### Altered API endpoints + +#### api.getCollateral(params: { amount: cbor\ }): Promise\ + +Native script based addresses cannot provide collateral for transactions. Using this function, dApps can request the wallet to provide collateral for a transaction. The collateral must be a pure ADA UTXO, held by one of the signers in the list of signers returned by `api.getScriptRequirements()`. + +### Disabled API endpoints + +When connecting to a wallet using this extension the following endpoints will be disabled: + +#### `api.signTx(tx: cbor, partialSign: bool = false): Promise>` + + +#### `api.signData(addr: Address, payload: Bytes): Promise` + +These endpoints should return an error if called when using this extension. + +## Rationale: how does this CIP achieve its goals? + +See justification and explanations provided with each API endpoint. + + +## Path to Active + +### Acceptance Criteria + +- [ ] The interface is implemented and supported by multiple wallet providers. +- [ ] The interface is used by multiple dApps to interact with wallet providers. + +### Implementation Plan + +- [x] Provide some reference implementation of wallet providers + - [leo42/BroClanWallet](https://github.com/leo42/BroClanWallet) + +## Copyright + +This CIP is licensed under [CC-BY-4.0](https://creativecommons.org/licenses/by/4.0/legalcode).