-
Notifications
You must be signed in to change notification settings - Fork 0
/
declare_v2.py
85 lines (69 loc) · 2.79 KB
/
declare_v2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import toml
import logging
from asyncio import run
from pathlib import Path
from starknet_py.net.signer.stark_curve_signer import KeyPair
from starknet_py.net.full_node_client import FullNodeClient
from starknet_py.net.models.chains import StarknetChainId
from starknet_py.net.account.account import Account
from starknet_py.common import create_casm_class, create_sierra_compiled_contract
from starknet_py.hash.casm_class_hash import compute_casm_class_hash
from starknet_py.hash.sierra_class_hash import compute_sierra_class_hash
# Set up logging
logging.basicConfig()
logger = logging.getLogger(__name__)
logger.setLevel(logging.INFO)
with open("config.toml", "r") as config_file:
config = toml.load(config_file)
# Accessing variables from config
ADDRESS = config.get("ADDRESS")
PRIV_KEY = config.get("PRIV_KEY")
NODE_URL = config.get("NODE_URL")
NAME = config.get("CONTRACT_NAME") # Load contract name from config
CHAIN = config.get("CHAIN", "MAINNET") # Load chain with MAINNET as default
CASM_FILE = f"contracts/{NAME}.compiled_contract_class.json"
SIERRA_FILE = f"contracts/{NAME}.contract_class.json"
async def main():
key_pair = KeyPair.from_private_key(PRIV_KEY)
client = FullNodeClient(node_url=NODE_URL)
# Use the chain from config
chain_id = (
StarknetChainId.MAINNET
if CHAIN == "MAINNET"
else (
StarknetChainId.SEPOLIA_TESTNET
if CHAIN == "SEPOLIA"
else StarknetChainId.MAINNET
) # fallback to MAINNET
)
account = Account(
address=ADDRESS,
client=client,
chain=chain_id,
key_pair=key_pair,
)
logger.info("ℹ️ Using account %s as deployer", hex(account.address))
contract_compiled_casm = Path(CASM_FILE).read_text()
casm_class = create_casm_class(contract_compiled_casm)
casm_class_hash = compute_casm_class_hash(casm_class)
contract_compiled_sierra = Path(SIERRA_FILE).read_text()
sierra_class = create_sierra_compiled_contract(contract_compiled_sierra)
sierra_class_hash = compute_sierra_class_hash(sierra_class)
try:
await client.get_class_by_hash(class_hash=sierra_class_hash)
logger.info(f"✅ Class {hex(sierra_class_hash)} already declared, skipping")
return sierra_class_hash
except Exception:
pass
declare_v3_tx = await account.sign_declare_v2(
compiled_contract=contract_compiled_sierra,
compiled_class_hash=casm_class_hash,
auto_estimate=False,
max_fee=8794884308816881,
)
resp = await account.client.declare(transaction=declare_v3_tx)
logger.info(f"ℹ️ tx hash: {hex(resp.transaction_hash)}")
await account.client.wait_for_tx(resp.transaction_hash)
logger.info(f"✅ class hash: {hex(resp.class_hash)}")
if __name__ == "__main__":
run(main())