From 8d7aa1e17f321c5500abbe2984ddfe5b92442851 Mon Sep 17 00:00:00 2001 From: Nils Codes Date: Tue, 3 Sep 2024 13:47:06 -0700 Subject: [PATCH] CIP-0095 | Misspelling of `DeprecatedCertificate` (#875) * Correcting a typo in implementation details for error types for CIP-0095 Minor wording improvements to the standard committed alongside. * CIP-0095 | Reordered the newly introduced DRep data types to make their dependency clearer The ordering now matches the order in CIP-0105. Also updated the first paragraph to a more expressive wording. --- CIP-0095/README.md | 50 +++++++++++++++++++++++----------------------- 1 file changed, 25 insertions(+), 25 deletions(-) diff --git a/CIP-0095/README.md b/CIP-0095/README.md index 01c80c0eb6..b9930b1073 100644 --- a/CIP-0095/README.md +++ b/CIP-0095/README.md @@ -44,11 +44,11 @@ For the many contributors to this proposal, see [Acknowledgements](#acknowledgem ## Motivation: why is this CIP necessary? CIP-1694 introduces many new concepts, entities and actors to Cardano; -describing their implementation at the ledger level. Yet, for most ecosystem -participants low level details are abstracted away by tooling. Creating a need -for such tooling, to allow the utilization of new ledger features. This -specification allows for creation of web-based tools for the utilization of -CIP-1694's governance features. +describing their implementation at the ledger level. This creates the need for +new tooling with respect to governance. For the average ecosystem participant, +the details should be abstracted away, enabling them to leverage the new ledger +features more effectively. This specification allows for creation of web-based +tools for the utilization of CIP-1694's governance features. Whilst CIP-30 facilitated the launch of dApp development on Cardano, it's functionality is limited in scope. It was written well before the emergence of @@ -123,24 +123,24 @@ extending the API (as a plain integer, without padding). For example: #### CIP-95 Data Types -#### DRepID +##### PubDRepKey ```ts -type DRepID = string; +type PubDRepKey = string; ``` -A hex-encoded string representing a registered DRep's ID which is a Blake2b-224 -hash digest of a 32 byte Ed25519 public key, as described in -[CIP-1694 Registered DReps](https://github.com/cardano-foundation/CIPs/blob/430f64d3e86dd67903a6bf1e611c06e5343072f3/CIP-1694/README.md#registered-dreps). +A hex-encoded string representing 32 byte Ed25519 DRep public key, as described +in [CIP-0105 | Conway Era Key Chains for HD Wallets](https://github.com/cardano-foundation/CIPs/blob/master/CIP-0105/README.md). -##### PubDRepKey +#### DRepID ```ts -type PubDRepKey = string; +type DRepID = string; ``` -A hex-encoded string representing 32 byte Ed25519 DRep public key, as described -in [CIP-0105 | Conway Era Key Chains for HD Wallets](https://github.com/cardano-foundation/CIPs/blob/master/CIP-0105/README.md). +A hex-encoded string representing a registered DRep's ID which is a Blake2b-224 +hash digest of the above mentioned 32 byte Ed25519 public key, as described in +[CIP-1694 Registered DReps](https://github.com/cardano-foundation/CIPs/blob/430f64d3e86dd67903a6bf1e611c06e5343072f3/CIP-1694/README.md#registered-dreps). ##### PubStakeKey @@ -154,7 +154,7 @@ credential. ### Error Types For the methods described in -[Governance Extension API](#governance-extension-api), we inherent APIError, +[Governance Extension API](#governance-extension-api), we inherit APIError, DataSignError and TxSignError from [CIP-30's Error Types](https://github.com/cardano-foundation/CIPs/tree/master/CIP-0030#error-types). @@ -195,13 +195,13 @@ type APIError { We repurpose this error type from CIP-30, extending it's functionality. We extend the `ProofGeneration` error code to also include cases where DRep secret -key is not available. We also add one new error code `DepreciatedCertificate`. +key is not available. We also add one new error code `DeprecatedCertificate`. ```ts TxSignErrorCode = { ProofGeneration: 1, UserDeclined: 2, - DepreciatedCertificate: 3, + DeprecatedCertificate: 3, }; type TxSignError = { code: TxSignErrorCode; @@ -213,8 +213,8 @@ type TxSignError = { unable to sign the transaction. This is because the wallet does have some of the private keys required. - `UserDeclined` - User declined to sign the transaction. -- `DepreciatedCertificate` - Returned regardless of user consent if the - transaction contains a depreciated certificate. +- `DeprecatedCertificate` - Returned regardless of user consent if the + transaction contains a deprecated certificate. #### [DataSignError](https://github.com/cardano-foundation/CIPs/tree/master/CIP-0030#datasignerror) @@ -381,8 +381,8 @@ should be able to be recognized by supporting wallets. ##### Unsupported Inspection -In the Conway ledger era two certificate types are depreciated `genesis_key_delegation` and `move_instantaneous_rewards_cert`. -If the wallet receives a transaction containing a depreciated certificate it should return a `TxSignError` with an error code of `DepreciatedCertificate`. +In the Conway ledger era two certificate types are deprecated `genesis_key_delegation` and `move_instantaneous_rewards_cert`. +If the wallet receives a transaction containing a deprecated certificate it should return a `TxSignError` with an error code of `DeprecatedCertificate`. | Index | Unsupported Pre-Conway Certificates | | ----- | ----------------------------------- | @@ -411,7 +411,7 @@ endpoint before building the final transaction. | `APIError` | `AccountChange` | `true` or `false` | Returned if wallet has changed account, meaning connection should be reestablished. | | `TxSignError` | `ProofGeneration` | `false` | Returned if user has accepted transaction to sign, but the wallet is unable to sign because it does not have the required key(s). | | `TxSignError` | `UserDeclined` | `true` or `false` | Returned if user has declined to sign the transaction. | -| `TxSignError` | `DepreciatedCertificate` | `true` or `false` | Returned regardless of user consent if the transaction contains a depreciated certificate. | +| `TxSignError` | `DeprecatedCertificate` | `true` or `false` | Returned regardless of user consent if the transaction contains a deprecated certificate. | If `partialSign` is `true`, the wallet only tries to sign what it can. If @@ -556,7 +556,7 @@ wallet has already been made via 3. **Inspect and Sign:** The app passes the transaction to the wallet via `.signTx()`. The wallet inspects the content of the transaction, informing the user of the client app's intension. If the user confirms that they are - happy to sign, the wallet returns the appropriate witnesses, of payment key + willing to sign, the wallet returns the appropriate witnesses, of payment key and stake key. 4. **Submit:** The app will add the provided witnesses into the transaction body and then pass the witnessed transaction back to the wallet for submission via @@ -635,7 +635,7 @@ CIP-1694; Ada holders and DReps, this decision was three fold. Primarily, this is to allow these groups to utilize a web-based client to participate in Cardano's governance. These groups are likely less comfortable utilizing command-line interfaces than other groups, thus making alternatives from them is -a priority. Secondly, the other types of actor (constitution committee member +a priority. Secondly, the other types of actor (constitutional committee members and SPOs) are identified by different credentials than Ada holders and DReps, making their integration in this specification more complex. These alternative credentials are unlikely to be stored within standard wallet software which may @@ -666,7 +666,7 @@ cold key setup. Hot and cold keys are not suited for standard light wallets. Genesis key delegation and move instantaneous reward certificates (see in [Shelley spec](https://github.com/IntersectMBO/cardano-ledger/blob/0738804155245062f05e2f355fadd1d16f04cd56/shelley-ma/shelley-ma-test/cddl-files/shelley-ma.cddl#L117#L118)) -are not supported here because they have been depreciated in the Conway ledger +are not supported here because they have been deprecated in the Conway ledger era. Furthermore, due to the lack of accessibility (require access to genesis keys) for these certificates it is extremely unlikely any CIP-30 implementations supported these.