Skip to content
This repository has been archived by the owner on Aug 19, 2022. It is now read-only.

Commit

Permalink
add a command line flag to set the key type
Browse files Browse the repository at this point in the history
  • Loading branch information
marten-seemann committed Feb 20, 2019
1 parent f10f298 commit 96b3240
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 5 deletions.
25 changes: 22 additions & 3 deletions example/client/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,22 +23,41 @@ func main() {
func startClient() error {
port := flag.Int("p", 5533, "port")
peerIDString := flag.String("id", "", "peer ID")
keyType := flag.String("key", "ecdsa", "rsa, ecdsa, ed25519 or secp256k1")
flag.Parse()

peerID, err := peer.IDB58Decode(*peerIDString)
var priv ic.PrivKey
var err error
switch *keyType {
case "rsa":
fmt.Printf("Generated new peer with an RSA key.")
priv, _, err = ic.GenerateRSAKeyPair(2048, rand.Reader)
case "ecdsa":
fmt.Printf("Generated new peer with an ECDSA key.")
priv, _, err = ic.GenerateECDSAKeyPair(rand.Reader)
case "ed25519":
fmt.Printf("Generated new peer with an Ed25519 key.")
priv, _, err = ic.GenerateEd25519Key(rand.Reader)
case "secp256k1":
fmt.Printf("Generated new peer with an Secp256k1 key.")
priv, _, err = ic.GenerateSecp256k1Key(rand.Reader)
default:
return fmt.Errorf("unknown key type: %s", *keyType)
}
if err != nil {
return err
}

priv, _, err := ic.GenerateECDSAKeyPair(rand.Reader)
peerID, err := peer.IDB58Decode(*peerIDString)
if err != nil {
return err
}

id, err := peer.IDFromPrivateKey(priv)
if err != nil {
return err
}
fmt.Printf("Generated new peer with an ECDSA key. Peer ID: %s\n", id.Pretty())
fmt.Printf(" Peer ID: %s\n", id.Pretty())
tp, err := libp2ptls.New(priv)
if err != nil {
return err
Expand Down
23 changes: 21 additions & 2 deletions example/server/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,17 +21,36 @@ func main() {

func startServer() error {
port := flag.Int("p", 5533, "port")
keyType := flag.String("key", "ecdsa", "rsa, ecdsa, ed25519 or secp256k1")
flag.Parse()

priv, _, err := ic.GenerateECDSAKeyPair(rand.Reader)
var priv ic.PrivKey
var err error
switch *keyType {
case "rsa":
fmt.Printf("Generated new peer with an RSA key.")
priv, _, err = ic.GenerateRSAKeyPair(2048, rand.Reader)
case "ecdsa":
fmt.Printf("Generated new peer with an ECDSA key.")
priv, _, err = ic.GenerateECDSAKeyPair(rand.Reader)
case "ed25519":
fmt.Printf("Generated new peer with an Ed25519 key.")
priv, _, err = ic.GenerateEd25519Key(rand.Reader)
case "secp256k1":
fmt.Printf("Generated new peer with an Secp256k1 key.")
priv, _, err = ic.GenerateSecp256k1Key(rand.Reader)
default:
return fmt.Errorf("unknown key type: %s", *keyType)
}
if err != nil {
return err
}

id, err := peer.IDFromPrivateKey(priv)
if err != nil {
return err
}
fmt.Printf("Generated new peer with an ECDSA key. Peer ID: %s\n", id.Pretty())
fmt.Printf(" Peer ID: %s\n", id.Pretty())
tp, err := libp2ptls.New(priv)
if err != nil {
return err
Expand Down

0 comments on commit 96b3240

Please sign in to comment.