keygen.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "io"
  6. "io/ioutil"
  7. "os"
  8. "github.com/slackhq/nebula/cert"
  9. )
  10. type keygenFlags struct {
  11. set *flag.FlagSet
  12. outKeyPath *string
  13. outPubPath *string
  14. }
  15. func newKeygenFlags() *keygenFlags {
  16. cf := keygenFlags{set: flag.NewFlagSet("keygen", flag.ContinueOnError)}
  17. cf.set.Usage = func() {}
  18. cf.outPubPath = cf.set.String("out-pub", "", "Required: path to write the public key to")
  19. cf.outKeyPath = cf.set.String("out-key", "", "Required: path to write the private key to")
  20. return &cf
  21. }
  22. func keygen(args []string, out io.Writer, errOut io.Writer) error {
  23. cf := newKeygenFlags()
  24. err := cf.set.Parse(args)
  25. if err != nil {
  26. return err
  27. }
  28. if err := mustFlagString("out-key", cf.outKeyPath); err != nil {
  29. return err
  30. }
  31. if err := mustFlagString("out-pub", cf.outPubPath); err != nil {
  32. return err
  33. }
  34. pub, rawPriv := x25519Keypair()
  35. err = ioutil.WriteFile(*cf.outKeyPath, cert.MarshalX25519PrivateKey(rawPriv), 0600)
  36. if err != nil {
  37. return fmt.Errorf("error while writing out-key: %s", err)
  38. }
  39. err = ioutil.WriteFile(*cf.outPubPath, cert.MarshalX25519PublicKey(pub), 0600)
  40. if err != nil {
  41. return fmt.Errorf("error while writing out-pub: %s", err)
  42. }
  43. return nil
  44. }
  45. func keygenSummary() string {
  46. return "keygen <flags>: create a public/private key pair. the public key can be passed to `nebula-cert sign`"
  47. }
  48. func keygenHelp(out io.Writer) {
  49. cf := newKeygenFlags()
  50. out.Write([]byte("Usage of " + os.Args[0] + " " + keygenSummary() + "\n"))
  51. cf.set.SetOutput(out)
  52. cf.set.PrintDefaults()
  53. }