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

Acp77 remote etna devnet #2233

Merged
merged 20 commits into from
Oct 18, 2024
Merged

Acp77 remote etna devnet #2233

merged 20 commits into from
Oct 18, 2024

Conversation

arturrez
Copy link
Collaborator

@arturrez arturrez commented Oct 10, 2024

Why this should be merged

adds --etna-devnet flag to node create command.
adds bootstrap and upgrade/genesis options
acp77 PoA workflow works

How this works

it adds support for remote clusters in AWS/GCP to connect to Enta Devnet
it's possilble to create a L1 subnet using the following commands
It uses @felipemadero awm-relayer extraPeerEndpoints implementation to work with Etna Devnet L1

How this was tested

./bin/avalanche blockchain create remote0
./bin/avalanche node create --aws --use-static-ip=false etna0
and chose Etna Devnet
also make sure that v1.12.0-initial-poc.5 is used for avago
./bin/avalanche blockchain deploy remote0 --cluster remote0

❯ ./bin/avalanche blockchain deploy remote0 --cluster remote0
✔ Get address from an existing stored key (created from avalanche key create or avalanche key import)
✔ arturtest2
Deploying [remote0] to Etna Devnet
✔ Use stored key
✔ arturtest2
Your Subnet's control keys: [P-custom1sa4k00j5gkus94f3mqs05s3hgumwwcw0mvpwzj]
Your subnet auth keys for chain creation: [P-custom1sa4k00j5gkus94f3mqs05s3hgumwwcw0mvpwzj]
CreateSubnetTx fee: 0.000001012 AVAX
Subnet has been created with ID: 2ov1b7DJ5e4donohSfna2xfFDnXds8MHWvsZiKwzr7pniYjJro
Now creating blockchain...
CreateChainTx fee: 0.000114450 AVAX
+--------------------+----------------------------------------------------+
| DEPLOYMENT RESULTS |                                                    |
+--------------------+----------------------------------------------------+
| Chain Name         | remote0                                            |
+--------------------+----------------------------------------------------+
| Subnet ID          | 2ov1b7DJ5e4donohSfna2xfFDnXds8MHWvsZiKwzr7pniYjJro |
+--------------------+----------------------------------------------------+
| VM ID              | sP6ej3WaxxPDE6G1UBzjuvv2dt5TGEgAXjkJx37BJwWzZ4qXb  |
+--------------------+----------------------------------------------------+
| Blockchain ID      | 2YnuaBFd1Prj3meoWP9gL3Aj7von3kjen6qV1mtVX7ahz7Rtwy |
+--------------------+                                                    +
| P-Chain TXID       |                                                    |
+--------------------+----------------------------------------------------+
Now calling ConvertL1 Tx...
ConvertSubnetTX fee: 0.000002758 AVAX
ConvertL1Tx ID: 291Ecz8BD93RdVxE2M3Zk2iako85NtkDR4mXE2MfjBbUZgpA7s
Waiting for L1 to be converted into sovereign blockchain ... 100% [===============]           
Node(s) successfully started syncing with blockchain!
Check node blockchain syncing status with avalanche node status remote0 --blockchain remote0

Waiting for node(s) in cluster remote0 to be healthy...
✓ Checking if node(s) are healthy...
✓ Nodes healthy after 61 seconds
Which is the RPC endpoint for remote0: http://18.207.117.246:9650/ext/bc/2YnuaBFd1Prj3meoWP9gL3Aj7von3kjen6qV1mtVX7ahz7Rtwy/rpc
✓ L1 is successfully converted to sovereign blockchain

How is this documented

@arturrez arturrez requested a review from a team as a code owner October 10, 2024 00:11
bootstrapIPs []string
genesisPath string
upgradePath string
useEtnaDevnet bool
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think useEtnaDevnet should be put into the existing NetworkFlags rather than being treated differently here.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

etnadevnet is a shortcut for the devnet
we already have devnet here so I don't think we should

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isn't the existing devnet still a personal network, separate from the pre-existing Etna Devnet?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

good point.
etna devnet should be treated like fuji, the only difference is lack of prebuilt genesis/boostrapper info that is included into avalanchego pkg. For enta devnet we need to specify bootstrap config in avalanchego config. We just have it in constants to help user

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

in my opinion it should be something like custom

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

More generally, it seems like network_options.go currently contains logic for supported networks to connect to. I think it would be error prone and less organized to put other network option logic in different places. This way it's all contained in the same places so it's easier to reason about.

Comment on lines 214 to 232
// bootsrap checks
if useEtnaDevnet && (len(bootstrapIDs) != 0 || len(bootstrapIPs) != 0 || genesisPath != "" || upgradePath != "") {
return fmt.Errorf("etna devnet uses predefined bootsrap configuration")
}
if len((bootstrapIDs)) != len(bootstrapIPs) {
return fmt.Errorf("number of bootstrap ids and ip:port pairs must be equal")
}
if genesisPath != "" && !utils.FileExists(genesisPath) {
return fmt.Errorf("genesis file %s does not exist", genesisPath)
}
if upgradePath != "" && !utils.FileExists(upgradePath) {
return fmt.Errorf("upgrade file %s does not exist", upgradePath)
}
// check ip:port pairs
for _, ip := range bootstrapIPs {
if _, err := netip.ParseAddrPort(ip); err != nil {
return fmt.Errorf("invalid ip:port pair %s", ip)
}
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we unit test these cases?

Also should we allow bootstrap IDs/IPs in the case Fuji/Mainnet?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it's allowed. these params are available for user to use.
I feel like I should move it into pkg/utils so I can add unittest for verification func

if err != nil {
return err
// etna devnet constants
if useEtnaDevnet {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It will also be cleaner here to support the Etna case within GetNetworkFromCmdLineFlags rather than needing to have custom handling for it throughout.

Copy link
Collaborator Author

@arturrez arturrez Oct 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

etnadevnet is shortcut with predefined bootstrap configuration for custom external network.
let me think about appropriate name for this. External or custom might be a correct name.
Once it's merged we should be able to support any other remote networks like etnadevnet or whatever we will need going forward

Comment on lines 21 to 44
EtnaDevnetBootstrapNodeIDs = []string{
"NodeID-WrLWMK5sJ4dBUAsx1dP2FUyTqrYwbFA1",
"NodeID-bojBKDrpt81bYhxYKQfLw89V7CpoH2m7",
"NodeID-8LbTmmGsDC991SbD8Nkx88VULT3XYzYXC",
"NodeID-DDhXtFm6Q9tCq2yiFRmcSMKvHgUgh8yQC",
"NodeID-QDYnWDQd6g4cQ5H6yiWNqSmfRMBqEH9AG",
"NodeID-P5QGH4EXddrcyNAzkqyZKHXgEpVX6HExL",
"NodeID-78ibWpjtZz5ZGT6EyTEdu8VKmboUHTuGT",
"NodeID-7eRvnfs2a2PvrPHUuCRRpPVAoVjbWxaFG",
"NodeID-gpXWBExQSZXqJPQt6L6MnveUfgr7HJ4q",
"NodeID-L4CY8B5uVSDe4cnN1BpeDsHacMp4q4q8q",
}
EtnaDevnetBootstrapIPs = []string{
"107.21.11.213:9651",
"34.233.248.130:9651",
"52.201.126.172:9651",
"35.170.144.5:9651",
"98.82.41.186:9651",
"34.228.34.127:9651",
"44.205.136.166:9651",
"52.6.31.40:9651",
"54.197.98.148:9651",
"18.211.108.228:9651",
}
Copy link
Collaborator

@michaelkaplan13 michaelkaplan13 Oct 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There should only be 5 bootstrap nodes I believe:

  --bootstrap-ids="NodeID-8LbTmmGsDC991SbD8Nkx88VULT3XYzYXC,NodeID-bojBKDrpt81bYhxYKQfLw89V7CpoH2m7,NodeID-WrLWMK5sJ4dBUAsx1dP2FUyTqrYwbFA1,NodeID-DDhXtFm6Q9tCq2yiFRmcSMKvHgUgh8yQC,NodeID-QDYnWDQd6g4cQ5H6yiWNqSmfRMBqEH9AG"
  --bootstrap-ips="52.201.126.172:9651,34.233.248.130:9651,107.21.11.213:9651,35.170.144.5:9651,98.82.41.186:9651"

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I used all validators available.
let me fix this. and also open a PR for ANR

Comment on lines +32 to +35
avalanchegoBootstrapIDs []string,
avalanchegoBootstrapIPs []string,
avalanchegoGenesisFilePath string,
avalanchegoUpgradeFilePath string,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it be worth encapsulating all of these options in an AvalancheGoConfigOptions struct so that they don't need to be passed around individually?

@@ -182,8 +182,18 @@ func RunSSHUpgradeAvalanchego(host *models.Host, network models.Network, avalanc
if err != nil {
return err
}

if err := docker.ComposeSSHSetupNode(host, network, avalancheGoVersion, withMonitoring, publicAccessToHTTPPort); err != nil {
if err := docker.ComposeOverSSH("Compose Node",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks like we can rid of the network parameter here now if it's no longer used?

arturrez and others added 3 commits October 10, 2024 11:08
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Comment on lines +137 to +138
cmd.Flags().StringArrayVar(&bootstrapIDs, "bootstrap-ids", []string{}, "nodeIDs of bootstrap nodes")
cmd.Flags().StringArrayVar(&bootstrapIPs, "bootstrap-ips", []string{}, "IP:port pairs of bootstrap nodes")
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't think we need to even enable flags for bootstrap ids and bootstrap ips. Lets just set these values to hardcoded values if users want join etna devnet.

@arturrez arturrez force-pushed the acp77-remote-etna-devnet branch from e691af8 to ed42043 Compare October 17, 2024 22:17
Comment on lines 213 to 231
// bootsrap checks
if useEtnaDevnet && (len(bootstrapIDs) != 0 || len(bootstrapIPs) != 0 || genesisPath != "" || upgradePath != "") {
return fmt.Errorf("etna devnet uses predefined bootsrap configuration")
}
if len((bootstrapIDs)) != len(bootstrapIPs) {
return fmt.Errorf("number of bootstrap ids and ip:port pairs must be equal")
}
if genesisPath != "" && !utils.FileExists(genesisPath) {
return fmt.Errorf("genesis file %s does not exist", genesisPath)
}
if upgradePath != "" && !utils.FileExists(upgradePath) {
return fmt.Errorf("upgrade file %s does not exist", upgradePath)
}
// check ip:port pairs
for _, ipPortPair := range bootstrapIPs {
if ok := utils.IsValidIPPort(ipPortPair); !ok {
return fmt.Errorf("invalid ip:port pair %s", ipPortPair)
}
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Dont think flags for bootstrap id and ip should even exist

@sukantoraymond sukantoraymond merged commit a24d214 into acp-77 Oct 18, 2024
27 of 31 checks passed
@sukantoraymond sukantoraymond deleted the acp77-remote-etna-devnet branch October 18, 2024 14:33
sukantoraymond added a commit that referenced this pull request Nov 23, 2024
* acp-77

* fix lint

* address comments

* fix test

* make pos coming soon

* update test

* Prompts for Subnet create acp77 (#2150)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* address comments

* fix test

* address comments

* fix lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

* Validator prompt acp77 (#2152)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* validator prompt

* bootstrap validators

* add mock

* fix lint

* update prompt validator

* update prompt validator

* implement prompts

* fix prompt mock

* update sidecar

* update prompts

* update prompts

* refactor

* update prompts

* update prompts

* use default balance and weight

* generate new node ids and bls

* fix lint

* add flags

* add flags

* address comments

* address comments

* address comments

* move validator prompt to deploy

* address comments

* address comments

* fix lint

* address comments

* address comments

* fix test

* address comments

* fix lint

* address coments

* address coments

* fix test

* fix test

* fix test

* fix lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

* Genesis icm (#2154)

* adding teleporter contract to genesis

* fixes for icm on genesis

* add icm from a given embedded file

* add function to deploy ICM registry

* creating mapping values

* add consts

* make local deploy to work

* do not print info for icm support addrs

* nit

* nit

* fix wiz stuff

* address PR comments

* filter based on balance

* add unit tests

* Update cmd/blockchaincmd/describe.go

Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: felipemadero <felipe.madero@gmail.com>

* lint

---------

Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>

* lint

* Genesis poa (#2164)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* adding teleporter contract to genesis

* validator prompt

* bootstrap validators

* add mock

* fix lint

* update prompt validator

* update prompt validator

* fixes for icm on genesis

* add icm from a given embedded file

* add function to deploy ICM registry

* creating mapping values

* add consts

* make local deploy to work

* do not print info for icm support addrs

* nit

* implement prompts

* fix prompt mock

* update sidecar

* update prompts

* update prompts

* refactor

* nit

* update prompts

* fix wiz stuff

* update prompts

* use default balance and weight

* generate new node ids and bls

* fix lint

* add flags

* add flags

* add a function to initialize PoA manager

* add lib folder

* address comments

* address comments

* address comments

* move validator prompt to deploy

* address comments

* address comments

* fix lint

* address comments

* address comments

* fix test

* address PR comments

* basic PoA manager setting

* lint

* address comments

* fix lint

* fix e2e

* fix merge

* fix merge

* filter based on balance

* add unit tests

* nit

* address PR comments

* Update cmd/blockchaincmd/describe.go

Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: felipemadero <felipe.madero@gmail.com>

* nit

* address PR comments

* lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>

* Signature aggregator sdk (#2149)

* wip

* go mod tidy

* use awm-relayer@main

* fixes

* use latest awm-relayer pkg  which caused upgrade on coreth and avago  - has to be resolved

* use latest anr and rm prometheus metrics

* check for errors

* lint

* mv to sdk/interchain

* some refactoring and added unittests

* fix license

* fix unittest for now

* fix lint

* allow empty subnetID
add usage working example

* rm error msg from example

* refactor to address felipe feedback

* we should remove this from the test in favour of https://github.com/ava-labs/awm-relayer/blob/main/signature-aggregator/aggregator/aggregator_test.go - we just use exposed API

* update readme example

* rm goconst fix CI

* put `- goconst` back

* resolve conficts

---------

Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>

* Fix acp 77 ci (#2204)

* use latest anr main

* tidy

* bump e2e avago version to be dynamic fee compatible

* fix e2e for dynamic fees

* lint

* ACP 77 new commands (#2172)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* adding teleporter contract to genesis

* validator prompt

* bootstrap validators

* add mock

* fix lint

* update prompt validator

* update prompt validator

* fixes for icm on genesis

* add icm from a given embedded file

* add function to deploy ICM registry

* creating mapping values

* add consts

* make local deploy to work

* do not print info for icm support addrs

* nit

* implement prompts

* fix prompt mock

* update sidecar

* update prompts

* update prompts

* refactor

* nit

* update prompts

* fix wiz stuff

* update prompts

* use default balance and weight

* generate new node ids and bls

* fix lint

* add flags

* add flags

* add a function to initialize PoA manager

* add lib folder

* address comments

* address comments

* address comments

* move validator prompt to deploy

* address comments

* address comments

* fix lint

* address comments

* address comments

* fix test

* address PR comments

* basic PoA manager setting

* lint

* address comments

* fix lint

* fix e2e

* fix merge

* fix merge

* convert Subnet Tx

* convert subnet

* register validator

* add validator

* mock

* remove validator

* update weight

* update weight

* add flags add validator

* remove validator update

* refactor addvalidator

* use node id as arg in addvalidator

* fix change weight arg

* resolve merge conflict

* fix lint

* address comments

* fix lint

* Enable non sov subnets (#2203)

* subnet create non sov

* support non sov blockchain

* update test

* update tests

* update tests

* update test

* update tests

* update tests

* fix test

* update tests

* Rename Subnet to L1 for new commands ACP77 (#2209)

* rename convert subnet

* rename to l1

* fix lint

* fix lint

* fix lint

* fix lint

* Integrate ConvertSubnetTx AvalancheGo  (#2213)

* complete implementation of avalanche go convertsubnet

* update relayer

* update convertsubnettx

* update avalanchego

* update avalanche go

* update avalanche go

* dont prompt control key for sov

* add tx cases for convert subnet tx (#2218)

* Poa integration (#2212)

* use latest contract

* point to latest convert subnet avago PR

* nit

* use fixed anr

* nit

* add subnet conversion id calculation

* created unsigned warp message

* fixed local network deploy

* added signing

* now this is working

* using latest avago master + awm relayer

* working pretty well

* ready

* lint

* address PR comments

* nit

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* fix lint

* reverse sidecar sov logic

* fix merge

* add poa setup to blockchain deploy (#2219)

* add setup poa to blockchain deploy

* add command

* add proposervm update

* proposervm flag for nodes

* nit

* nit

* fixed dynamic fees params calculation

* only adding tracked apis to apis in sidecar

* improve prompts

* fixing various stuff

* add upgrade file

* use anr etna enabled

* keep upgrade on sync

* workin

* almost working

* working1

* Update cmd/keycmd/transfer.go

Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>
Signed-off-by: felipemadero <felipe.madero@gmail.com>

* fix some lint

* address PR comments

* missing file

* nit

---------

Signed-off-by: felipemadero <felipe.madero@gmail.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>

* fix lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>

* fix merge

* Track subnet refactor  (#2228)

* refactor subnet sync

* fix lint

* Remove redundancies (#2229)

* remove redundant code

* fix lint

* fix lint

* Convert Subnet in  1 command (#2230)

* one command deploy

* use default private key to deploy validator manager contract

* fix lint

* remove redundant code

* address comments

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

* Fix generate new node id and bls info (#2237)

* generate new node id

* fix lint

* assume blockchain endpoint only for cli managed node sync (#2241)

* fix merge

* node local PoC (#2216)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* use anr main

* fix merge

* Local mkdir rootdir (#2245)

* make sure rootDir exists

* mv it to proper location

* it's done before the start

* update anr

* Integrate local devnet (#2254)

* integrate deploy

* integrate deploy

* Fix lint

* address comments

* address comments

* Integrate start (#2262)

* integrate start

* integrate start

* update etna network

* integrate start

* integrate start

* finish integrate start

* fix lint

* stop existing local avalanchego

* more robust

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* go 1.22.8 for dockerfile

* Node local status (#2261)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* use anr main

* fix merge

* Local mkdir rootdir (#2245)

* make sure rootDir exists

* mv it to proper location

* it's done before the start

* update anr

* add `node local status` command

* add logging.Green.Wrap(
lint

* lint

* fix merge

* make `node status` works with local clusters
more lint fixes

* detect Stopped state for local clusterName passed as arg

* add stopped status to all local clusters

* undo change

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* fix lint

* fix merge

* Register validator local (#2247)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* partial work

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* not to much further to have a complete flow

* ok esto esta funcionando

* started refactoring

* use relayer branch

* partial work

* use anr main

* working for devnets

* is this working

* working for local

* nit

* working

* bump anr

* Fix merge

* Fix merge

* Fix merge

* Update avalanche go ledger (#2234)

* update avalanche go ledger

* fixes

* nit

* update prompt

* update tests

* update avalanchego

---------

Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>

* lint

* fix merge

* nits

* lint

* fix merge

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* fix lint

* lint

* Validator removal (#2267)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* partial work

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* not to much further to have a complete flow

* ok esto esta funcionando

* started refactoring

* use relayer branch

* partial work

* use anr main

* working for devnets

* is this working

* working for local

* nit

* working

* bump anr

* initialization

* nit

* add last step

* split

* nit

* nit

* nit

* improval

* Fix merge

* Fix merge

* Fix merge

* nits

* lint

* fix merge

* add tracing function for tx on blockchain

* now I have control of logs

* added log level flag for aggregator

* improve err management a bit more

* working

* adjust weights

* nits

* nit

* nits

* lint

* nit

* nit

* nit

* lint

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* lint

* make sure that we return empty clusterconf if cluster not found (#2269)

* Fix case where node is not generated before calling subnet deploy (#2270)

* fix no local

* fix generatre nod eid

* Use existing cluster deploy (#2271)

* fix no local

* fix generatre nod eid

* integrate deploy

* fix lint

* rm local machine cluster

* check for bootstrap endpoints before populating this slice

* lint

* fix inventory err for local (#2272)

* fix merge

---------

Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>

* Acp77 remote etna devnet (#2233)

* etna devnet constants

* add custom bootrap conf to node create

* Update cmd/nodecmd/create.go

Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* add unittests for ip:port pair verificatoion

* update etna bootstrap info

* add  AvalancheGoConfigOptions struct

* etnadevnet network model

* write data to files

* err handling

* support etna devnet

* fix address input

* allow public access to rpc endpoint for etna devnet

* add ux to report public access to user

* read bls info and nodeid for the cluster

* added 0x to string, added log

* fix issue with http_host reverted after sync

* resolve conflict

* lint

* after merge fixes

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>

* properly create nodes dir and cluster config file (#2273)

* Acp use etna devnet (#2275)

* fix

* push

* Cleanup AddValidator command (#2276)

* cleanup addvalidator command

* fix lint

* fix lint

* dont print err if fail on repeat

* fix lint (#2277)

* fix err msg

* print all errors (#2279)

* Check max balance on add validator (#2278)

* regen mocks

* addres PR comment

* address PR comment

* Continue on error remove validator (#2280)

* contiunue if validator removal process already started

* address PR comment

* Acp77 remote enta cluster fixes (#2281)

* put getClusterBootstrapValidators back

* lint

* add remore cluster helper for signature aggr

* lint

* fix merge

* update avalanche go tag

* remove dummy txs

* remove dummy txs

* Acp77 e2e (#2287)

* print all errors

* e2e acp77

* update test

* update test

* update test

* fix merge

* fix merge

* fix test

* fix lint

* update test

* update test

* fix ci

* update flags

* update tests

* update test

* update test

* update test

* update test

* update test

* update tests

* Acp77 e2e etna add remove validator flow (#2290)

* etna devnet add remove validator

* add remove validator

* fixes

* fix

* get blockchain ID from output

* more fixes

* lint

* add key

* add sov validator e2e on linux only

* fix typo

* use macosx becuse of the avalanchego poc.5 binary in the assets

* fix test

* update test

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>

* fix lint

* integrate main change

* Fix lint

* update binary for test

* add node configs to local cluster (#2296)

* Acp 77 fix (#2284)

* fix for meag env to work

* lint

* fix

* use anr without issue

* use anr main

* improve checks and inconsistency management

* fix lint

* Node local status more info  (#2288)

* wip

* added blockchain status support
fix typos

* address raymond feedback

* improve ux

* Your blockchain

* Validator Manager SDK (#2297)

* validator manager sdk

* fix lint

* fix lint

* remove duplicate code

* fix description

* update test

* complete test

* lint

* lint

* lint

* lint

* lint

* increase health timeout after network restart (#2299)

* increase health timeout after network restart

* fix unit tests

* fix keys e2e

* nits

* nit

* nit

* fix e2e

* use latest relayer dep (#2315)

* Use network name instead of cluster name on sidecar (#2303)

* use network instead of cluster

* replace clustername with network

* update test

* fix test

* fix test

* fix lint

* fix lint

* fix test

* fix lint

* fix test

* fix lint

* address comments

* fix lint

* address comments

* fix lint

* fix conflict

* fix lint

* fuji local clusters (#2309)

* fix contexts and signals

* add fuji cluster

* lint

* point to anr main

* address PR comments

* remove unused function

* address PR comments

* add flags for partial sync to local and remote

* fix panic

* fix e2e

* Update tag (#2332)

* update tag

* update relayer

* update tag

* fixes

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>

* no op

* no op

* Update e2e avago (#2342)

* use avago 1.11.13 to support evm 0.6.12

* fix avago dep

* lint

* use anr main

* Acp 77 PoS using sdk/validatorManager (#2308)

* mv changes frrom pos

* move from pos branch

* mocks

* sync with latest pos/ refactor PoS to sdk approach

* wip

* fix lint. get rid of example in var names, fix sdk<->pkg for validatormanager to make it DRY

* fix err in sdk

* PoS default values

* use sidecar for pos detection with force flag

* rename sc validatorManager

* use proxy for poa

* bugfixes and improve add validator for pos

* proper errors from validator manager smart contract

* rename cmd input

* add PoS e2e
add support for proxy Contract for PoA

* fix lint

* e2e fix arg

* fix typo and non needed check

* rm unneeded check

* fix lint

* fixes for the flow PoS vs PoA

* fix pos sidecar case

* refactor add validator add cmd params for inputs

* adjust e2e params

* use test-defaults for e2e POS

* fix bug. disable validator removal for now

* fix e2e

* address Raymond feedback

* add default value for delegation fee

* use stake-period for PoS

* read balance

* force uint64

* 100s

* add validatorManagerSettings to sdk

* provide default params for PoS and move networkBalance to utils

* add prompt verification for token amount input

* fix PromptChain. not sure how it was included into this PR and where this change is coming from

* address latest feedback

* lint

* improve user output

* Acp77 PoS Validator removal without proof of uptime  (#2338)

* add pos validator removal
debug

* continue debugging pos validator removal

* r4r

* lint

* fix e2e Error: failure initializing validator removal: min stake duration not passed (tx failed to be submitted)

* wait 90sec for min validation period

* min stake duration is 100

* update sidecar after bootstrap validator removed

* disable e2e for removing PoS bootstrap validator

* use 100s

* remove pos non bootstrap validator e2e

* add validator and remove it

* use 60s staking period

* go back to 90 and 120s

* small refactor

* fix duration prompt

* use minimum 100s

* add prompt check for minimum validator staking timr

* fix etna duration input

* use etna for name

* add debug info

* rm debug
force validator removal for PoS

* no need to updatePchainHeight

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* fix PosManager init

* use clusterNameFlagValue

* rm debug

* remove incorrect available balance

* fix lint

* update avalanchego

* update merge

* lint

* update merge

* fix lint

* update acp 77

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>

* e2e - disable PoS non-bootstrap validator removal

* add mainnet check (#2346)

* disable change owner for sov (#2347)

* Use v1.12.0 fuji on e2e (#2344)

* use avago v1.12.0-fuji on etna e2e

* update avalanchego

---------

Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>

* Acp7 change owner single prompt (#2350)

* reuse prompted addr as a change owner address for blockchain deploy

* mv code closer to SoV

* consistent address display to user

* we should not return err as we will ask in separate prompt later in the flow if provided key didn't work

* Acp77 init validator manager (#2349)

* replace initPoAValidatormanager and initPoSValidatorManager with single initValidatorManager cmd

* lint

* remove flag (#2345)

* Fix local status (#2353)

* fix l1 status for node local

* add e2e for node local cluster status

* add node local status for PoA

* add sleep and fix regex

* missed regex change

* add e2e for status

* simplify regex

* filter network options to deployed networks

* Revert "filter network options to deployed networks"

This reverts commit 4978276.

* Fix acp77 e2e (#2358)

* fix pattern

* nit

* Filter network (#2356)

* filter network

* address comments

* fix case

* allow cluster in flags

* allow cluster in flags

---------

Co-authored-by: arturrez <artur.reznikov@avalabs.org>

* Install binary for avalanchego instead of providing local path (#2351)

* dont force users to add local build

* remove avalanche go binary in test

* update test

* fix lint

* update test

* update node create

* update node create

* update node create

* update node create

* update pos test

* custom endponit etna (#2354)

* update test

* address comments

* undo avalanche go dir change

* fix lint

* fix e2e public

* update deploy

* lint

* fix e2e

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>
Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
felipemadero added a commit that referenced this pull request Nov 30, 2024
* acp-77

* fix lint

* address comments

* fix test

* make pos coming soon

* update test

* Prompts for Subnet create acp77 (#2150)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* address comments

* fix test

* address comments

* fix lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

* Validator prompt acp77 (#2152)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* validator prompt

* bootstrap validators

* add mock

* fix lint

* update prompt validator

* update prompt validator

* implement prompts

* fix prompt mock

* update sidecar

* update prompts

* update prompts

* refactor

* update prompts

* update prompts

* use default balance and weight

* generate new node ids and bls

* fix lint

* add flags

* add flags

* address comments

* address comments

* address comments

* move validator prompt to deploy

* address comments

* address comments

* fix lint

* address comments

* address comments

* fix test

* address comments

* fix lint

* address coments

* address coments

* fix test

* fix test

* fix test

* fix lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

* Genesis icm (#2154)

* adding teleporter contract to genesis

* fixes for icm on genesis

* add icm from a given embedded file

* add function to deploy ICM registry

* creating mapping values

* add consts

* make local deploy to work

* do not print info for icm support addrs

* nit

* nit

* fix wiz stuff

* address PR comments

* filter based on balance

* add unit tests

* Update cmd/blockchaincmd/describe.go

Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: felipemadero <felipe.madero@gmail.com>

* lint

---------

Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>

* lint

* Genesis poa (#2164)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* adding teleporter contract to genesis

* validator prompt

* bootstrap validators

* add mock

* fix lint

* update prompt validator

* update prompt validator

* fixes for icm on genesis

* add icm from a given embedded file

* add function to deploy ICM registry

* creating mapping values

* add consts

* make local deploy to work

* do not print info for icm support addrs

* nit

* implement prompts

* fix prompt mock

* update sidecar

* update prompts

* update prompts

* refactor

* nit

* update prompts

* fix wiz stuff

* update prompts

* use default balance and weight

* generate new node ids and bls

* fix lint

* add flags

* add flags

* add a function to initialize PoA manager

* add lib folder

* address comments

* address comments

* address comments

* move validator prompt to deploy

* address comments

* address comments

* fix lint

* address comments

* address comments

* fix test

* address PR comments

* basic PoA manager setting

* lint

* address comments

* fix lint

* fix e2e

* fix merge

* fix merge

* filter based on balance

* add unit tests

* nit

* address PR comments

* Update cmd/blockchaincmd/describe.go

Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: felipemadero <felipe.madero@gmail.com>

* nit

* address PR comments

* lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>

* Signature aggregator sdk (#2149)

* wip

* go mod tidy

* use awm-relayer@main

* fixes

* use latest awm-relayer pkg  which caused upgrade on coreth and avago  - has to be resolved

* use latest anr and rm prometheus metrics

* check for errors

* lint

* mv to sdk/interchain

* some refactoring and added unittests

* fix license

* fix unittest for now

* fix lint

* allow empty subnetID
add usage working example

* rm error msg from example

* refactor to address felipe feedback

* we should remove this from the test in favour of https://github.com/ava-labs/awm-relayer/blob/main/signature-aggregator/aggregator/aggregator_test.go - we just use exposed API

* update readme example

* rm goconst fix CI

* put `- goconst` back

* resolve conficts

---------

Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>

* Fix acp 77 ci (#2204)

* use latest anr main

* tidy

* bump e2e avago version to be dynamic fee compatible

* fix e2e for dynamic fees

* lint

* ACP 77 new commands (#2172)

* prompt addresses

* fix lint

* fix lint

* fix lint

* fix lint

* add flags

* adding teleporter contract to genesis

* validator prompt

* bootstrap validators

* add mock

* fix lint

* update prompt validator

* update prompt validator

* fixes for icm on genesis

* add icm from a given embedded file

* add function to deploy ICM registry

* creating mapping values

* add consts

* make local deploy to work

* do not print info for icm support addrs

* nit

* implement prompts

* fix prompt mock

* update sidecar

* update prompts

* update prompts

* refactor

* nit

* update prompts

* fix wiz stuff

* update prompts

* use default balance and weight

* generate new node ids and bls

* fix lint

* add flags

* add flags

* add a function to initialize PoA manager

* add lib folder

* address comments

* address comments

* address comments

* move validator prompt to deploy

* address comments

* address comments

* fix lint

* address comments

* address comments

* fix test

* address PR comments

* basic PoA manager setting

* lint

* address comments

* fix lint

* fix e2e

* fix merge

* fix merge

* convert Subnet Tx

* convert subnet

* register validator

* add validator

* mock

* remove validator

* update weight

* update weight

* add flags add validator

* remove validator update

* refactor addvalidator

* use node id as arg in addvalidator

* fix change weight arg

* resolve merge conflict

* fix lint

* address comments

* fix lint

* Enable non sov subnets (#2203)

* subnet create non sov

* support non sov blockchain

* update test

* update tests

* update tests

* update test

* update tests

* update tests

* fix test

* update tests

* Rename Subnet to L1 for new commands ACP77 (#2209)

* rename convert subnet

* rename to l1

* fix lint

* fix lint

* fix lint

* fix lint

* Integrate ConvertSubnetTx AvalancheGo  (#2213)

* complete implementation of avalanche go convertsubnet

* update relayer

* update convertsubnettx

* update avalanchego

* update avalanche go

* update avalanche go

* dont prompt control key for sov

* add tx cases for convert subnet tx (#2218)

* Poa integration (#2212)

* use latest contract

* point to latest convert subnet avago PR

* nit

* use fixed anr

* nit

* add subnet conversion id calculation

* created unsigned warp message

* fixed local network deploy

* added signing

* now this is working

* using latest avago master + awm relayer

* working pretty well

* ready

* lint

* address PR comments

* nit

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* fix lint

* reverse sidecar sov logic

* fix merge

* add poa setup to blockchain deploy (#2219)

* add setup poa to blockchain deploy

* add command

* add proposervm update

* proposervm flag for nodes

* nit

* nit

* fixed dynamic fees params calculation

* only adding tracked apis to apis in sidecar

* improve prompts

* fixing various stuff

* add upgrade file

* use anr etna enabled

* keep upgrade on sync

* workin

* almost working

* working1

* Update cmd/keycmd/transfer.go

Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>
Signed-off-by: felipemadero <felipe.madero@gmail.com>

* fix some lint

* address PR comments

* missing file

* nit

---------

Signed-off-by: felipemadero <felipe.madero@gmail.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>

* fix lint

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>

* fix merge

* Track subnet refactor  (#2228)

* refactor subnet sync

* fix lint

* Remove redundancies (#2229)

* remove redundant code

* fix lint

* fix lint

* Convert Subnet in  1 command (#2230)

* one command deploy

* use default private key to deploy validator manager contract

* fix lint

* remove redundant code

* address comments

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>

* Fix generate new node id and bls info (#2237)

* generate new node id

* fix lint

* assume blockchain endpoint only for cli managed node sync (#2241)

* fix merge

* node local PoC (#2216)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* use anr main

* fix merge

* Local mkdir rootdir (#2245)

* make sure rootDir exists

* mv it to proper location

* it's done before the start

* update anr

* Integrate local devnet (#2254)

* integrate deploy

* integrate deploy

* Fix lint

* address comments

* address comments

* Integrate start (#2262)

* integrate start

* integrate start

* update etna network

* integrate start

* integrate start

* finish integrate start

* fix lint

* stop existing local avalanchego

* more robust

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* go 1.22.8 for dockerfile

* Node local status (#2261)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* use anr main

* fix merge

* Local mkdir rootdir (#2245)

* make sure rootDir exists

* mv it to proper location

* it's done before the start

* update anr

* add `node local status` command

* add logging.Green.Wrap(
lint

* lint

* fix merge

* make `node status` works with local clusters
more lint fixes

* detect Stopped state for local clusterName passed as arg

* add stopped status to all local clusters

* undo change

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* fix lint

* fix merge

* Register validator local (#2247)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* partial work

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* not to much further to have a complete flow

* ok esto esta funcionando

* started refactoring

* use relayer branch

* partial work

* use anr main

* working for devnets

* is this working

* working for local

* nit

* working

* bump anr

* Fix merge

* Fix merge

* Fix merge

* Update avalanche go ledger (#2234)

* update avalanche go ledger

* fixes

* nit

* update prompt

* update tests

* update avalanchego

---------

Co-authored-by: Felipe Madero <felipe.madero@gmail.com>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>

* lint

* fix merge

* nits

* lint

* fix merge

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* fix lint

* lint

* Validator removal (#2267)

* node local init

* hardcode etna devnet config

* wip

* rm not needed utils

* ready for draft PR

* nits
rm unused struct

* refactor - wip

* make sure we can resume without prompts

* add custom network and local cluster

* devnet instead of custom network, rm custom

* go mod tidy

* upgrade.json for etna devnet

* more local cluster

* partial work

* separate between local network and local cluster

* working

* nit

* fix plugin

* nit

* improve snapshot management

* fix bug

* nit

* proper etna devnet boostrappers

* fix bug with local rootdir

* remove global node config stuff

* destroy node data and processes if bad start

* nit

* always use fresh staking keys

* nit

* so less flags

* add back fast boot time

* add checks for local cluster. minor refactor (#2239)

* add checks for local cluster
minor refactoring

* fix test

* addressed Felipe feedback

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* bump anr

* fixes for convert flow

* add check for already initialized error on PoA init

* nit

* not to much further to have a complete flow

* ok esto esta funcionando

* started refactoring

* use relayer branch

* partial work

* use anr main

* working for devnets

* is this working

* working for local

* nit

* working

* bump anr

* initialization

* nit

* add last step

* split

* nit

* nit

* nit

* improval

* Fix merge

* Fix merge

* Fix merge

* nits

* lint

* fix merge

* add tracing function for tx on blockchain

* now I have control of logs

* added log level flag for aggregator

* improve err management a bit more

* working

* adjust weights

* nits

* nit

* nits

* lint

* nit

* nit

* nit

* lint

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: sukantoraymond <rsukanto@umich.edu>

* lint

* make sure that we return empty clusterconf if cluster not found (#2269)

* Fix case where node is not generated before calling subnet deploy (#2270)

* fix no local

* fix generatre nod eid

* Use existing cluster deploy (#2271)

* fix no local

* fix generatre nod eid

* integrate deploy

* fix lint

* rm local machine cluster

* check for bootstrap endpoints before populating this slice

* lint

* fix inventory err for local (#2272)

* fix merge

---------

Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>

* Acp77 remote etna devnet (#2233)

* etna devnet constants

* add custom bootrap conf to node create

* Update cmd/nodecmd/create.go

Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* add unittests for ip:port pair verificatoion

* update etna bootstrap info

* add  AvalancheGoConfigOptions struct

* etnadevnet network model

* write data to files

* err handling

* support etna devnet

* fix address input

* allow public access to rpc endpoint for etna devnet

* add ux to report public access to user

* read bls info and nodeid for the cluster

* added 0x to string, added log

* fix issue with http_host reverted after sync

* resolve conflict

* lint

* after merge fixes

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>

* properly create nodes dir and cluster config file (#2273)

* Acp use etna devnet (#2275)

* fix

* push

* Cleanup AddValidator command (#2276)

* cleanup addvalidator command

* fix lint

* fix lint

* dont print err if fail on repeat

* fix lint (#2277)

* fix err msg

* print all errors (#2279)

* Check max balance on add validator (#2278)

* regen mocks

* addres PR comment

* address PR comment

* Continue on error remove validator (#2280)

* contiunue if validator removal process already started

* address PR comment

* Acp77 remote enta cluster fixes (#2281)

* put getClusterBootstrapValidators back

* lint

* add remore cluster helper for signature aggr

* lint

* fix merge

* update avalanche go tag

* remove dummy txs

* remove dummy txs

* Acp77 e2e (#2287)

* print all errors

* e2e acp77

* update test

* update test

* update test

* fix merge

* fix merge

* fix test

* fix lint

* update test

* update test

* fix ci

* update flags

* update tests

* update test

* update test

* update test

* update test

* update test

* update tests

* Acp77 e2e etna add remove validator flow (#2290)

* etna devnet add remove validator

* add remove validator

* fixes

* fix

* get blockchain ID from output

* more fixes

* lint

* add key

* add sov validator e2e on linux only

* fix typo

* use macosx becuse of the avalanchego poc.5 binary in the assets

* fix test

* update test

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>

* fix lint

* integrate main change

* Fix lint

* update binary for test

* add node configs to local cluster (#2296)

* Acp 77 fix (#2284)

* fix for meag env to work

* lint

* fix

* use anr without issue

* use anr main

* improve checks and inconsistency management

* fix lint

* Node local status more info  (#2288)

* wip

* added blockchain status support
fix typos

* address raymond feedback

* improve ux

* Your blockchain

* Validator Manager SDK (#2297)

* validator manager sdk

* fix lint

* fix lint

* remove duplicate code

* fix description

* update test

* complete test

* lint

* lint

* lint

* lint

* lint

* increase health timeout after network restart (#2299)

* increase health timeout after network restart

* fix unit tests

* fix keys e2e

* nits

* nit

* nit

* fix e2e

* use latest relayer dep (#2315)

* Use network name instead of cluster name on sidecar (#2303)

* use network instead of cluster

* replace clustername with network

* update test

* fix test

* fix test

* fix lint

* fix lint

* fix test

* fix lint

* fix test

* fix lint

* address comments

* fix lint

* address comments

* fix lint

* fix conflict

* fix lint

* fuji local clusters (#2309)

* fix contexts and signals

* add fuji cluster

* lint

* point to anr main

* address PR comments

* remove unused function

* address PR comments

* add flags for partial sync to local and remote

* fix panic

* fix e2e

* Update tag (#2332)

* update tag

* update relayer

* update tag

* fixes

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Co-authored-by: Felipe Madero <felipe.madero@gmail.com>

* make network start to create a new network without boostrap snapshot

* add flags struct to network start and stop

* just start network if --local, not use local deployer

* add upgrade to local network

* added aliases on track

* no op

* no op

* Update e2e avago (#2342)

* use avago 1.11.13 to support evm 0.6.12

* fix avago dep

* lint

* use anr main

* Acp 77 PoS using sdk/validatorManager (#2308)

* mv changes frrom pos

* move from pos branch

* mocks

* sync with latest pos/ refactor PoS to sdk approach

* wip

* fix lint. get rid of example in var names, fix sdk<->pkg for validatormanager to make it DRY

* fix err in sdk

* PoS default values

* use sidecar for pos detection with force flag

* rename sc validatorManager

* use proxy for poa

* bugfixes and improve add validator for pos

* proper errors from validator manager smart contract

* rename cmd input

* add PoS e2e
add support for proxy Contract for PoA

* fix lint

* e2e fix arg

* fix typo and non needed check

* rm unneeded check

* fix lint

* fixes for the flow PoS vs PoA

* fix pos sidecar case

* refactor add validator add cmd params for inputs

* adjust e2e params

* use test-defaults for e2e POS

* fix bug. disable validator removal for now

* fix e2e

* address Raymond feedback

* add default value for delegation fee

* use stake-period for PoS

* read balance

* force uint64

* 100s

* add validatorManagerSettings to sdk

* provide default params for PoS and move networkBalance to utils

* add prompt verification for token amount input

* fix PromptChain. not sure how it was included into this PR and where this change is coming from

* address latest feedback

* lint

* improve user output

* Acp77 PoS Validator removal without proof of uptime  (#2338)

* add pos validator removal
debug

* continue debugging pos validator removal

* r4r

* lint

* fix e2e Error: failure initializing validator removal: min stake duration not passed (tx failed to be submitted)

* wait 90sec for min validation period

* min stake duration is 100

* update sidecar after bootstrap validator removed

* disable e2e for removing PoS bootstrap validator

* use 100s

* remove pos non bootstrap validator e2e

* add validator and remove it

* use 60s staking period

* go back to 90 and 120s

* small refactor

* fix duration prompt

* use minimum 100s

* add prompt check for minimum validator staking timr

* fix etna duration input

* use etna for name

* add debug info

* rm debug
force validator removal for PoS

* no need to updatePchainHeight

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>

* fix PosManager init

* use clusterNameFlagValue

* rm debug

* remove incorrect available balance

* fix lint

* update avalanchego

* update merge

* lint

* update merge

* fix lint

* update acp 77

---------

Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>

* e2e - disable PoS non-bootstrap validator removal

* nosov working

* add mainnet check (#2346)

* disable change owner for sov (#2347)

* teleporter almost working for local

* teleporter deploy working for local

* move relayer to other place

* add flags to relayer deploy command so can be executed without prompts

* intergated relayer deploy for local network

* Use v1.12.0 fuji on e2e (#2344)

* use avago v1.12.0-fuji on etna e2e

* update avalanchego

---------

Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>

* fix root dir

* Acp7 change owner single prompt (#2350)

* reuse prompted addr as a change owner address for blockchain deploy

* mv code closer to SoV

* consistent address display to user

* we should not return err as we will ask in separate prompt later in the flow if provided key didn't work

* Acp77 init validator manager (#2349)

* replace initPoAValidatormanager and initPoSValidatorManager with single initValidatorManager cmd

* lint

* add validators

* remove flag (#2345)

* fixed validators issue

* lint

* remove single node settings

* reenabling teleporter

* Fix local status (#2353)

* fix l1 status for node local

* add e2e for node local cluster status

* add node local status for PoA

* add sleep and fix regex

* missed regex change

* add e2e for status

* simplify regex

* nit

* if only blockchain id is given for genesis key search, provide
the managed key with max balance

* use a given relayer binary

* filter network options to deployed networks

* Revert "filter network options to deployed networks"

This reverts commit 4978276.

* add prompt to decide if install relayer

* final fixes

* lint

* Fix acp77 e2e (#2358)

* fix pattern

* nit

* fix parts of e2e

* add the snapshots again to not brack backward compat

* fix network e2e + persist avago + relayer path

* start doing some merge stuff

* nit

* clean up some e2e to merge

* nits

* lint

* fix unit tests

* fixing packageman for SOV

* fix tracked subnets when deploying multiple blockchains

* add missing file

* add update of blockchain deploy

* nit

* nit

* working again

* fix per node chain config case

* fix some e2e

* supossely public e2e is ok

* nit

* disable teleporter on etna

* make local network to work with relayer 1.5.1

* add subnet evm config for non debug, and set db to leveldb

* reduce local network disk usage from avago logs

* use pre relases on local network by default

* lint

* use also pre release on network start

* add missing file

* deploy relayer for local machine

* do not deploy relayer if fuji

* fix rpc checks for localnet

* avoid using same relayer port for local, etna, fuji

* fix lint

* lint

* fail for nice error for incompatible snapshot

* address PR comments

* fix unit tests

---------

Signed-off-by: sukantoraymond <rsukanto@umich.edu>
Signed-off-by: felipemadero <felipe.madero@gmail.com>
Signed-off-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Raymond Sukanto <rsukanto@umich.edu>
Co-authored-by: Michael Kaplan <55204436+michaelkaplan13@users.noreply.github.com>
Co-authored-by: arturrez <56270896+arturrez@users.noreply.github.com>
Co-authored-by: Meaghan FitzGerald <meag.fitz@avalabs.org>
Co-authored-by: Artur Reznikov <artur.reznikov@avalabs.org>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

3 participants