From c375301fa8fa807ae084cfd7abfb2cf915b01ee9 Mon Sep 17 00:00:00 2001 From: Justus Ranvier Date: Fri, 18 Sep 2015 13:30:07 -0500 Subject: [PATCH] BIP-47: Clarify decoding of notification transactions Specify procedure for extracting payment codes from notification transactions. Add explicit check that payment code x values are valid for secp256k1 --- bip-0047.mediawiki | 25 +++++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/bip-0047.mediawiki b/bip-0047.mediawiki index d49b0ea5..15c5a8b4 100644 --- a/bip-0047.mediawiki +++ b/bip-0047.mediawiki @@ -1,3 +1,7 @@ +RECENT CHANGES: + +* (18 Sep 2015) Clarify decoding of notification transactions +
   BIP:     47
   Title:   Reusable Payment Codes for Hierarchical Deterministic Wallets
@@ -60,7 +64,7 @@ A payment code contains the following elements:
 ** Bit 0: Bitmessage notification
 ** Bits 1-7: reserved
 * Byte 2: sign. required value: 0x02 or 0x03
-* Bytes 3 - 34: x value
+* Bytes 3 - 34: x value, must be a member of the secp256k1 group
 * Bytes 35 - 66: chain code
 * Bytes 67 - 79: reserved for future expansion, zero-filled unless otherwise noted
 
@@ -90,17 +94,30 @@ Prior to the first time Alice initiates a transaction to Bob, Alice MUST inform
 # Alice constructs a transaction which sends a small quantity of bitcoins to Bob's notification address (notification transaction)
 ## The inputs selected for this transaction MUST NOT be easily associated with Alice's notification address
 # Alice derives a unique shared secret using ECDH:
-## Alice selects the first exposed public key, of the first pubkey-exposing input, of the transaction: 
a
+## Alice selects the private key corresponding to the first exposed public key, of the first pubkey-exposing input, of the transaction:
a
## Alice selects the public key associated with Bob's notification address:
B, where B = bG
## Alice calculates a secret point:
S = aB
## Alice expresses the secret point in compressed DER format, then calculates a scalar shared secret:
s = SHA256(S)
# Alice serializes her payment code in binary form. # Alice renders her payment code (P) unreadable to anyone except Bob by: -## Replace the x value with:
s XOR (x value)
-## Replace the chain code with:
sha256(s) XOR (chain code)
+## Replace the x value with x':
x' = s XOR (x value)
+## Replace the chain code with c':
c' = sha256(s) XOR (chain code)
# Alice adds an OP_RETURN output to her transaction which consists of P. +# Bob watches for any transactions which create an output at his notification address. +# When a transaction is received, the client examines it to determine if it contains a standard OP_RETURN output with an 80 byte payload (notification transactions). +# If the first byte of the payload in a notification transaction is 0x01: +## Bob selects the first exposed public key, of the first pubkey-exposing input, of the transaction:
A, where A = aG
+## Bob selects the private key associated with his notification address:
b
+## Bob calculates a secret point:
S = bA
+## Bob expresses the secret point in compressed DER format, then calculates a scalar shared secret:
s = SHA256(S)
+## Bob interprets the 80 byte payload as a payment code, except: +### Replace the x value with x':
x' = s XOR (x value)
+### Replace the chain code with c':
c' = sha256(s) XOR (chain code)
+## If the updated x value is a member of the secp256k1 group, the payment code is valid. +## If the updated x value is not a member of the secp256k1 group, the payment code is ignored. + Now that Bob's client has received Alice's payment code, it is possible for Alice to send payments (up to 232 payments) to Bob. Alice will never again need to send a notification transaction to Bob.