## Description
- Update the schema of `SuiTransactionResponse` to make all fields
optional and add a new `digest` field
- Add `SuiTransactionResponseOptions`
- Update the `sui_getTransaction` and `sui_multiGetTransaction` to take
in `SuiTransactionResponseOptions`
- rewrite the `sui_multiGetTransaction` logic
Here's the new interface
```
pub struct SuiTransactionResponseOptions {
/// Whether to show transaction input data. Default to be False
pub show_input: bool,
/// Whether to show transaction effects. Default to be False
pub show_effects: bool,
/// Whether to show transaction events. Default to be False
pub show_events: bool,
/// Whether to show checkpoint sequence number. Default to be False
pub show_checkpoint: bool,
/// Whether to show timestamp. Default to be False
pub show_timestamp: bool,
}
#[derive(Serialize, Deserialize, Debug, JsonSchema, Clone, Default)]
#[serde(rename_all = "camelCase", rename = "TransactionResponse")]
pub struct SuiTransactionResponse {
pub digest: TransactionDigest,
/// Transaction input data
#[serde(skip_serializing_if = "Option::is_none")]
pub transaction: Option<SuiTransaction>,
#[serde(skip_serializing_if = "Option::is_none")]
pub effects: Option<SuiTransactionEffects>,
#[serde(skip_serializing_if = "Option::is_none")]
pub events: Option<SuiTransactionEvents>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub timestamp_ms: Option<u64>,
#[serde(default, skip_serializing_if = "Option::is_none")]
@@ -49,6 +114,17 @@ pub struct SuiTransactionResponse {
/// This is only returned in the read api, not in the transaction execution api.
#[serde(skip_serializing_if = "Option::is_none")]
pub checkpoint: Option<CheckpointSequenceNumber>,
#[serde(skip_serializing_if = "Vec::is_empty", default)]
pub errors: Vec<String>,
}
#[method(name = "getTransaction")]
async fn get_transaction_with_options(
&self,
/// the digest of the queried transaction
digest: TransactionDigest,
/// options for specifying the content to be returned
options: Option<SuiTransactionResponseOptions>,
) -> RpcResult<SuiTransactionResponse>;
/// Return the object information for a specified object
@@ -139,10 +142,16 @@ pub trait ReadApi {
descending_order: Option<bool>,
) -> RpcResult<TransactionsPage>;
/// Returns an ordered list of transaction responses
/// The method will throw an error if the input contains any duplicate or
/// the input size exceeds [QUERY_MAX_RESULT_LIMIT]
#[method(name = "multiGetTransactions")]
async fn multi_get_transactions_with_options(
&self,
/// A list of transaction digests.
digests: Vec<TransactionDigest>,
/// config options to control which fields to fetch
options: Option<SuiTransactionResponseOptions>,
) -> RpcResult<Vec<SuiTransactionResponse>>;
```
# Follow up items ( in separate PRs)
- [ ] rename `sui_getTransactions` to `sui_queryTransactions(query:
TransactionQuery, options: Option<SuiTransactionResponseOptions>) ->
Page<SuiTransactionResponse>`
- [ ] Add `SuiTransactionResponseOptions` as a parameter for
`sui_executeTransaction`
- [ ] remove existing ``sui_submitTransaction` and
`sui_executeTransactionSig`
- [ ] support options in the Indexer implementation
- [ ] Support more option variants such as `showRawBcs` and
`showLatestObjectData`
## Test Plan
1. TS-SDK e2e tests `pnpm sdk prepare:e2e` `pnpm sdk test:e2e`
2. Test Explorer with the following steps
a. In root sui directory, run `pnpm sdk prepare:e2e`
b. In root sui directory, run `pnpm explorer dev`
c. in root sui directory, run `pnpm sdk test:e2e` to generate some data
d. open localhost:3000 to check on a few transactions with different
kinds
Address page
data:image/s3,"s3://crabby-images/a565b/a565be4f0bcbf0fab5d2473d3e59cceaea450ec6" alt="CleanShot 2023-03-08 at 03 23
38"
Transaction Details page(Events tab)
data:image/s3,"s3://crabby-images/710d6/710d67e6c58eb7c74e4107a4dfd914a0386ec752" alt="CleanShot 2023-03-08 at 03 23
31"
Transaction Details page (main)
data:image/s3,"s3://crabby-images/61c1d/61c1d9e5b5d935915395b356616db1ab0a9f8678" alt="CleanShot 2023-03-08 at 03 23
24"
Home page
data:image/s3,"s3://crabby-images/6db50/6db5072a0adbc15aa1e44518391b4c885f5baac9" alt="CleanShot 2023-03-08 at 03 23
12"
3. Test wallet with the following steps
a. In root sui directory, run `pnpm sdk prepare:e2e`
b. Duplicate this
[file](https://github.com/MystenLabs/sui/blob/main/apps/wallet/configs/environment/.env.defaults#L4)
and rename it to .env,
c. In root sui directory, run `pnpm wallet start`
d. follow
https://github.com/MystenLabs/sui/tree/main/apps/wallet#install-the-extension-to-chrome
to install the wallet
e. make some transactions(staking, transfer, nft mint)
f. verify that the activity tab looks good
Send NFT
data:image/s3,"s3://crabby-images/edb96/edb96a5d1730244ddd1a670334de3940d278bca4" alt="CleanShot 2023-03-08 at 03 21
18"
Activity Tab
data:image/s3,"s3://crabby-images/492e4/492e4bdce8a1f0825862ab6d760f832e2ae9a461" alt="CleanShot 2023-03-08 at 03 20
53"
Transfer Coin
data:image/s3,"s3://crabby-images/5ae47/5ae47ac3ee88db9d965e462c246dca5798c44a47" alt="CleanShot 2023-03-08 at 03 20
40"
---
If your changes are not user-facing and not a breaking change, you can
skip the following section. Otherwise, please indicate what changed, and
then add to the Release Notes section as highlighted during the release
process.
### Type of Change (Check all that apply)
- [x] user-visible impact
- [x] breaking change for a client SDKs
- [x] breaking change for FNs (FN binary must upgrade)
- [ ] breaking change for validators or node operators (must upgrade
binaries)
- [ ] breaking change for on-chain data layout
- [ ] necessitate either a data wipe or data migration
### Release notes
- [RPC] `sui_getTransaction` and `sui_multiGetTransaction` now take in
an additional optional parameter called `options` which is used to
specify which fields to fetch (e.g., transaction, effects, events, etc).
By default, only the transaction digest will be returned.
- [TS SDK] Rename `provider.getTransactionWithEffects` to
`provider.getTransactionResponse`. The new method takes in an additional
parameter `SuiTransactionResponseOptions` to configure which fields to
fetch (e.g., transaction, effects, events, etc). By default, only the
transaction digest will be returned.