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

Introduced by-name deployment and declare-deploy command #2331

Open
wants to merge 40 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
eecc2e2
Added a compiled contract representation
integraledelebesgue Jul 24, 2024
c4dbf57
Redesigned `declare` handler
integraledelebesgue Jul 24, 2024
69cf938
Introduced deploy by name
integraledelebesgue Jul 24, 2024
c449de5
Improved deploy-by-name
integraledelebesgue Jul 24, 2024
1f74c9c
Added deploy-by-name tests
integraledelebesgue Jul 24, 2024
b87ef03
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Jul 24, 2024
436dd28
Added deploy-by-name to changelog and docs
integraledelebesgue Jul 24, 2024
48ab4a9
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Jul 29, 2024
c84afe1
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Jul 29, 2024
f691a22
Moved deploy-by-name example higher in the docs
integraledelebesgue Jul 31, 2024
40b8ad7
Improved descriptivity of the `build_artifacts` method
integraledelebesgue Jul 31, 2024
d6b13d3
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Jul 31, 2024
873f524
Removed auto-declaration from `deploy` and introduced `declare-deploy…
integraledelebesgue Aug 5, 2024
9739534
Fixed `clippy` warnings
integraledelebesgue Aug 5, 2024
41880aa
Merged `master`
integraledelebesgue Aug 5, 2024
ae24960
Updated `declare-deploy` in docs and changelog
integraledelebesgue Aug 5, 2024
c29673b
Updated doc summary
integraledelebesgue Aug 5, 2024
9af83f9
Updated tests
integraledelebesgue Aug 7, 2024
8f9502a
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Aug 8, 2024
6350ac6
Simplified `declare_compiled` flow
integraledelebesgue Aug 8, 2024
67b2b96
Updated tests
integraledelebesgue Aug 9, 2024
79f23e9
Updated docs
integraledelebesgue Aug 9, 2024
fa5052f
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Aug 9, 2024
9a60f27
Optimized errors
integraledelebesgue Aug 9, 2024
c272f71
Merge branch 'master' into integraledelebesgue/feature-2279
integraledelebesgue Aug 27, 2024
1d0341e
Removed duplicated test
integraledelebesgue Aug 27, 2024
15d26df
Changed salt name to more professional :woozy_face:
integraledelebesgue Aug 27, 2024
7578221
Changed notes to warnings
integraledelebesgue Aug 27, 2024
f085c3e
Changed `From` to `TryFrom`
integraledelebesgue Aug 27, 2024
7b77cd3
Added block explorer output to `declare-deploy`
integraledelebesgue Aug 27, 2024
85f478e
Removed unnecessary `test-runner` argument
integraledelebesgue Aug 27, 2024
b11b1bc
Fixed logic related to class hashes
integraledelebesgue Aug 27, 2024
8c5bd8d
Merge branch 'master' of https://github.com/foundry-rs/starknet-found…
franciszekjob Dec 20, 2024
1fab090
Resolve other conflicts
franciszekjob Dec 20, 2024
28319d2
Use `HelloSncast` contract in snippet
franciszekjob Dec 20, 2024
b2a7f16
Fix declare-deploy about text
franciszekjob Dec 20, 2024
e3cbebe
Update declare-deploy docs
franciszekjob Dec 20, 2024
c6b1d55
Trigger CI
franciszekjob Dec 20, 2024
05113b7
Merge branch 'master' of https://github.com/foundry-rs/starknet-found…
franciszekjob Dec 20, 2024
363e4cf
Merge branch 'master' of https://github.com/foundry-rs/starknet-found…
franciszekjob Jan 14, 2025
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
4 changes: 3 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

### Cast

#### Added
### Added

- `sncast deploy` can now deploy contracts by name instead of class hash. [Read more here](https://foundry-rs.github.io/starknet-foundry/starknet/deploy.html)
- `sncast declare-deploy` allows to declare and deploy contract at once. [Read more here](https://foundry-rs.github.io/starknet-foundry/starknet/declare-deploy.html)
- When using `--max-fee` with transactions v3, calculated max gas and max gas unit price are automatically validated to ensure they are greater than 0 after conversion
- interactive interface that allows setting created or imported account as the default

Expand Down
2 changes: 1 addition & 1 deletion crates/sncast/src/helpers/fee.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ use std::{
str::FromStr,
};

#[derive(Args, Debug, Clone)]
#[derive(Args, Debug, Clone, Default)]
pub struct FeeArgs {
/// Token that transaction fee will be paid in
#[clap(long, value_parser = parse_fee_token)]
Expand Down
76 changes: 75 additions & 1 deletion crates/sncast/src/helpers/scarb_utils.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use anyhow::{anyhow, Context, Result};
use anyhow::{anyhow, bail, Context, Result};
use camino::{Utf8Path, Utf8PathBuf};
use scarb_api::{
get_contracts_artifacts_and_source_sierra_paths,
Expand All @@ -7,6 +7,14 @@ use scarb_api::{
};
use scarb_ui::args::PackagesFilter;
use shared::{command::CommandExt, print::print_as_warning};
use starknet::{
core::types::{
contract::{CompiledClass, SierraClass},
BlockId, FlattenedSierraClass,
},
providers::{jsonrpc::HttpTransport, JsonRpcClient, Provider, ProviderError},
};
use starknet_types_core::felt::Felt;
use std::collections::HashMap;
use std::env;
use std::str::FromStr;
Expand Down Expand Up @@ -188,6 +196,72 @@ pub fn build_and_load_artifacts(
}
}

pub fn read_manifest_and_build_artifacts(
package: &Option<String>,
json: bool,
profile: Option<&String>,
) -> Result<HashMap<String, StarknetContractArtifacts>> {
let manifest_path = assert_manifest_path_exists()?;
let package_metadata = get_package_metadata(&manifest_path, package)?;

let default_profile = "dev".to_string();
let profile = profile.unwrap_or(&default_profile);

let build_config = BuildConfig {
scarb_toml_path: manifest_path,
json,
profile: profile.to_string(),
};

build_and_load_artifacts(&package_metadata, &build_config, false)
.context("Failed to build contract")
}

pub struct CompiledContract {
pub class: FlattenedSierraClass,
pub sierra_class_hash: Felt,
pub casm_class_hash: Felt,
}

impl TryFrom<&StarknetContractArtifacts> for CompiledContract {
type Error = anyhow::Error;

fn try_from(artifacts: &StarknetContractArtifacts) -> Result<Self, Self::Error> {
let sierra_class = serde_json::from_str::<SierraClass>(&artifacts.sierra)
.context("Failed to parse Sierra artifact")?
.flatten()?;

let compiled_class = serde_json::from_str::<CompiledClass>(&artifacts.casm)
.context("Failed to parse CASM artifact")?;

let sierra_class_hash = sierra_class.class_hash();
let casm_class_hash = compiled_class.class_hash()?;

Ok(Self {
class: sierra_class,
sierra_class_hash,
casm_class_hash,
})
}
}

impl CompiledContract {
pub async fn is_declared(&self, provider: &JsonRpcClient<HttpTransport>) -> Result<bool> {
let block_id = BlockId::Tag(starknet::core::types::BlockTag::Pending);
let class_hash = self.sierra_class_hash;

let response = provider.get_class(block_id, class_hash).await;

match response {
Ok(_) => Ok(true),
Err(ProviderError::StarknetError(
starknet::core::types::StarknetError::ClassHashNotFound,
)) => Ok(false),
Err(other) => bail!(other),
}
}
}

#[cfg(test)]
mod tests {
use crate::helpers::scarb_utils::{get_package_metadata, get_scarb_metadata};
Expand Down
Loading
Loading