passforios-gopenpgp/crypto/subtle.go

35 lines
1.1 KiB
Go
Raw Normal View History

2018-11-27 18:17:58 +01:00
package crypto
import (
"crypto/aes"
"crypto/cipher"
"golang.org/x/crypto/scrypt"
)
// EncryptWithoutIntegrity encrypts data with AES-CTR. Note: this encryption mode is not secure when stored/sent on an untrusted medium.
2019-03-07 14:08:17 +01:00
// Use: ios/android only
2018-11-27 18:17:58 +01:00
func EncryptWithoutIntegrity(key, input, iv []byte) (output []byte, err error) {
var block cipher.Block
if block, err = aes.NewCipher(key); err != nil {
return
}
output = make([]byte, len(input))
stream := cipher.NewCTR(block, iv)
stream.XORKeyStream(output, input)
return
}
// DecryptWithoutIntegrity decrypts data encrypted with AES-CTR.
2019-03-07 14:08:17 +01:00
// Use: ios/android only
2018-11-27 18:17:58 +01:00
func DecryptWithoutIntegrity(key, input, iv []byte) ([]byte, error) {
// AES-CTR decryption is identical to encryption.
return EncryptWithoutIntegrity(key, input, iv)
}
2018-12-19 11:52:52 -05:00
// DeriveKey derives a key from a password using scrypt. N should be set to the highest power of 2 you can derive within 100 milliseconds.
2019-03-07 14:08:17 +01:00
// Use: ios/android only
2018-12-19 11:52:52 -05:00
func DeriveKey(password string, salt []byte, N int) ([]byte, error) {
return scrypt.Key([]byte(password), salt, N, 8, 1, 32)
2018-11-27 18:17:58 +01:00
}