Skip to content

Commit

Permalink
merge main
Browse files Browse the repository at this point in the history
  • Loading branch information
glihm committed Oct 10, 2023
2 parents 06e1d3a + 3505fae commit b95b065
Show file tree
Hide file tree
Showing 13 changed files with 133 additions and 28 deletions.
2 changes: 1 addition & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ all-features = true
[dependencies]
starknet-ff = { version = "0.3.4", path = "./starknet-ff", default-features = false }
starknet-crypto = { version = "0.6.0", path = "./starknet-crypto" }
starknet-core = { version = "0.6.0", path = "./starknet-core", default-features = false }
starknet-core = { version = "0.6.1", path = "./starknet-core", default-features = false }
starknet-providers = { version = "0.6.0", path = "./starknet-providers" }
starknet-contract = { version = "0.5.0", path = "./starknet-contract" }
starknet-signers = { version = "0.4.0", path = "./starknet-signers" }
Expand Down
2 changes: 1 addition & 1 deletion starknet-accounts/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ keywords = ["ethereum", "starknet", "web3"]
exclude = ["test-data/**"]

[dependencies]
starknet-core = { version = "0.6.0", path = "../starknet-core" }
starknet-core = { version = "0.6.1", path = "../starknet-core" }
starknet-providers = { version = "0.6.0", path = "../starknet-providers" }
starknet-signers = { version = "0.4.0", path = "../starknet-signers" }
async-trait = "0.1.68"
Expand Down
13 changes: 12 additions & 1 deletion starknet-accounts/src/factory/argent.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
use crate::{AccountFactory, PreparedAccountDeployment, RawAccountDeployment};

use async_trait::async_trait;
use starknet_core::types::FieldElement;
use starknet_core::types::{BlockId, BlockTag, FieldElement};
use starknet_providers::Provider;
use starknet_signers::Signer;

Expand All @@ -12,6 +12,7 @@ pub struct ArgentAccountFactory<S, P> {
guardian_public_key: FieldElement,
signer: S,
provider: P,
block_id: BlockId,
}

impl<S, P> ArgentAccountFactory<S, P>
Expand All @@ -33,8 +34,14 @@ where
guardian_public_key,
signer,
provider,
block_id: BlockId::Tag(BlockTag::Latest),
})
}

pub fn set_block_id(&mut self, block_id: BlockId) -> &Self {
self.block_id = block_id;
self
}
}

#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
Expand Down Expand Up @@ -63,6 +70,10 @@ where
&self.provider
}

fn block_id(&self) -> BlockId {
self.block_id
}

async fn sign_deployment(
&self,
deployment: &RawAccountDeployment,
Expand Down
13 changes: 12 additions & 1 deletion starknet-accounts/src/factory/open_zeppelin.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
use crate::{AccountFactory, PreparedAccountDeployment, RawAccountDeployment};

use async_trait::async_trait;
use starknet_core::types::FieldElement;
use starknet_core::types::{BlockId, BlockTag, FieldElement};
use starknet_providers::Provider;
use starknet_signers::Signer;

Expand All @@ -11,6 +11,7 @@ pub struct OpenZeppelinAccountFactory<S, P> {
public_key: FieldElement,
signer: S,
provider: P,
block_id: BlockId,
}

impl<S, P> OpenZeppelinAccountFactory<S, P>
Expand All @@ -30,8 +31,14 @@ where
public_key: public_key.scalar(),
signer,
provider,
block_id: BlockId::Tag(BlockTag::Latest),
})
}

pub fn set_block_id(&mut self, block_id: BlockId) -> &Self {
self.block_id = block_id;
self
}
}

#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
Expand Down Expand Up @@ -60,6 +67,10 @@ where
&self.provider
}

fn block_id(&self) -> BlockId {
self.block_id
}

async fn sign_deployment(
&self,
deployment: &RawAccountDeployment,
Expand Down
2 changes: 1 addition & 1 deletion starknet-contract/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ keywords = ["ethereum", "starknet", "web3"]
exclude = ["test-data/**"]

[dependencies]
starknet-core = { version = "0.6.0", path = "../starknet-core" }
starknet-core = { version = "0.6.1", path = "../starknet-core" }
starknet-providers = { version = "0.6.0", path = "../starknet-providers" }
starknet-accounts = { version = "0.5.0", path = "../starknet-accounts" }
serde = { version = "1.0.160", features = ["derive"] }
Expand Down
2 changes: 1 addition & 1 deletion starknet-core/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "starknet-core"
version = "0.6.0"
version = "0.6.1"
authors = ["Jonathan LEI <[email protected]>"]
license = "MIT OR Apache-2.0"
edition = "2021"
Expand Down
114 changes: 96 additions & 18 deletions starknet-core/src/types/contract/legacy.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use alloc::{boxed::Box, collections::BTreeMap, format, string::String, vec::Vec};
use alloc::{borrow::ToOwned, boxed::Box, collections::BTreeMap, format, string::String, vec::Vec};

use crate::{
crypto::compute_hash_on_elements,
Expand Down Expand Up @@ -464,8 +464,6 @@ impl LegacyContractClass {
program: &'a LegacyProgram,
}

// TODO: handle adding extra whitespaces in pre-0.10.0 artifacts for backward compatibility

let serialized = to_string_pythonic(&ContractArtifactForHash {
abi: &self.abi,
program: &self.program,
Expand Down Expand Up @@ -628,21 +626,85 @@ impl SerializeAs<LegacyProgram> for ProgramForHintedHash {
reference_manager: &'a LegacyReferenceManager,
}

HashVo::serialize(
&HashVo {
attributes: &source.attributes,
builtins: &source.builtins,
compiler_version: &source.compiler_version,
data: &source.data,
debug_info: &None,
hints: &source.hints,
identifiers: &source.identifiers,
main_scope: &source.main_scope,
prime: &source.prime,
reference_manager: &source.reference_manager,
},
serializer,
)
if source.compiler_version.is_some() {
// Anything since 0.10.0 can be hashed directly. No extra overhead incurred.

HashVo::serialize(
&HashVo {
attributes: &source.attributes,
builtins: &source.builtins,
compiler_version: &source.compiler_version,
data: &source.data,
debug_info: &None,
hints: &source.hints,
identifiers: &source.identifiers,
main_scope: &source.main_scope,
prime: &source.prime,
reference_manager: &source.reference_manager,
},
serializer,
)
} else {
// This is needed for backward compatibility with pre-0.10.0 contract artifacts.

// We're cloning the entire `identifiers` here as a temporary patch. This is not
// optimal, as it should technically be possible to avoid the cloning. This only
// affects very old contract artifacts though.
// TODO: optimize this to remove cloning.

let patched_identifiers = source
.identifiers
.iter()
.map(|(key, value)| {
(
key.to_owned(),
LegacyIdentifier {
decorators: value.decorators.to_owned(),
cairo_type: value
.cairo_type
.to_owned()
.map(|content| content.replace(": ", " : ")),
full_name: value.full_name.to_owned(),
members: value.members.to_owned().map(|map| {
map.iter()
.map(|(key, value)| {
(
key.to_owned(),
LegacyIdentifierMember {
cairo_type: value.cairo_type.replace(": ", " : "),
offset: value.offset,
},
)
})
.collect()
}),
references: value.references.to_owned(),
size: value.size,
pc: value.pc,
destination: value.destination.to_owned(),
r#type: value.r#type.to_owned(),
value: value.value.to_owned(),
},
)
})
.collect::<BTreeMap<_, _>>();

HashVo::serialize(
&HashVo {
attributes: &source.attributes,
builtins: &source.builtins,
compiler_version: &source.compiler_version,
data: &source.data,
debug_info: &None,
hints: &source.hints,
identifiers: &patched_identifiers,
main_scope: &source.main_scope,
prime: &source.prime,
reference_manager: &source.reference_manager,
},
serializer,
)
}
}
}

Expand Down Expand Up @@ -842,6 +904,14 @@ mod tests {
"../../../test-data/contracts/cairo0/artifacts/pre-0.11.0/oz_account.hashes.json"
),
),
(
include_str!(
"../../../test-data/contracts/cairo0/artifacts/pre-0.10.0/braavos_proxy.txt"
),
include_str!(
"../../../test-data/contracts/cairo0/artifacts/pre-0.10.0/braavos_proxy.hashes.json"
),
),
]
.into_iter()
{
Expand Down Expand Up @@ -879,6 +949,14 @@ mod tests {
"../../../test-data/contracts/cairo0/artifacts/pre-0.11.0/oz_account.hashes.json"
),
),
(
include_str!(
"../../../test-data/contracts/cairo0/artifacts/pre-0.10.0/braavos_proxy.txt"
),
include_str!(
"../../../test-data/contracts/cairo0/artifacts/pre-0.10.0/braavos_proxy.hashes.json"
),
),
]
.into_iter()
{
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"hinted_class_hash": "0x2e2b816fbc785f0713c87a343e4ece749743c992231de6e3b2ae3d87bc349aa",
"class_hash": "0x3131fa018d520a037686ce3efddeab8f28895662f019ca3ca18a626650f7d1e"
}

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion starknet-macros/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ keywords = ["ethereum", "starknet", "web3"]
proc-macro = true

[dependencies]
starknet-core = { version = "0.6.0", path = "../starknet-core" }
starknet-core = { version = "0.6.1", path = "../starknet-core" }
starknet-contract = { version = "0.5.0", path = "../starknet-contract" }
proc-macro2 = "1.0"
quote = "1.0"
Expand Down
2 changes: 1 addition & 1 deletion starknet-providers/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ keywords = ["ethereum", "starknet", "web3"]
exclude = ["test-data/**"]

[dependencies]
starknet-core = { version = "0.6.0", path = "../starknet-core" }
starknet-core = { version = "0.6.1", path = "../starknet-core" }
async-trait = "0.1.68"
auto_impl = "1.0.1"
ethereum-types = "0.14.1"
Expand Down
2 changes: 1 addition & 1 deletion starknet-signers/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ Starknet signer implementations
keywords = ["ethereum", "starknet", "web3"]

[dependencies]
starknet-core = { version = "0.6.0", path = "../starknet-core" }
starknet-core = { version = "0.6.1", path = "../starknet-core" }
starknet-crypto = { version = "0.6.0", path = "../starknet-crypto" }
async-trait = "0.1.68"
auto_impl = "1.0.1"
Expand Down

0 comments on commit b95b065

Please sign in to comment.