2.0.0 • Published 2 years ago

@hexpayday/stake-manager v2.0.0

Weekly downloads
-
License
MIT
Repository
-
Last release
2 years ago

Stake Manager

Tests Coverage Status

build the contracts

yarn run build

NOTE: sometimes tests fail if your network connection is a little slow at the time and are running for the first time after a fresh install or deleting the cache

run tests

yarn run foundry:test
yarn run test
yarn run test --trace-error # with error traces

Verification

Verification should occur with git hash f1180beb5322796abeaa5fd2371afb3f6a880d62 to have the correct bytecode for contract 0x209b1C66cB0Ea99DC2d4Ad13C35859DD1c258988 on Ethereum mainnet.

Run Traces

npx hardhat trace --hash 0xdeadbeef... # tx hash

Local Development

to run a node locally, simply run

npx hardhat node

then, in another terminal, you can run the local-development script to fund your deploy mnemonic (env: DEPLOY_MNEMONIC)

./local-development

in the case of the hexpay.day developers, they may wish to provide the following series of envs and run the local development script as noted above in order to test in a browser

# where stakes will be ended / managed from
TEST_ADDRESS=0xE971e07BF9917e91DFbeD9165f2ea8e6FF876880
# where contracts will be deployed from
# must be first address of `DEPLOY_MNEMONIC`
DEPLOY_ADDRESS=0x73CaB6c9EDA8aBc28099aF9F5dBd100Aa998Ae72

Auditors

The contracts that need to be reviewed are in the contracts folder and excludes the interfaces and test folders. The reference folder contains 3 contracts: HEX.sol, HEDRON and HSIM, and COMM. The contracts folder is ~2400 sloc. The reference contract HEX.sol is ~1640 SLOC. The HEDRON and HSIM contracts are ~2700 sloc combined. The COMM contract is ~1200 sloc.

NOTE: the contracts in this repo do not care about any tokens except for the ones listed above and the maximus perpetuals (custodial contract for a hex stake). That being said, it would be great if you familiarized yourself with the quirks of these 3 token contracts as they do break common practices.

Metrics for the repo can be generated by running yarn run metrics.

# ethereum
npx hardhat --network external write:existing:end-bundle:base --wait --mev
# if the above command fails, then run
npx hardhat --network external write:existing:end-bundle:base --wait

# pulsechain
npx hardhat --network external write:existing:end-bundle:base --wait
2.0.0

2 years ago

1.0.19

2 years ago

1.0.18

2 years ago

1.0.16

2 years ago

1.0.9

2 years ago

1.0.8

2 years ago

1.0.7

2 years ago

1.0.6

2 years ago

1.0.5

2 years ago

1.0.4

2 years ago

1.0.3

2 years ago

1.0.11

2 years ago

1.0.10

2 years ago

1.0.20

2 years ago

1.0.15

2 years ago

1.0.14

2 years ago

1.0.13

2 years ago

1.0.12

2 years ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago