-
Notifications
You must be signed in to change notification settings - Fork 364
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'staging' into operator-liveness-metric
- Loading branch information
Showing
80 changed files
with
894,411 additions
and
9,089 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# SLACK_WEBHOOK_URL=<YOUR_SLACK_WEBHOOK_URL> | ||
# TELEGRAM_BOT_TOKEN=<YOUR_TELEGRAM_BOT_TOKEN> | ||
# TELEGRAM_CHAT_ID=<YOUR_TELEGRAM_CHAT_ID> | ||
|
||
# # Variables for contract_alerts.sh | ||
# RPC_URL=<YOUR_RPC_URL> | ||
# CONTRACT_ADDRESS=<YOUR_CONTRACT_ADDRESS> | ||
# NEW_BATCH_TOPIC=<YOUR_NEW_BATCH_TOPIC> | ||
# VERIFIED_BATCH_TOPIC=<YOUR_VERIFIED_BATCH_TOPIC> | ||
# PAGER_DUTY_KEY=<YOUR_PAGER_DUTY_KEY> | ||
# PAGER_DUTY_EMAIL=<YOUR_PAGER_DUTY_EMAIL> | ||
# PAGER_DUTY_SERVICE_ID=<YOUR_PAGER_DUTY_SERVICE_ID> | ||
|
||
# # Variables for process_errors_alerts.sh | ||
# SERVICE=<YOUR_SERVICE> | ||
# EXPRESSION=<GREP_EXPRESSION> | ||
|
||
# # Variables for balance_alerts.sh | ||
# RPC_URL=<YOUR_RPC_URL> | ||
# PAYMENT_CONTRACT_ADDRESS=<YOUR_PAYMENT_CONTRACT_ADDRESS> | ||
# BALANCE_THRESHOLD=<YOUR_BALANCE_THRESHOLD_IN_ETH> | ||
# WALLET_ADDRESS=<YOUR_WALLET_ADDRESS> | ||
|
||
# Variables for sender_with_alert.sh | ||
REPETITIONS=8 | ||
SENDER_ADDRESS=0x14dC79964da2C08b23698B3D3cc7Ca32193d9955 | ||
BATCHER_URL=ws://localhost:8080 | ||
RPC_URL=http://localhost:8545 | ||
EXPLORER_URL=http://localhost:3000 | ||
NETWORK=devnet | ||
PRIVATE_KEY=0x4bbbf85ce3377467afe5d46f804f221813b2bb87f24d81f60f1fcdbf7cbf4356 | ||
VERIFICATION_WAIT_TIME=30 | ||
LOGS_BLOCK_RANGE=100 |
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,186 @@ | ||
#!/bin/bash | ||
|
||
# ENV VARIABLES: | ||
# - REPETITIONS | ||
# - EXPLORER_URL | ||
# - SENDER_ADDRESS | ||
# - BATCHER_URL | ||
# - RPC_URL | ||
# - EXPLORER_URL | ||
# - NETWORK | ||
# - PRIVATE_KEY | ||
# - VERIFICATION_WAIT_TIME | ||
# - LOGS_BLOCK_RANGE | ||
# - SLEEP_TIME | ||
# - PAGER_DUTY_KEY | ||
# - PAGER_DUTY_EMAIL | ||
# - PAGER_DUTY_SERVICE_ID | ||
# - SLACK_WEBHOOK_URL | ||
|
||
# TODO (Improvement): | ||
# 1. This script waits VERIFICATION_WAIT_TIME seconds before fetching the explorer for the response tx hash. | ||
# We should instead poll in a loop until the batch is marked as verified | ||
|
||
# ACKNOWLEDGMENTS | ||
# | ||
# Special thanks to AniV for their contribution on StackExchange regarding AWK formatting with floating point operations: | ||
# https://unix.stackexchange.com/questions/292087/how-do-i-get-bc-to-start-decimal-fractions-with-a-leading-zero | ||
|
||
|
||
# Load env file from $1 path | ||
source "$1" | ||
|
||
# Just for debugging | ||
#set -ex | ||
|
||
### FUNCTIONS ### | ||
|
||
# Function to get the tx cost from the tx hash | ||
# @param tx_hash | ||
function fetch_tx_cost() { | ||
if [[ -z "$1" ]]; then | ||
echo 0 | ||
else | ||
# Get the tx receipt from the blockchain | ||
receipt=$(cast receipt --rpc-url $RPC_URL $1) | ||
# Parse the gas used and gas price | ||
gas_price=$(echo "$receipt" | grep "effectiveGasPrice" | awk '{ print $2 }') | ||
gas_used=$(echo "$receipt" | grep "gasUsed" | awk '{ print $2 }') | ||
# Calculate fee in wei | ||
fee_in_wei=$(($gas_price * $gas_used)) | ||
|
||
echo $fee_in_wei | ||
fi | ||
} | ||
|
||
# Function to send PagerDuty alert | ||
# @param message | ||
function send_pagerduty_alert() { | ||
. alerts/pagerduty.sh "$1" | ||
} | ||
|
||
# Function so send Slack message | ||
# @param message | ||
function send_slack_message() { | ||
. alerts/slack.sh "$1" | ||
} | ||
|
||
################# | ||
while true | ||
do | ||
|
||
## Remove Proof Data | ||
rm -rf ./scripts/test_files/gnark_groth16_bn254_infinite_script/infinite_proofs/* | ||
rm -rf ./aligned_verification_data/* | ||
|
||
mkdir -p ./scripts/test_files/gnark_groth16_bn254_infinite_script/infinite_proofs | ||
|
||
## Generate Proof | ||
nonce=$(aligned get-user-nonce --batcher_url $BATCHER_URL --user_addr $SENDER_ADDRESS 2>&1 | awk '{print $9}') | ||
x=$((nonce + 1)) # So we don't have any issues with nonce = 0 | ||
echo "Generating proof $x != 0" | ||
go run ./scripts/test_files/gnark_groth16_bn254_infinite_script/cmd/main.go $x | ||
|
||
## Send Proof | ||
echo "Submitting $REPETITIONS proofs $x != 0" | ||
submit=$(aligned submit \ | ||
--proving_system Groth16Bn254 \ | ||
--repetitions $REPETITIONS \ | ||
--proof "./scripts/test_files/gnark_groth16_bn254_infinite_script/infinite_proofs/ineq_${x}_groth16.proof" \ | ||
--public_input "./scripts/test_files/gnark_groth16_bn254_infinite_script/infinite_proofs/ineq_${x}_groth16.pub" \ | ||
--vk "./scripts/test_files/gnark_groth16_bn254_infinite_script/infinite_proofs/ineq_${x}_groth16.vk" \ | ||
--proof_generator_addr $SENDER_ADDRESS \ | ||
--private_key $PRIVATE_KEY \ | ||
--rpc_url $RPC_URL \ | ||
--batcher_url $BATCHER_URL \ | ||
--network $NETWORK \ | ||
--max_fee 4000000000000000 \ | ||
2>&1) | ||
|
||
echo "$submit" | ||
|
||
echo "Waiting $VERIFICATION_WAIT_TIME seconds for verification" | ||
sleep $VERIFICATION_WAIT_TIME | ||
|
||
# Get all the batches merkle roots | ||
batch_merkle_roots=$(echo "$submit" | grep "Batch merkle root: " | grep -oE "0x[[:alnum:]]{64}" | uniq) | ||
|
||
# Fetch the logs of both submission and response | ||
current_block_number=$(cast block-number --rpc-url $RPC_URL) | ||
from_block_number=$(($current_block_number - LOGS_BLOCK_RANGE)) | ||
if [ $from_block_number -lt 0 ]; then | ||
from_block_number=0 | ||
fi | ||
|
||
total_fee_in_wei=0 | ||
batch_explorer_urls=() | ||
for batch_merkle_root in $batch_merkle_roots | ||
do | ||
# Construct the batcher explorer url | ||
batch_explorer_url="$EXPLORER_URL/batches/$batch_merkle_root" | ||
batch_explorer_urls+=($batch_explorer_url) | ||
|
||
log=$(cast logs --rpc-url $RPC_URL --from-block $from_block_number --to-block latest 'NewBatchV3 (bytes32 indexed batchMerkleRoot, address senderAddress, uint32 taskCreatedBlock, string batchDataPointer, uint256 respondToTaskFeeLimit)' $batch_merkle_root) | ||
submission_tx_hash=$(echo "$log" | grep -oE "transactionHash: 0x[[:alnum:]]{64}" | awk '{ print $2 }') | ||
|
||
log=$(cast logs --rpc-url $RPC_URL --from-block $from_block_number --to-block latest 'BatchVerified (bytes32 indexed batchMerkleRoot, address senderAddress)' $batch_merkle_root) | ||
response_tx_hash=$(echo "$log" | grep -oE "transactionHash: 0x[[:alnum:]]{64}" | awk '{ print $2 }') | ||
|
||
# Calculate fees for transactions | ||
submission_fee_in_wei=$(fetch_tx_cost $submission_tx_hash) | ||
response_fee_in_wei=$(fetch_tx_cost $response_tx_hash) | ||
batch_fee_in_wei=$((submission_fee_in_wei + response_fee_in_wei)) | ||
|
||
# Accumulate the fee | ||
total_fee_in_wei=$(($total_fee_in_wei + $batch_fee_in_wei)) | ||
done | ||
|
||
# Calculate the spent amount by converting the fee to ETH | ||
wei_to_eth_division_factor=$((10**18)) | ||
spent_amount=$(echo "scale=30; $total_fee_in_wei / (10^18)" | bc -l | awk '{printf "%.15f", $0}') | ||
|
||
eth_usd=$(curl -s https://cryptoprices.cc/ETH/) | ||
spent_amount_usd=$(echo "$spent_amount * $eth_usd" | bc | awk '{printf "%.2f", $1}') | ||
|
||
slack_messsage="" | ||
verified=1 | ||
|
||
## Verify Proofs | ||
echo "Verifying $REPETITIONS proofs $x != 0" | ||
for proof in ./aligned_verification_data/*.cbor; do | ||
## Validate Proof on Chain | ||
verification=$(aligned verify-proof-onchain \ | ||
--aligned-verification-data $proof \ | ||
--rpc_url $RPC_URL \ | ||
--network $NETWORK \ | ||
2>&1) | ||
|
||
## Send Alert if Verification Fails | ||
if echo "$verification" | grep -q not; then | ||
message="Proof verification failed for $proof [ ${batch_explorer_urls[@]} ]" | ||
echo "$message" | ||
send_pagerduty_alert "$message" | ||
verified=0 # Some proofs failed, so we should not send the success message | ||
break | ||
elif echo "$verification" | grep -q verified; then | ||
echo "Proof verification succeeded for $proof" | ||
fi | ||
done | ||
|
||
if [ $verified -eq 1 ]; then | ||
slack_message="$REPETITIONS Proofs submitted and verified. Spent amount: $spent_amount ETH ($ $spent_amount_usd) [ ${batch_explorer_urls[@]} ]" | ||
else | ||
slack_message="$REPETITIONS Proofs submitted but not verified. Spent amount: $spent_amount ETH ($ $spent_amount_usd) [ ${batch_explorer_urls[@]} ]" | ||
fi | ||
|
||
## Send Update to Slack | ||
echo "$slack_message" | ||
send_slack_message "$slack_message" | ||
|
||
## Remove Proof Data | ||
rm -rf ./scripts/test_files/gnark_groth16_bn254_infinite_script/infinite_proofs/* | ||
rm -rf ./aligned_verification_data/* | ||
|
||
echo "Sleeping $SLEEP_TIME seconds" | ||
sleep $SLEEP_TIME | ||
done |
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,5 @@ | ||
# Function to send slack message | ||
# @param message | ||
curl -X POST -H 'Content-type: application/json' \ | ||
--data "{\"text\":\"$1\"}" \ | ||
$SLACK_WEBHOOK_URL |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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 |
---|---|---|
@@ -1,6 +1,6 @@ | ||
[package] | ||
name = "aligned" | ||
version = "0.12.1" | ||
version = "0.12.2" | ||
edition = "2021" | ||
|
||
[dependencies] | ||
|
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,14 @@ | ||
# Compiler files | ||
cache/ | ||
out/ | ||
|
||
# Ignores development broadcast logs | ||
!/broadcast | ||
/broadcast/*/31337/ | ||
/broadcast/**/dry-run/ | ||
|
||
# Docs | ||
docs/ | ||
|
||
# Dotenv file | ||
.env |
Oops, something went wrong.