| 
									
										
										
										
											2014-10-31 12:37:43 +01:00
										 |  |  | package crypto | 
					
						
							| 
									
										
										
										
											2014-06-29 16:02:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2014-10-08 12:06:39 +02:00
										 |  |  | 	"strings" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-22 00:35:00 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/crypto/secp256k1" | 
					
						
							| 
									
										
										
										
											2014-10-23 15:01:27 +02:00
										 |  |  | 	"github.com/ethereum/go-ethereum/ethutil" | 
					
						
							| 
									
										
										
										
											2014-06-29 16:02:23 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type KeyPair struct { | 
					
						
							|  |  |  | 	PrivateKey []byte | 
					
						
							|  |  |  | 	PublicKey  []byte | 
					
						
							| 
									
										
										
										
											2014-06-29 20:28:04 +01:00
										 |  |  | 	address    []byte | 
					
						
							|  |  |  | 	mnemonic   string | 
					
						
							| 
									
										
										
										
											2014-06-29 16:02:23 +01:00
										 |  |  | 	// The associated account | 
					
						
							|  |  |  | 	// account *StateObject | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func GenerateNewKeyPair() *KeyPair { | 
					
						
							|  |  |  | 	_, prv := secp256k1.GenerateKeyPair() | 
					
						
							|  |  |  | 	keyPair, _ := NewKeyPairFromSec(prv) // swallow error, this one cannot err | 
					
						
							|  |  |  | 	return keyPair | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func NewKeyPairFromSec(seckey []byte) (*KeyPair, error) { | 
					
						
							|  |  |  | 	pubkey, err := secp256k1.GeneratePubKey(seckey) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return nil, err | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return &KeyPair{PrivateKey: seckey, PublicKey: pubkey}, nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *KeyPair) Address() []byte { | 
					
						
							| 
									
										
										
										
											2014-06-29 20:28:04 +01:00
										 |  |  | 	if k.address == nil { | 
					
						
							| 
									
										
										
										
											2014-10-08 12:06:39 +02:00
										 |  |  | 		k.address = Sha3(k.PublicKey[1:])[12:] | 
					
						
							| 
									
										
										
										
											2014-06-29 20:28:04 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return k.address | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *KeyPair) Mnemonic() string { | 
					
						
							|  |  |  | 	if k.mnemonic == "" { | 
					
						
							|  |  |  | 		k.mnemonic = strings.Join(MnemonicEncode(ethutil.Bytes2Hex(k.PrivateKey)), " ") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return k.mnemonic | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *KeyPair) AsStrings() (string, string, string, string) { | 
					
						
							|  |  |  | 	return k.Mnemonic(), ethutil.Bytes2Hex(k.Address()), ethutil.Bytes2Hex(k.PrivateKey), ethutil.Bytes2Hex(k.PublicKey) | 
					
						
							| 
									
										
										
										
											2014-06-29 16:02:23 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *KeyPair) RlpEncode() []byte { | 
					
						
							|  |  |  | 	return k.RlpValue().Encode() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (k *KeyPair) RlpValue() *ethutil.Value { | 
					
						
							|  |  |  | 	return ethutil.NewValue(k.PrivateKey) | 
					
						
							|  |  |  | } |