Skip to content

Commit

Permalink
CIP-0095 | Misspelling of DeprecatedCertificate (#875)
Browse files Browse the repository at this point in the history
* 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.
  • Loading branch information
nilscodes authored Sep 3, 2024
1 parent 76d0698 commit 8d7aa1e
Showing 1 changed file with 25 additions and 25 deletions.
50 changes: 25 additions & 25 deletions CIP-0095/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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

Expand All @@ -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).

Expand Down Expand Up @@ -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;
Expand All @@ -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)

Expand Down Expand Up @@ -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 |
| ----- | ----------------------------------- |
Expand Down Expand Up @@ -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. |
<!-- prettier-ignore-stop -->
If `partialSign` is `true`, the wallet only tries to sign what it can. If
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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.
Expand Down

0 comments on commit 8d7aa1e

Please sign in to comment.