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

CIP-0021 | Conway update #687

Merged
merged 3 commits into from
Apr 22, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
91 changes: 73 additions & 18 deletions CIP-0021/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,11 +45,17 @@ Transactions must be serialized in line with suggestions from [Section 3.9 of CB

See the RFC for details.

### Tags in sets

Conway introduced optional 258 tags in certain items that are considered sets semantically but encoded as arrays in CBOR. HW wallets will support this optional encoding, but it must be consistent across the transaction: either there are no tags 258 in sets, or there are such tags everywhere (as described in the CDDL specification).

### Transaction body

#### Unsupported entries

The transaction body entry `6 : update` must not be included.
The following transaction body entries must not be included:
* `6 : update`
* `20 : proposal procedures`

#### Integers

Expand All @@ -72,10 +78,14 @@ The number of the following transaction elements individually must not exceed `U
- reference inputs in transaction body
- the total number of witnesses

For voting procedures, it is only allowed to include a single voter with a single voting procedure.

#### Optional empty lists and maps

Unless mentioned otherwise in this CIP, optional empty lists and maps must not be included as part of the transaction body or its elements.

Since Conway, the [CDDL specification](https://github.com/intersectmbo/cardano-ledger/tree/master/eras/conway/impl/cddl-files) is stricter, so many arrays are now treated as non-empty sets, and some maps are required to be non-empty. HW wallets enforce this in many cases.

#### Outputs

A new, "post Alonzo", output format has been introduced in the Babbage ledger era which uses a map instead of an array to store the output data. For now, both the "legacy" (array) and "post Alonzo" (map) output formats are supported by HW wallets but we encourage everyone to migrate to the "post Alonzo" format as support for the "legacy" output format might be removed in the future. Both formats can be mixed within a single transaction, both in outputs and in the collateral return output.
Expand All @@ -94,34 +104,36 @@ Since multiassets (`policy_id` and `asset_name`) are represented as maps, both n

#### Certificates

Certificates of type `genesis_key_delegation` and `move_instantaneous_rewards_cert` are not supported and must not be included.
Certificates of the following types are not supported and must not be included:
* `genesis_key_delegation`
* `move_instantaneous_rewards_cert`
* `stake_vote_deleg_cert`
* `stake_reg_deleg_cert`
* `vote_reg_deleg_cert`
* `stake_vote_reg_deleg_cert`

If a transaction contains a pool registration certificate, then it must not contain:
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why do we not add any protections like this around constitutional committee keys or DRep keys

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The main reason for pool registration certificate restrictions is that pool owners are signing them with stake keys, which also sign other elements of the transaction (e.g. withdrawals and other certificates), and that's a security risk: the transactions are not created by them and so they might contain, from their viewpoint, third-party elements --- they can't easily distinguish whether a key hash used in a withdrawal belongs to them or not, and a HW wallet does not see the whole tx at once, so cannot warn them that the same stake key hash is used in several places.

With DRep or constitutional committee keys, only votes are signed, nothing else AFAIK.

Copy link
Contributor

@gitmachtl gitmachtl Apr 4, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

With DRep or constitutional committee keys, only votes are signed, nothing else AFAIK.

@janmazak @Ryun1
I have not tested this, but when you do a DRep deregistration, you could also sneak in a vote too. Not sure what the protocol is doing with that. Or the other way round, you just wanna vote, but a deregistration certificates gets sneaked in. So theses two things should not happen within one transaction imo.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

DRep keys are used for votes, registration certs, update certs and resignation certs.

CC Hot keys are only used for voting.
CC Cold keys are used for authorising hot cert and resign cert.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Ryun1 do you think its worth to check if there is a vote together with a cert in the transaction?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@gitmachtl

to follow the precedent of how stake key signing is handled, yes it makes sense for the check.

But practically speaking, I don't think this is a significant issue, so IMO it is probably fine.
It is quite easy for a DRep to re-register.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Ryun1 i was more thinking in a way that if online services provide the feature to easy register as a DRep, if they could sneak in a vote for there proposal f.e. and the user would not see that directly.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes this would be easy to do over a dApp.
but of course on the hardware wallet device it still shows the vote to the user, at signing time.


- any other certificate;
- any withdrawal;
- mint entry;
- any output containing datum hash;
- any output containing datum, datum hash or reference script;
- script data hash;
- any collateral input;
- any required signer.
- any required signer;
- collateral return output;
- total collateral;
- reference inputs;
- voting procedures;
- treasury value;
- donation value.

It is allowed to arbitrarily combine other supported certificate types.

Certificate stake credentials must be:
- only key hashes in ordinary (single-sig) transactions;
- only script hashes in multi-sig transactions.
(There is no restriction for transactions involving Plutus.)

#### Withdrawals

Since withdrawals are represented as a map of reward accounts, withdrawals also need to be sorted in accordance with the specified canonical CBOR format. A transaction must not contain duplicate withdrawals.

Withdrawal reward accounts must be:
- only based on key hashes in ordinary (single-sig) transactions;
- only based on script hashes in multi-sig transactions.
(There is no restriction for transactions involving Plutus.)

#### Auxiliary data

HW wallets do not serialize auxiliary data because of their complex structure. They only include the given auxiliary data hash in the transaction body. The only exception is Catalyst voting registration because it requires a signature computed by the HW wallet.
Expand All @@ -144,6 +156,20 @@ The specified canonical CBOR format is consistent with how certain other data ar

### Transaction body

#### Credentials

Generally, HW wallets require that any key hash credential (and withdrawal address too) is given by the derivation path of the key (otherwise the user will not be aware that the key belongs to his wallet). This does not apply to Plutus transactions where HW wallets instead aim for maximum flexibility at the cost of users being potentially misled. (It is very hard to foresee how Plutus script authors would use various transaction elements and any restriction applied by HW wallets might break a use case which is otherwise perfectly sound and safe.)

When signing a transaction, Ledger and Trezor use a _transaction signing mode_ that describes upfront what the intent is
(the software wallet is responsible for choosing an appropriate mode). The transaction is then validated according to the mode.
There are, in principle, four options:
* _Stake pool registration transaction_. Stake pool registration certificates are signed on their own, the transaction should contain nothing that is not necessary.
* _Ordinary transaction_. Credentials must be given as key paths.
* _Multisig transaction_. Credentials must be script hashes; only [multisig keys](https://github.com/cardano-foundation/CIPs/blob/master/CIP-1854/README.md) are allowed.
* _Plutus transaction_. The only mode that allows elements related to running Plutus scripts (script data hash etc.). No extra restrictions on transaction elements or their combinations. The drawback is that more is shown to the user (e.g. witnesses are not hidden as in ordinary transactions). Please only use this mode if no other mode is sufficient.

This brief description does not aim to capture the full complexity of signing modes; always verify that transactions you aim to construct are supported by other tools you will rely on (hardware wallets, software wallets, command-line tools like [`cardano-hw-cli`](https://github.com/vacuumlabs/cardano-hw-cli) etc.).

#### Multiassets

Allowing duplicate `policy_id`s (or `asset_name`s) might lead to inconsistencies between what is displayed to the user and how nodes and other tools might interpret the duplicate keys, i.e. all policies (or asset names) would be shown to the user, but nodes and other tools might eventually interpret only a single one of them.
Expand All @@ -160,9 +186,10 @@ Similarly to multiassets, allowing duplicate withdrawals might lead to inconsist

The specified auxiliary data format was chosen in order to be compatible with other Cardano tools, which mostly use this serialization format.

### Backwards compatibility
### Stake key signing vs other keys

Tools interacting with HW wallets might need to be updated in order to continue being compatible with HW wallets because of canonical CBOR serialization format, which is being enforced since multi-sig support.
A DRep witness can serve for both certificates and votes at the same time. Unlike with stake keys (where combining pool registration with e.g. withdrawals is forbidden), no restriction is imposed on the combination of certificates and votes.
We think that votes and DRep certificates are rare and substantially distinguished parts of a transaction, signed by DRep keys which are likely to only be used by users with deep enough understanding (and, unlike stake keys, are always visible when providing witnesses). A single vote or a DRep certificate is unlikely to have a major effect (esp. not on the loss of funds). If submitting unintended votes turns out to be a problem, it is likely better to solve it on the level of Cardano blockchain ledger by providing a mechanism allowing for replacing or cancelling votes.

## Path to Active

Expand All @@ -173,8 +200,36 @@ Tools interacting with HW wallets might need to be updated in order to continue
### Implementation Plan

- [x] Tools exist which can be used to validate or transform transactions into a HW wallet compatible format if possible:
- [x] [`cardano-hw-interop-library`](https://github.com/vacuumlabs/cardano-hw-interop-lib)
- [x] [`cardano-hw-cli'](https://github.com/vacuumlabs/cardano-hw-cli) (which uses the interop library)
- [x] [`cardano-hw-interop-library`](https://github.com/vacuumlabs/cardano-hw-interop-lib)
- [x] [`cardano-hw-cli`](https://github.com/vacuumlabs/cardano-hw-cli) (which uses the interop library)

## Restrictions for specific hardware devices

The following list of features with missing support on particular hardware devices is subject to occasional changes. Some features might be added, but some could also be removed (e.g. if they take too much space needed for other features).

#### Ledger: Nano S Plus, Nano X, Stax

Everything described here as allowed should (eventually) work on these devices.

#### Ledger: Nano S

Missing features:
- signing operational certificates
- derivation of native script hashes
- stake pool registration and retirement
- display of certain details of Byron addresses (though addresses themselves are supported)

#### Trezor

Missing features:
- derivation of stake pool cold keys
- signing operational certificates
- signing pool registration certificates as operator (only as owner is allowed)
- derivation of DRep and constitutional committee keys
- DRep certificates (registration, retirement, update)
- constitutional committee certificates
- voting procedures
- treasury and donation elements of transactions

## Copyright

Expand Down