Documentation ¶
Index ¶
- func DecryptReader(b cipher.Block, iv []byte, r io.Reader) (data.Reader, error)
- func DecryptWriter(b cipher.Block, iv []byte, w io.Writer) (data.Writer, error)
- func EncryptReader(b cipher.Block, iv []byte, r io.Reader) (data.Reader, error)
- func EncryptWriter(b cipher.Block, iv []byte, w io.Writer) (data.Writer, error)
- func NewAes(k []byte) (cipher.Block, error)
- func NewReader(c Reader, r io.Reader) data.Reader
- func NewSource(seed interface{}) rand.Source
- func NewSourceEx(rounds int, seed interface{}) rand.Source
- func NewWriter(c Writer, w io.Writer) data.Writer
- func SHA512(b []byte) []byte
- type CBK
- func (e CBK) BlockSize() int
- func (e *CBK) Decrypt(dst, src []byte)
- func (e CBK) Deshuffle(b []byte)
- func (e *CBK) Encrypt(dst, src []byte)
- func (e *CBK) Flush(w io.Writer) error
- func (e *CBK) Read(r io.Reader, b []byte) (int, error)
- func (e *CBK) Reset() error
- func (e CBK) Shuffle(b []byte)
- func (e *CBK) Write(w io.Writer, b []byte) (int, error)
- type MultiSource
- type Reader
- type Writer
- type XOR
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func DecryptReader ¶
DecryptReader creates a data.Reader type from the specified block Cipher, IV and Reader. This is used to Decrypt data. This function returns an error if the blocksize of the Block does not equal the length of the supplied IV.
func DecryptWriter ¶
DecryptWriter creates a data.Writer type from the specified block Cipher, IV and Writer. This is used to Decrypt data. This function returns an error if the blocksize of the Block does not equal the length of the supplied IV.
func EncryptReader ¶
EncryptReader creates a data.Reader type from the specified block Cipher, IV and Reader. This is used to Encrypt data. This function returns an error if the blocksize of the Block does not equal the length of the supplied IV.
func EncryptWriter ¶
EncryptWriter creates a data.Reader type from the specified block Cipher, IV and Writer. This is used to Encrypt data. This function returns an error if the blocksize of the Block does not equal the length of the supplied IV.
func NewAes ¶
NewAes attempts to create a new AES block Cipher from the provided key data. Errors will be returned if the key length is invalid.
func NewSource ¶
NewSource creates a random Source from the provided interface. This function supports all types of Golang primitives.
func NewSourceEx ¶
NewSourceEx creates a random Source from the provided interface. This function supports all types of Golang primitives. This function allows for supplying the rounds value, which defaults to the value of 4.
Types ¶
type CBK ¶
type CBK struct { // Random Source to use for data generation from keys. // This source MUST be repeatable. Source rand.Source A, B byte C, D byte // contains filtered or unexported fields }
CBK is the representation of the CBK Cipher. CBK is a block based cipher that allows for a variable size index in encoding.
func NewCBK ¶
NewCBK returns a new CBK Cipher with the D value specified. The other A, B and C values are randomally generated at runtime.
func NewCBKEx ¶
NewCBKEx returns a new CBK Cipher with the D value, BlockSize and Entropy source specified. The other A, B and C values are randomally generated at runtime.
func (*CBK) Decrypt ¶
Decrypt decrypts the first block in src into dst. Dst and src must overlap entirely or not at all.
func (CBK) Deshuffle ¶
Deshuffle will reverse the switch around the bytes in the array based on the Cipher bytes.
func (*CBK) Encrypt ¶
Encrypt encrypts the first block in src into dst. Dst and src must overlap entirely or not at all.
func (*CBK) Flush ¶
Flush pushes the remaining bytes stored into the buffer into the supplies Writer.
func (*CBK) Read ¶
Read reads the contents of the Reader to the byte array after decrypting with this Cipher.
type MultiSource ¶
type MultiSource struct {
// contains filtered or unexported fields
}
MultiSource is a struct that is a random Source that can use multiple source providers and spreads the calls among them in a random manner.
func NewMultiSource ¶
func NewMultiSource(s ...rand.Source) *MultiSource
NewMultiSource creates a new MultiSource struct instance.
func (*MultiSource) Add ¶
func (m *MultiSource) Add(s ...rand.Source)
Add will append the Source values to this MultiSource instance.
func (*MultiSource) Int63 ¶
func (m *MultiSource) Int63() int64
Int63 returns a int64 number between zero and the max value.
func (*MultiSource) Seed ¶
func (m *MultiSource) Seed(n int64)
Seed will set the seed value of this MultiSource instance.
type Reader ¶
Reader is an interface that supports reading bytes from a Reader through the specified Cipher.
type Writer ¶
Writer is an interface that supports writing bytes to a Writer through the specified Cipher.
type XOR ¶
type XOR []byte
XOR is an alias for a byte array that acts as the XOR key data buffer.
func (XOR) Decrypt ¶
Decrypt preforms the XOR operation on the specified byte array using the cipher as the key.
func (XOR) Encrypt ¶
Encrypt preforms the XOR operation on the specified byte array using the cipher as the key.
func (XOR) Operate ¶
Operate preforms the XOR operation on the specified byte array using the cipher as the key.