mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-03-30 15:08:33 +00:00

* [NOD-570] Separate genesis variables for different netwroks * [NOD-570] Make Testnet genesis * [NOD-570] Make simnet and regtest genesis * [NOD-570] Remake devnet genesis * [NOD-570] Rename regNet -> regTest testnet->testNet * [NOD-570] Change network names to one word instead of camel case * [NOD-570] Change network names to one word instead of camel case * [NOD-570] Fix test names * [NOD-570] Fix TestGHOSTDAG Co-authored-by: Dan Aharoni <dereeno@protonmail.com>
64 lines
1.9 KiB
Go
64 lines
1.9 KiB
Go
/*
|
|
Package dagconfig defines DAG configuration parameters.
|
|
|
|
In addition to the main Kaspa network, which is intended for the transfer
|
|
of monetary value, there also exists the following standard networks:
|
|
* testnet
|
|
* simnet
|
|
* devnet
|
|
* regression test
|
|
These networks are incompatible with each other (each sharing a different
|
|
genesis block) and software should handle errors where input intended for
|
|
one network is used on an application instance running on a different
|
|
network.
|
|
|
|
For library packages, dagconfig provides the ability to lookup DAG
|
|
parameters and encoding magics when passed a *Params.
|
|
|
|
For main packages, a (typically global) var may be assigned the address of
|
|
one of the standard Param vars for use as the application's "active" network.
|
|
When a network parameter is needed, it may then be looked up through this
|
|
variable (either directly, or hidden in a library call).
|
|
|
|
package main
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
|
|
"github.com/kaspanet/kaspad/util"
|
|
"github.com/kaspanet/kaspad/dagconfig"
|
|
)
|
|
|
|
var testnet = flag.Bool("testnet", false, "operate on the testnet Kaspa network")
|
|
|
|
// By default (without --testnet), use mainnet.
|
|
var dagParams = &dagconfig.MainnetParams
|
|
|
|
func main() {
|
|
flag.Parse()
|
|
|
|
// Modify active network parameters if operating on testnet.
|
|
if *testnet {
|
|
dagParams = &dagconfig.TestnetParams
|
|
}
|
|
|
|
// later...
|
|
|
|
// Create and print new payment address, specific to the active network.
|
|
pubKeyHash := make([]byte, 20)
|
|
addr, err := util.NewAddressPubKeyHash(pubKeyHash, dagParams)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
fmt.Println(addr)
|
|
}
|
|
|
|
If an application does not use one of the standard Kaspa networks, a new
|
|
Params struct may be created which defines the parameters for the non-
|
|
standard network. As a general rule of thumb, all network parameters
|
|
should be unique to the network, but parameter collisions can still occur.
|
|
*/
|
|
package dagconfig
|