123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- package crypto
- import (
- "crypto/aes"
- "crypto/cipher"
- "crypto/sha1"
- "io"
- "golang.org/x/crypto/pbkdf2"
- )
- func NewReader(r io.Reader, key []byte) *Reader {
- key = pbkdf2.Key(key, []byte(DefaultSalt), 64, aes.BlockSize, sha1.New)
- return &Reader{
- r: r,
- key: key,
- }
- }
- type Reader struct {
- r io.Reader
- dec *cipher.StreamReader
- key []byte
- iv []byte
- err error
- }
- func (r *Reader) Read(p []byte) (nRet int, errRet error) {
- if r.err != nil {
- return 0, r.err
- }
- if r.dec == nil {
- iv := make([]byte, aes.BlockSize)
- if _, errRet = io.ReadFull(r.r, iv); errRet != nil {
- return
- }
- r.iv = iv
- block, err := aes.NewCipher(r.key)
- if err != nil {
- errRet = err
- return
- }
- r.dec = &cipher.StreamReader{
- S: cipher.NewCFBDecrypter(block, iv),
- R: r.r,
- }
- }
- nRet, errRet = r.dec.Read(p)
- if errRet != nil {
- r.err = errRet
- }
- return
- }
|