2018-01-26 18:04:13 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"strings"
|
|
|
|
|
2018-02-01 18:54:23 +00:00
|
|
|
"github.com/CityOfZion/neo-go/pkg/network"
|
2018-01-26 18:04:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2018-02-01 08:00:42 +00:00
|
|
|
tcp = flag.Int("tcp", 3000, "port TCP listener will listen on.")
|
2018-01-26 18:04:13 +00:00
|
|
|
seed = flag.String("seed", "", "initial seed servers.")
|
2018-01-26 20:39:34 +00:00
|
|
|
net = flag.Int("net", 56753, "the mode the server will operate in.")
|
2018-02-01 08:00:42 +00:00
|
|
|
rpc = flag.Int("rpc", 0, "let this server also respond to rpc calls on this port")
|
2018-01-26 18:04:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Simple dirty and quick bootstrapping for the sake of development.
|
|
|
|
// e.g run 2 nodes:
|
2018-02-01 08:00:42 +00:00
|
|
|
// neoserver -tcp :4000
|
|
|
|
// neoserver -tcp :3000 -seed 127.0.0.1:4000
|
2018-01-26 18:04:13 +00:00
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
|
2018-02-01 08:00:42 +00:00
|
|
|
opts := network.StartOpts{
|
|
|
|
Seeds: parseSeeds(*seed),
|
|
|
|
TCP: *tcp,
|
|
|
|
RPC: *rpc,
|
|
|
|
}
|
|
|
|
|
2018-01-26 20:39:34 +00:00
|
|
|
s := network.NewServer(network.NetMode(*net))
|
2018-02-01 08:00:42 +00:00
|
|
|
s.Start(opts)
|
|
|
|
}
|
|
|
|
|
|
|
|
func parseSeeds(s string) []string {
|
|
|
|
if len(s) == 0 {
|
|
|
|
return nil
|
2018-01-26 18:04:13 +00:00
|
|
|
}
|
2018-02-01 08:00:42 +00:00
|
|
|
seeds := strings.Split(s, ",")
|
|
|
|
if len(seeds) == 0 {
|
|
|
|
return nil
|
2018-01-26 18:04:13 +00:00
|
|
|
}
|
2018-02-01 08:00:42 +00:00
|
|
|
return seeds
|
2018-01-26 18:04:13 +00:00
|
|
|
}
|