Skip to content

Commit

Permalink
cmd: add blinded path helper commands
Browse files Browse the repository at this point in the history
Add a blinded-key option to the parse command so that it can be used to
test parsing of an onion for hops in a blinded route. Also add a helper
nextBlindedKey command.
  • Loading branch information
ellemouton committed Dec 20, 2022
1 parent eb768d0 commit 4bf61b8
Showing 1 changed file with 64 additions and 2 deletions.
66 changes: 64 additions & 2 deletions cmd/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,25 @@ func main() {
Usage: "The associated data to include",
Value: defaultAssocData,
},
cli.StringFlag{
Name: "blinding_point",
Usage: "The blinding point to use " +
"when parsing this onion.",
},
},
},
{
Name: "nextblindedpub",
Action: nextBlindedPub,
Flags: []cli.Flag{
cli.StringFlag{
Name: "priv",
Required: true,
},
cli.StringFlag{
Name: "pub",
Required: true,
},
},
},
}
Expand Down Expand Up @@ -228,9 +247,21 @@ func parse(ctx *cli.Context) error {
if len(sessionKeyBytes) != 32 {
return fmt.Errorf("session key must be 32 bytes")
}

sessionKey, _ := btcec.PrivKeyFromBytes(sessionKeyBytes)

var blindingPoint *btcec.PublicKey
if bpStr := ctx.String("blinding_point"); bpStr != "" {
bpBytes, err := hex.DecodeString(bpStr)
if err != nil {
return err
}

blindingPoint, err = btcec.ParsePubKey(bpBytes)
if err != nil {
return err
}
}

onion, err := hex.DecodeString(ctx.String("onion"))
if err != nil {
return err
Expand All @@ -250,7 +281,7 @@ func parse(ctx *cli.Context) error {
defer s.Stop()

p, err := s.ProcessOnionPacket(
&packet, []byte(ctx.String("assocData")), 10, nil,
&packet, []byte(ctx.String("assocData")), 10, blindingPoint,
)
if err != nil {
return err
Expand All @@ -265,3 +296,34 @@ func parse(ctx *cli.Context) error {
fmt.Printf("%x\n", w.Bytes())
return nil
}

func nextBlindedPub(ctx *cli.Context) error {
privKeyByte, err := hex.DecodeString(ctx.String("priv"))
if err != nil {
return err
}
if len(privKeyByte) != 32 {
return fmt.Errorf("private key must be 32 bytes")
}
privKey, _ := btcec.PrivKeyFromBytes(privKeyByte)

pubKeyBytes, err := hex.DecodeString(ctx.String("pub"))
if err != nil {
return err
}

pubKey, err := btcec.ParsePubKey(pubKeyBytes)
if err != nil {
return err
}

nextBlindedKey, err := sphinx.NextEphemeral(
&sphinx.PrivKeyECDH{PrivKey: privKey}, pubKey,
)
if err != nil {
return err
}

fmt.Printf("%x\n", nextBlindedKey.SerializeCompressed())
return nil
}

0 comments on commit 4bf61b8

Please sign in to comment.