2014-12-10 14:29:22 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/elliptic"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"net"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
|
|
"github.com/ethereum/go-ethereum/logger"
|
|
|
|
"github.com/ethereum/go-ethereum/p2p"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
logger.AddLogSystem(logger.NewStdLogSystem(os.Stdout, log.LstdFlags, logger.InfoLevel))
|
|
|
|
key, _ := crypto.GenerateKey()
|
|
|
|
marshaled := elliptic.Marshal(crypto.S256(), key.PublicKey.X, key.PublicKey.Y)
|
|
|
|
|
|
|
|
srv := p2p.Server{
|
2015-01-04 13:20:16 +00:00
|
|
|
MaxPeers: 100,
|
2014-12-10 14:29:22 +00:00
|
|
|
Identity: p2p.NewSimpleClientIdentity("Ethereum(G)", "0.1", "Peer Server Two", string(marshaled)),
|
|
|
|
ListenAddr: ":30301",
|
|
|
|
NAT: p2p.UPNP(),
|
|
|
|
}
|
|
|
|
if err := srv.Start(); err != nil {
|
|
|
|
fmt.Println("could not start server:", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// add seed peers
|
2015-01-04 13:20:16 +00:00
|
|
|
seed, err := net.ResolveTCPAddr("tcp", "poc-8.ethdev.com:30303")
|
2014-12-10 14:29:22 +00:00
|
|
|
if err != nil {
|
|
|
|
fmt.Println("couldn't resolve:", err)
|
2015-01-04 13:20:16 +00:00
|
|
|
} else {
|
|
|
|
srv.SuggestPeer(seed.IP, seed.Port, nil)
|
2014-12-10 14:29:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
select {}
|
|
|
|
}
|