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

Interaction with Casper smart-contract source code verification service for feat-2.0 branch #184

Merged
Show file tree
Hide file tree
Changes from 40 commits
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
17bb79f
Added verify-contract command
kchudy Dec 22, 2023
0148785
Added verify contract to lib
kchudy Dec 22, 2023
70ac387
Added function for creating archive
kchudy Jan 2, 2024
7ff89c0
Added arg parsing
kchudy Jan 2, 2024
eeabc5b
Added verificator api client
kchudy Jan 2, 2024
3a93b2c
Added waiting for verification to finish
kchudy Jan 3, 2024
d705c97
Switched to deploy hash
kchudy Jan 3, 2024
41e3816
Updated comments
kchudy Jan 3, 2024
c2a8e89
Added getting verification details
kchudy Jan 5, 2024
906a080
Imploved error handling
kchudy Jan 8, 2024
3c30a1b
Improved logging
kchudy Jan 8, 2024
13e9698
Refactored verification function
kchudy Jan 8, 2024
5c2624c
Initialized API client
kchudy Jan 8, 2024
6d098d7
Adopt new datatypes; use reqwest
moubctez Jan 22, 2024
31b511a
Cleanup
moubctez Jan 22, 2024
85a5192
Fix result type
moubctez Jan 22, 2024
2b5b981
Fixes and cleanups
moubctez Jan 22, 2024
58b73b1
Sync structs with verificator
moubctez Jan 23, 2024
ce01727
More retries
moubctez Jan 24, 2024
103606c
Increase number of retries
moubctez Jan 25, 2024
935262a
Shorten message
moubctez Jan 25, 2024
2d530d5
Resolve comments
moubctez Apr 10, 2024
18c263e
Update src/verify_contract.rs
moubctez Apr 11, 2024
ad14347
cargo fmt
moubctez Apr 11, 2024
4159153
Update vergen to v8. This resolves audit error.
moubctez Apr 19, 2024
091215e
Resolve pull request comments
moubctez Jun 20, 2024
c2bb909
Restore vergen
moubctez Jun 24, 2024
b09ec9b
Use correct build.rs
moubctez Jun 24, 2024
8fb5f21
Fix build without default features. Now tokio is required with "time"…
moubctez Jun 26, 2024
4ec2565
Fix wasm build
moubctez Jun 27, 2024
8ee8610
Fix CI-CD tokio not optional
gRoussac Jun 27, 2024
c39952f
post-merge fixes
Jul 17, 2024
713a7cc
remove references to deploy hash in contract verification
Jul 17, 2024
09b6993
fix typo
Jul 18, 2024
5adcd50
remove duplicate CLI argument
Jul 26, 2024
f657151
pass deploy/transaction hash to verification service as string
Jul 26, 2024
5481a59
make struct fields public
Jul 26, 2024
9f408ca
update gitignore
Aug 5, 2024
9aa1ca2
Merge branch 'refs/heads/feat-track-node-2.0' into contract-verificat…
Aug 5, 2024
f5eb8c8
add missing newline
Aug 5, 2024
44f2d6b
Merge branch 'refs/heads/feat-track-node-2.0' into contract-verificat…
Sep 12, 2024
2aaa4ef
resolve review comments
Sep 12, 2024
25c3ed9
update toolchain
gRoussac Sep 12, 2024
9831851
Merge pull request #3 from gRoussac/teonite-feat-2.0
wojcik91 Sep 12, 2024
5178548
update sample transaction
Sep 12, 2024
a5901c3
Merge branch 'feat-track-node-2.0' into contract-verification-command…
Oct 23, 2024
c0e562b
add AddressableEntity export
Oct 23, 2024
191b80d
cargo fmt
gRoussac Oct 23, 2024
77d05c1
clippy
gRoussac Oct 23, 2024
e9409fb
clippy
gRoussac Oct 23, 2024
8df82e9
Merge pull request #5 from gRoussac/teonite-compile
wojcik91 Oct 23, 2024
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
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
/target
Cargo.lock
*casper_keygen_test*
.idea/
.envrc
.direnv/
25 changes: 17 additions & 8 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
[package]
name = "casper-client"
version = "2.0.0" # when updating, also update 'html_root_url' in lib.rs
authors = ["Marc Brinkmann <[email protected]>", "Fraser Hutchison <[email protected]>", "Zachary Showalter <[email protected]>"]
authors = [
"Marc Brinkmann <[email protected]>",
"Fraser Hutchison <[email protected]>",
"Zachary Showalter <[email protected]>",
]
edition = "2021"
description = "A client library and binary for interacting with the Casper network"
documentation = "https://docs.rs/casper-client"
Expand All @@ -18,48 +22,53 @@ path = "lib/lib.rs"
name = "casper-client"
path = "src/main.rs"
doc = false
required-features = ["async-trait", "clap", "clap_complete", "std-fs-io"]

[features]
default = ["async-trait", "clap", "clap_complete", "tokio", "std-fs-io"]
default = ["async-trait", "clap", "clap_complete", "std-fs-io"]
std-fs-io = ["casper-types/std-fs-io"]

[dependencies]
async-trait = { version = "0.1.59", default-features = false, optional = true }
base16 = "0.2.1"
base64 = { version = "0.22.1", default-features = false }
bytes = { version = "1.6.0", default-features = false }
casper-types = { version = "5.0.0", features = ["std"] }
clap = { version = "4", features = [
"cargo",
"deprecated",
"wrap_help",
], optional = true }
clap_complete = { version = "4", default-features = false, optional = true }
flate2 = "1.0.30"
hex-buffer-serde = "0.4.0"
humantime = "2"
itertools = "0.11.0"
jsonrpc-lite = "0.6.0"
num-traits = "0.2.15"
once_cell = "1"
rand = "0.8.5"
reqwest = { version = "0.11.13", features = ["json"] }
reqwest = { version = "0.12.5", features = ["json"] }
schemars = "0.8.13"
serde = { version = "1", default-features = false, features = ["derive"] }
serde-map-to-array = "1.1.1"
serde_json = { version = "1", features = ["preserve_order"] }
thiserror = "1.0.34"
tokio = { version = "1.23.0", features = [
tar = { version = "0.4.41", default-features = false }
thiserror = "1.0.62"
tokio = { version = "1.38.1", features = [
"macros",
"net",
"rt-multi-thread",
"sync",
"time",
], optional = true }
uint = "0.9.4"
]}
uint = "0.9.5"

[dev-dependencies]
tempfile = "3.7.1"

[build-dependencies]
vergen = { version = "7", default-features = false, features = ["git"] }
vergen = { version = "8", default-features = false, features = ["git", "git2"] }

[patch.crates-io]
casper-types = { git = "https://github.com/casper-network/casper-node.git", branch = "feat-2.0" }
Expand Down
22 changes: 18 additions & 4 deletions build.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,21 @@
use vergen::{Config, ShaKind};
use std::process::Command;

const GIT_HASH_ENV_VAR: &str = "GIT_SHA_SHORT";

fn main() {
let mut config = Config::default();
*config.git_mut().sha_kind_mut() = ShaKind::Short;
let _ = vergen::vergen(config);
//Build command to retrieve the short git commit hash
wojcik91 marked this conversation as resolved.
Show resolved Hide resolved
let git_process_output = Command::new("git")
.arg("rev-parse")
.arg("--short")
.arg("HEAD")
.output()
.expect("Failed to retrieve short git commit hash");

//Parse the raw output into a string, we still need to remove the newline character
let git_hash_raw =
String::from_utf8(git_process_output.stdout).expect("Failed to convert git hash to string");
//Remove the newline character from the short git commit hash
let git_hash = git_hash_raw.trim_end_matches('\n');

println!("cargo:rustc-env={}={}", GIT_HASH_ENV_VAR, git_hash);
}
21 changes: 21 additions & 0 deletions lib/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ mod transaction;
mod transaction_builder_params;
mod transaction_str_params;

#[cfg(feature = "std-fs-io")]
wojcik91 marked this conversation as resolved.
Show resolved Hide resolved
use serde::Serialize;

#[cfg(doc)]
Expand All @@ -54,6 +55,7 @@ use crate::{
},
DictionaryItemIdentifier,
},
verification_types::VerificationDetails,
SuccessResponse,
};
#[cfg(doc)]
Expand Down Expand Up @@ -593,3 +595,22 @@ pub async fn get_era_info(
.await
.map_err(CliError::from)
}

/// Verifies the smart contract code against the one installed
/// by deploy or transaction with given hash.
pub async fn verify_contract(
hash_str: &str,
verification_url_base_path: &str,
verification_project_path: Option<&str>,
verbosity_level: u64,
) -> Result<VerificationDetails, CliError> {
let verbosity = parse::verbosity(verbosity_level);
crate::verify_contract(
hash_str,
verification_url_base_path,
verification_project_path,
verbosity,
)
.await
.map_err(CliError::from)
}
44 changes: 22 additions & 22 deletions lib/cli/json_args.rs
Original file line number Diff line number Diff line change
Expand Up @@ -58,59 +58,59 @@ fn write_json_to_bytesrepr(
.as_i64()
.and_then(|value| i32::try_from(value).ok())
.ok_or(ErrorDetails::CannotParseToI32)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::I64, Value::Number(number)) => {
let value = number.as_i64().ok_or(ErrorDetails::CannotParseToI64)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U8, Value::Number(number)) => {
let value = number
.as_u64()
.and_then(|value| u8::try_from(value).ok())
.ok_or(ErrorDetails::CannotParseToU8)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U32, Value::Number(number)) => {
let value = number
.as_u64()
.and_then(|value| u32::try_from(value).ok())
.ok_or(ErrorDetails::CannotParseToU32)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U64, Value::Number(number)) => {
let value = number.as_u64().ok_or(ErrorDetails::CannotParseToU64)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U128, Value::String(string)) => {
let value = U128::from_dec_str(string)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U128, Value::Number(number)) => {
let value = number.as_u64().ok_or(ErrorDetails::CannotParseToU64)?;
U128::from(value).write_bytes(output)?
U128::from(value).write_bytes(output)?;
}
(&CLType::U256, Value::String(string)) => {
let value = U256::from_dec_str(string)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U256, Value::Number(number)) => {
let value = number.as_u64().ok_or(ErrorDetails::CannotParseToU64)?;
U256::from(value).write_bytes(output)?
U256::from(value).write_bytes(output)?;
}
(&CLType::U512, Value::String(string)) => {
let value = U512::from_dec_str(string)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::U512, Value::Number(number)) => {
let value = number.as_u64().ok_or(ErrorDetails::CannotParseToU64)?;
U512::from(value).write_bytes(output)?
U512::from(value).write_bytes(output)?;
}
(&CLType::Unit, Value::Null) => (),
(&CLType::String, Value::String(string)) => string.write_bytes(output)?,
(&CLType::Key, Value::String(string)) => {
let value = Key::from_formatted_str(string)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::Key, Value::Object(map)) => {
// This is an alternative JSON representation of a `Key`, e.g. if calling
Expand Down Expand Up @@ -140,22 +140,22 @@ fn write_json_to_bytesrepr(
Key::ChainspecRegistry if mapped_variant == "ChainspecRegistry" => {}
_ => return Err(ErrorDetails::KeyObjectHasInvalidVariant),
}
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::URef, Value::String(string)) => {
let value = URef::from_formatted_str(string)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(&CLType::PublicKey, Value::String(string)) => {
let value = PublicKey::from_hex(string)?;
value.write_bytes(output)?
value.write_bytes(output)?;
}
(CLType::Option(ref _inner_cl_type), Value::Null) => {
output.push(OPTION_NONE_TAG);
}
(CLType::Option(ref inner_cl_type), _) => {
output.push(OPTION_SOME_TAG);
write_json_to_bytesrepr(inner_cl_type, json_value, output)?
write_json_to_bytesrepr(inner_cl_type, json_value, output)?;
}
(CLType::List(ref inner_cl_type), Value::Array(vec)) => {
(vec.len() as u32).write_bytes(output)?;
Expand Down Expand Up @@ -208,11 +208,11 @@ fn write_json_to_bytesrepr(
match map.iter().next() {
Some((key, value)) if key.to_ascii_lowercase() == "ok" => {
output.push(RESULT_OK_TAG);
write_json_to_bytesrepr(ok, value, output)?
write_json_to_bytesrepr(ok, value, output)?;
}
Some((key, value)) if key.to_ascii_lowercase() == "err" => {
output.push(RESULT_ERR_TAG);
write_json_to_bytesrepr(err, value, output)?
write_json_to_bytesrepr(err, value, output)?;
}
_ => return Err(ErrorDetails::ResultObjectHasInvalidVariant),
}
Expand Down Expand Up @@ -242,7 +242,7 @@ fn write_json_to_bytesrepr(
_ => return Err(ErrorDetails::MapTypeNotValidAsObject(*key_type.clone())),
};
(map.len() as u32).write_bytes(output)?;
for (key_as_str, value) in map.iter() {
for (key_as_str, value) in map {
let key = match **key_type {
CLType::I32 => json!(i32::from_str(key_as_str)?),
CLType::I64 => json!(i64::from_str(key_as_str)?),
Expand Down Expand Up @@ -293,7 +293,7 @@ fn write_json_to_bytesrepr(
actual: vec.len(),
});
}
write_json_to_bytesrepr(&inner_cl_types[0], &vec[0], output)?
write_json_to_bytesrepr(&inner_cl_types[0], &vec[0], output)?;
}
(CLType::Tuple2(ref inner_cl_types), Value::Array(vec)) => {
if vec.len() != inner_cl_types.len() {
Expand All @@ -303,7 +303,7 @@ fn write_json_to_bytesrepr(
});
}
write_json_to_bytesrepr(&inner_cl_types[0], &vec[0], output)?;
write_json_to_bytesrepr(&inner_cl_types[1], &vec[1], output)?
write_json_to_bytesrepr(&inner_cl_types[1], &vec[1], output)?;
}
(CLType::Tuple3(ref inner_cl_types), Value::Array(vec)) => {
if vec.len() != inner_cl_types.len() {
Expand All @@ -314,7 +314,7 @@ fn write_json_to_bytesrepr(
}
write_json_to_bytesrepr(&inner_cl_types[0], &vec[0], output)?;
write_json_to_bytesrepr(&inner_cl_types[1], &vec[1], output)?;
write_json_to_bytesrepr(&inner_cl_types[2], &vec[2], output)?
write_json_to_bytesrepr(&inner_cl_types[2], &vec[2], output)?;
}
_ => return Err(ErrorDetails::IncompatibleType),
};
Expand Down
16 changes: 8 additions & 8 deletions lib/cli/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -585,8 +585,8 @@ mod transaction {
let validator_public_key = PublicKey::from(&validator_secret_key);
let amount = U512::from(2000);

let delegator_public_key_cl = &CLValue::from_t(&delegator_public_key).unwrap();
let validator_public_key_cl = &CLValue::from_t(&validator_public_key).unwrap();
let delegator_public_key_cl = &CLValue::from_t(delegator_public_key).unwrap();
let validator_public_key_cl = &CLValue::from_t(validator_public_key).unwrap();
let amount_cl = &CLValue::from_t(amount).unwrap();

let transaction_string_params = TransactionStrParams {
Expand Down Expand Up @@ -699,8 +699,8 @@ mod transaction {
let validator_public_key = PublicKey::from(&validator_secret_key);

let amount_cl = &CLValue::from_t(amount).unwrap();
let delegator_public_key_cl = &CLValue::from_t(&delegator_public_key).unwrap();
let validator_public_key_cl = &CLValue::from_t(&validator_public_key).unwrap();
let delegator_public_key_cl = &CLValue::from_t(delegator_public_key).unwrap();
let validator_public_key_cl = &CLValue::from_t(validator_public_key).unwrap();

let transaction_string_params = TransactionStrParams {
secret_key: "",
Expand Down Expand Up @@ -764,9 +764,9 @@ mod transaction {
let new_validator_public_key = PublicKey::from(&new_validator_secret_key);
let amount = U512::from(5000);

let delegator_public_key_cl = &CLValue::from_t(&delegator_public_key).unwrap();
let validator_public_key_cl = &CLValue::from_t(&validator_public_key).unwrap();
let new_validator_public_key_cl = &CLValue::from_t(&new_validator_public_key).unwrap();
let delegator_public_key_cl = &CLValue::from_t(delegator_public_key).unwrap();
let validator_public_key_cl = &CLValue::from_t(validator_public_key).unwrap();
let new_validator_public_key_cl = &CLValue::from_t(new_validator_public_key).unwrap();
let amount_cl = &CLValue::from_t(amount).unwrap();

let transaction_string_params = TransactionStrParams {
Expand Down Expand Up @@ -1053,7 +1053,7 @@ mod transaction {
let maybe_source = Some(source_uref);

let source_uref_cl = &CLValue::from_t(Some(&source_uref)).unwrap();
let target_uref_cl = &CLValue::from_t(&target_uref).unwrap();
let target_uref_cl = &CLValue::from_t(target_uref).unwrap();

let transaction_string_params = TransactionStrParams {
secret_key: "",
Expand Down
8 changes: 8 additions & 0 deletions lib/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,14 @@ pub enum Error {
/// Underlying error.
error: std::str::Utf8Error,
},

/// Failed to verify contract.
#[error("contract verification failed")]
ContractVerificationFailed,

/// Failed to construct HTTP client.
#[error("failed to construct HTTP client")]
FailedToConstructHttpClient,
}

impl From<ToBytesError> for Error {
Expand Down
Loading