Documentation ¶
Index ¶
- Variables
- func AddCipher(name string, cipher func() Cipher)
- func AddKDF(name string, params func() KDFParameters)
- func AddKey(name string, key func() Key)
- func EncodeSSHKeyToPem(keyBlock *pem.Block) []byte
- func GetStructName(name any) string
- func MarshalOpenSSHPrivateKey(key crypto.PrivateKey, comment string) (*pem.Block, error)
- func MarshalOpenSSHPrivateKeyWithPassword(key crypto.PrivateKey, comment string, password []byte, opts ...Opts) (*pem.Block, error)
- func ParseOpenSSHPrivateKey(key []byte) (crypto.PrivateKey, error)
- func ParseOpenSSHPrivateKeyWithPassword(key []byte, password []byte) (crypto.PrivateKey, error)
- func ParseSSHKeyPem(data []byte) ([]byte, error)
- type BcryptOpts
- type Cipher
- type CipherCBC
- type CipherCTR
- type CipherChacha20poly1305
- func (this CipherChacha20poly1305) BlockSize() int
- func (this CipherChacha20poly1305) Decrypt(key, ciphertext []byte) ([]byte, error)
- func (this CipherChacha20poly1305) Encrypt(key, plaintext []byte) ([]byte, error)
- func (this CipherChacha20poly1305) KeySize() int
- func (this CipherChacha20poly1305) Name() string
- type CipherGCM
- type CipherRC4
- func (this CipherRC4) BlockSize() int
- func (this CipherRC4) Decrypt(key, ciphertext []byte) ([]byte, error)
- func (this CipherRC4) Encrypt(key, plaintext []byte) ([]byte, error)
- func (this CipherRC4) KeySize() int
- func (this CipherRC4) Name() string
- func (this CipherRC4) WithKeySize(keySize int) CipherRC4
- type KDFOpts
- type KDFParameters
- type Key
- type KeyEcdsa
- type KeyEdDsa
- type KeyRsa
- type KeySM2
- type Opts
- type PcryptOpts
Constants ¶
This section is empty.
Variables ¶
var ( SSHDESEDE3CBC = "3des-cbc" SSHAES128CBC = "aes128-cbc" SSHAES192CBC = "aes192-cbc" SSHAES256CBC = "aes256-cbc" SSHAES128CTR = "aes128-ctr" SSHAES192CTR = "aes192-ctr" SSHAES256CTR = "aes256-ctr" SSHAES128GCM = "aes128-gcm@openssh.com" SSHAES256GCM = "aes256-gcm@openssh.com" // RC4 SSHArcfour = "arcfour" SSHArcfour128 = "arcfour128" SSHArcfour256 = "arcfour256" SSHBlowfishCBC = "blowfish-cbc" SSHChacha20poly1305 = "chacha20-poly1305@openssh.com" SSHSM4CBC = "sm4-cbc" SSHSM4CTR = "sm4-ctr" )
var AES128CBC = CipherCBC{ // contains filtered or unexported fields }
AES128CBC is the 128-bit key AES cipher in CBC mode.
var AES128CTR = CipherCTR{ // contains filtered or unexported fields }
AES128CTR is the 128-bit key AES cipher in CTR mode.
var AES128GCM = CipherGCM{ // contains filtered or unexported fields }
AES128GCM is the 128-bit key AES cipher in GCM mode.
var AES192CBC = CipherCBC{ // contains filtered or unexported fields }
AES192CBC is the 192-bit key AES cipher in CBC mode.
var AES192CTR = CipherCTR{ // contains filtered or unexported fields }
AES192CTR is the 192-bit key AES cipher in CTR mode.
var AES256CBC = CipherCBC{ // contains filtered or unexported fields }
AES256CBC is the 256-bit key AES cipher in CBC mode.
var AES256CTR = CipherCTR{ // contains filtered or unexported fields }
AES256CTR is the 256-bit key AES cipher in CTR mode.
var AES256GCM = CipherGCM{ // contains filtered or unexported fields }
AES256GCM is the 256-bit key AES cipher in GCM mode.
var Arcfour = CipherRC4{ // contains filtered or unexported fields }
Arcfour is the (from 1 to 256 bytes) key RC4 cipher.
var Arcfour128 = CipherRC4{ // contains filtered or unexported fields }
Arcfour128 is the 128-bit key RC4 cipher.
var Arcfour256 = CipherRC4{ // contains filtered or unexported fields }
Arcfour256 is the 256-bit key RC4 cipher.
var BlowfishCBC = CipherCBC{ // contains filtered or unexported fields }
BlowfishCBC is the key (from 1 to 56 bytes) blowfish cipher in CBC mode.
var Chacha20poly1305 = CipherChacha20poly1305{ // contains filtered or unexported fields }
Chacha20poly1305 is the 256-bit chacha20poly1305 cipher.
var CipherMap = map[string]Cipher{ "DESEDE3CBC": DESEDE3CBC, "BlowfishCBC": BlowfishCBC, "Chacha20poly1305": Chacha20poly1305, "AES128CBC": AES128CBC, "AES192CBC": AES192CBC, "AES256CBC": AES256CBC, "AES128CTR": AES128CTR, "AES192CTR": AES192CTR, "AES256CTR": AES256CTR, "AES128GCM": AES128GCM, "AES256GCM": AES256GCM, "Arcfour": Arcfour, "Arcfour128": Arcfour128, "Arcfour256": Arcfour256, "SM4CBC": SM4CBC, "SM4CTR": SM4CTR, }
Cipher 列表
var DESEDE3CBC = CipherCBC{ // contains filtered or unexported fields }
DESEDE3CBC is the 168-bit key 3DES cipher in CBC mode.
var DefaultOpts = Opts{ Cipher: AES256CTR, KDFOpts: BcryptOpts{ SaltSize: 16, Rounds: 16, }, }
默认配置
var (
KeyAlgoSM2 = "ssh-sm2"
)
var SM4CBC = CipherCBC{ // contains filtered or unexported fields }
SM4CBC is the 128-bit SM4 AES cipher in CBC mode.
var SM4CTR = CipherCTR{ // contains filtered or unexported fields }
SM4CTR is the 128-bit SM4 AES cipher in CTR mode.
Functions ¶
func EncodeSSHKeyToPem ¶ added in v1.0.1030
编码到 pem
func MarshalOpenSSHPrivateKey ¶
编码
func MarshalOpenSSHPrivateKeyWithPassword ¶ added in v1.0.1030
func MarshalOpenSSHPrivateKeyWithPassword(key crypto.PrivateKey, comment string, password []byte, opts ...Opts) (*pem.Block, error)
编码
func ParseOpenSSHPrivateKeyWithPassword ¶ added in v1.0.1030
func ParseOpenSSHPrivateKeyWithPassword(key []byte, password []byte) (crypto.PrivateKey, error)
解析带密码
Types ¶
type BcryptOpts ¶
BcryptOpts 设置
func (BcryptOpts) GetSaltSize ¶
func (this BcryptOpts) GetSaltSize() int
func (BcryptOpts) Name ¶
func (this BcryptOpts) Name() string
type Cipher ¶
type Cipher interface { // 名称 Name() string // 值大小 KeySize() int // 块大小 BlockSize() int // 加密, 返回: [加密后数据, error] Encrypt(key, plaintext []byte) ([]byte, error) // 解密 Decrypt(key, ciphertext []byte) ([]byte, error) }
加密接口
func ParseCipher ¶
type CipherChacha20poly1305 ¶ added in v1.0.1031
type CipherChacha20poly1305 struct {
// contains filtered or unexported fields
}
Chacha20poly1305 加密/解密
func (CipherChacha20poly1305) BlockSize ¶ added in v1.0.1031
func (this CipherChacha20poly1305) BlockSize() int
块大小
func (CipherChacha20poly1305) Decrypt ¶ added in v1.0.1031
func (this CipherChacha20poly1305) Decrypt(key, ciphertext []byte) ([]byte, error)
解密
func (CipherChacha20poly1305) Encrypt ¶ added in v1.0.1031
func (this CipherChacha20poly1305) Encrypt(key, plaintext []byte) ([]byte, error)
加密
func (CipherChacha20poly1305) KeySize ¶ added in v1.0.1031
func (this CipherChacha20poly1305) KeySize() int
值大小
func (CipherChacha20poly1305) Name ¶ added in v1.0.1031
func (this CipherChacha20poly1305) Name() string
名称
type CipherGCM ¶ added in v1.0.1031
type CipherGCM struct {
// contains filtered or unexported fields
}
gcm 模式加密
type CipherRC4 ¶ added in v1.0.1031
type CipherRC4 struct {
// contains filtered or unexported fields
}
CipherRC4 加密/解密
func (CipherRC4) WithKeySize ¶ added in v1.0.1031
设置值大小
type KDFOpts ¶
type KDFOpts interface { // 名称 Name() string // 生成密钥 DeriveKey(password []byte, size int) (key []byte, params string, err error) // 随机数大小 GetSaltSize() int }
KDF 设置接口
type KDFParameters ¶
type KDFParameters interface { // 生成密钥 DeriveKey(password []byte, kdfOpts string, size int) (key []byte, err error) }
数据接口
func ParsePbkdf ¶
func ParsePbkdf(kdfName string) (KDFParameters, error)
type Key ¶
type Key interface { // 包装 Marshal(key crypto.PrivateKey, comment string) (string, []byte, []byte, error) // 解析 Parse(data []byte) (crypto.PrivateKey, error) }
Key 接口
func ParseKeytype ¶
type KeySM2 ¶ added in v1.0.1031
type KeySM2 struct{}
SM2
type PcryptOpts ¶ added in v1.0.1029
PcryptOpts 设置
func (PcryptOpts) GetSaltSize ¶ added in v1.0.1029
func (this PcryptOpts) GetSaltSize() int
func (PcryptOpts) Name ¶ added in v1.0.1029
func (this PcryptOpts) Name() string