-
Notifications
You must be signed in to change notification settings - Fork 121
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* first version of remove command integration * import remove command * fix some type errors for code_hash * optimize parse_code_hash function use * remove rpc call and code use * get last changes * use new way to get code_hash * fix fmt * change the way to get code hash * add remove command integration test * fix fmt * ignore integration tests * complete documentation for remove command * remove unused parse code hash function * complete remove command documentation with code-hash * fix previous merge of last changes * fix previous merge of last changes * fix: fix code_hash check but still error variant issue * fix code-hash handle * optimize get hash and error message * fix documentation * improve code_hash * fix error handling * Add api imports * Use correct event type * Fix extrinsics.md * Fix extrinsics.md * Wrap long error message * Error message formatting --------- Co-authored-by: Andrew Jones <[email protected]>
- Loading branch information
1 parent
a29d50f
commit 901d805
Showing
8 changed files
with
274 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
// Copyright 2018-2022 Parity Technologies (UK) Ltd. | ||
// This file is part of cargo-contract. | ||
// | ||
// cargo-contract is free software: you can redistribute it and/or modify | ||
// it under the terms of the GNU General Public License as published by | ||
// the Free Software Foundation, either version 3 of the License, or | ||
// (at your option) any later version. | ||
// | ||
// cargo-contract is distributed in the hope that it will be useful, | ||
// but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
// GNU General Public License for more details. | ||
// | ||
// You should have received a copy of the GNU General Public License | ||
// along with cargo-contract. If not, see <http://www.gnu.org/licenses/>. | ||
|
||
use super::{ | ||
runtime_api::api::{ | ||
self, | ||
contracts::events::CodeRemoved, | ||
}, | ||
submit_extrinsic, | ||
Client, | ||
CodeHash, | ||
ContractMessageTranscoder, | ||
DefaultConfig, | ||
ExtrinsicOpts, | ||
PairSigner, | ||
TokenMetadata, | ||
}; | ||
use crate::{ | ||
cmd::extrinsics::{ | ||
events::DisplayEvents, | ||
parse_code_hash, | ||
ErrorVariant, | ||
}, | ||
name_value_println, | ||
}; | ||
use anyhow::Result; | ||
use std::fmt::Debug; | ||
use subxt::{ | ||
Config, | ||
OnlineClient, | ||
}; | ||
|
||
#[derive(Debug, clap::Args)] | ||
#[clap(name = "remove", about = "Remove a contract's code")] | ||
pub struct RemoveCommand { | ||
/// The hash of the smart contract code already uploaded to the chain. | ||
#[clap(long, value_parser = parse_code_hash)] | ||
code_hash: Option<<DefaultConfig as Config>::Hash>, | ||
#[clap(flatten)] | ||
extrinsic_opts: ExtrinsicOpts, | ||
/// Export the call output in JSON format. | ||
#[clap(long, conflicts_with = "verbose")] | ||
output_json: bool, | ||
} | ||
|
||
impl RemoveCommand { | ||
pub fn is_json(&self) -> bool { | ||
self.output_json | ||
} | ||
|
||
pub fn run(&self) -> Result<(), ErrorVariant> { | ||
let artifacts = self.extrinsic_opts.contract_artifacts()?; | ||
let transcoder = artifacts.contract_transcoder()?; | ||
let signer = super::pair_signer(self.extrinsic_opts.signer()?); | ||
|
||
let artifacts_path = artifacts.artifact_path().to_path_buf(); | ||
|
||
let final_code_hash = match (self.code_hash.as_ref(), artifacts.code.as_ref()) { | ||
(Some(code_h), _) => { | ||
Ok(code_h.0) | ||
} | ||
(None, Some(_)) => { | ||
artifacts.code_hash() | ||
} | ||
(None, None) => { | ||
Err(anyhow::anyhow!( | ||
"No code_hash was provided or contract code was not found from artifact \ | ||
file {}. Please provide a code hash with --code-hash argument or specify the \ | ||
path for artifacts files with --manifest-path", | ||
artifacts_path.display() | ||
)) | ||
} | ||
}?; | ||
|
||
async_std::task::block_on(async { | ||
let url = self.extrinsic_opts.url_to_string(); | ||
let client = OnlineClient::from_url(url.clone()).await?; | ||
if let Some(code_removed) = self | ||
.remove_code( | ||
&client, | ||
sp_core::H256(final_code_hash), | ||
&signer, | ||
&transcoder, | ||
) | ||
.await? | ||
{ | ||
let remove_result = code_removed.code_hash; | ||
|
||
if self.output_json { | ||
println!("{}", &remove_result); | ||
} else { | ||
name_value_println!("Code hash", format!("{remove_result:?}")); | ||
} | ||
Result::<(), ErrorVariant>::Ok(()) | ||
} else { | ||
let error_code_hash = hex::encode(final_code_hash); | ||
Err(anyhow::anyhow!( | ||
"Error removing the code for the supplied code hash: {}", | ||
error_code_hash | ||
) | ||
.into()) | ||
} | ||
}) | ||
} | ||
|
||
async fn remove_code( | ||
&self, | ||
client: &Client, | ||
code_hash: CodeHash, | ||
signer: &PairSigner, | ||
transcoder: &ContractMessageTranscoder, | ||
) -> Result<Option<CodeRemoved>, ErrorVariant> { | ||
let call = api::tx() | ||
.contracts() | ||
.remove_code(sp_core::H256(code_hash.0)); | ||
|
||
let result = submit_extrinsic(client, &call, signer).await?; | ||
let display_events = | ||
DisplayEvents::from_events(&result, Some(transcoder), &client.metadata())?; | ||
|
||
let output = if self.output_json { | ||
display_events.to_json()? | ||
} else { | ||
let token_metadata = TokenMetadata::query(client).await?; | ||
display_events | ||
.display_events(self.extrinsic_opts.verbosity()?, &token_metadata)? | ||
}; | ||
println!("{output}"); | ||
let code_removed = result.find_first::<CodeRemoved>()?; | ||
Ok(code_removed) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters