keygen.go 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  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. curve *string
  15. }
  16. func newKeygenFlags() *keygenFlags {
  17. cf := keygenFlags{set: flag.NewFlagSet("keygen", flag.ContinueOnError)}
  18. cf.set.Usage = func() {}
  19. cf.outPubPath = cf.set.String("out-pub", "", "Required: path to write the public key to")
  20. cf.outKeyPath = cf.set.String("out-key", "", "Required: path to write the private key to")
  21. cf.curve = cf.set.String("curve", "25519", "ECDH Curve (25519, P256)")
  22. return &cf
  23. }
  24. func keygen(args []string, out io.Writer, errOut io.Writer) error {
  25. cf := newKeygenFlags()
  26. err := cf.set.Parse(args)
  27. if err != nil {
  28. return err
  29. }
  30. if err := mustFlagString("out-key", cf.outKeyPath); err != nil {
  31. return err
  32. }
  33. if err := mustFlagString("out-pub", cf.outPubPath); err != nil {
  34. return err
  35. }
  36. var pub, rawPriv []byte
  37. var curve cert.Curve
  38. switch *cf.curve {
  39. case "25519", "X25519", "Curve25519", "CURVE25519":
  40. pub, rawPriv = x25519Keypair()
  41. curve = cert.Curve_CURVE25519
  42. case "P256":
  43. pub, rawPriv = p256Keypair()
  44. curve = cert.Curve_P256
  45. default:
  46. return fmt.Errorf("invalid curve: %s", *cf.curve)
  47. }
  48. err = ioutil.WriteFile(*cf.outKeyPath, cert.MarshalPrivateKey(curve, rawPriv), 0600)
  49. if err != nil {
  50. return fmt.Errorf("error while writing out-key: %s", err)
  51. }
  52. err = ioutil.WriteFile(*cf.outPubPath, cert.MarshalPublicKey(curve, pub), 0600)
  53. if err != nil {
  54. return fmt.Errorf("error while writing out-pub: %s", err)
  55. }
  56. return nil
  57. }
  58. func keygenSummary() string {
  59. return "keygen <flags>: create a public/private key pair. the public key can be passed to `nebula-cert sign`"
  60. }
  61. func keygenHelp(out io.Writer) {
  62. cf := newKeygenFlags()
  63. out.Write([]byte("Usage of " + os.Args[0] + " " + keygenSummary() + "\n"))
  64. cf.set.SetOutput(out)
  65. cf.set.PrintDefaults()
  66. }