diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-06-25 17:16:54 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-06-25 17:16:54 +0800 |
commit | 6b2a03faa2473d38093adbeee62935af2fe2da59 (patch) | |
tree | 0a4127599ea4c35cfedd92ad037e916cd052bbd6 /crypto/crypto.go | |
parent | 8774fdcd64ffe55bbd5d47cd1479a626506d8f01 (diff) | |
parent | d23ec6c4194e7c0f70372db58d49ec222dc4e22c (diff) | |
download | dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.tar dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.tar.gz dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.tar.bz2 dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.tar.lz dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.tar.xz dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.tar.zst dexon-6b2a03faa2473d38093adbeee62935af2fe2da59.zip |
Merge pull request #1085 from Gustav-Simonsson/key_store_v3
crypto: key store v3
Diffstat (limited to 'crypto/crypto.go')
-rw-r--r-- | crypto/crypto.go | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/crypto/crypto.go b/crypto/crypto.go index 8f5597b09..153bbbc5d 100644 --- a/crypto/crypto.go +++ b/crypto/crypto.go @@ -258,19 +258,31 @@ func decryptPreSaleKey(fileContent []byte, password string) (key *Key, err error return key, err } -func aesCBCDecrypt(key []byte, cipherText []byte, iv []byte) (plainText []byte, err error) { +// AES-128 is selected due to size of encryptKey +func aesCTRXOR(key, inText, iv []byte) ([]byte, error) { aesBlock, err := aes.NewCipher(key) if err != nil { - return plainText, err + return nil, err + } + stream := cipher.NewCTR(aesBlock, iv) + outText := make([]byte, len(inText)) + stream.XORKeyStream(outText, inText) + return outText, err +} + +func aesCBCDecrypt(key, cipherText, iv []byte) ([]byte, error) { + aesBlock, err := aes.NewCipher(key) + if err != nil { + return nil, err } decrypter := cipher.NewCBCDecrypter(aesBlock, iv) - paddedPlainText := make([]byte, len(cipherText)) - decrypter.CryptBlocks(paddedPlainText, cipherText) - plainText = PKCS7Unpad(paddedPlainText) - if plainText == nil { + paddedPlaintext := make([]byte, len(cipherText)) + decrypter.CryptBlocks(paddedPlaintext, cipherText) + plaintext := PKCS7Unpad(paddedPlaintext) + if plaintext == nil { err = errors.New("Decryption failed: PKCS7Unpad failed after AES decryption") } - return plainText, err + return plaintext, err } // From https://leanpub.com/gocrypto/read#leanpub-auto-block-cipher-modes |