Documentation ¶
Index ¶
- Constants
- func AesGcmDecryptBase64String(key, nonce []byte, ciphertext string) (string, error)
- func AesGcmDecryptBytes(key, nonce, cipherBytes []byte) ([]byte, error)
- func AesGcmEncryptBase64String(key, nonce []byte, plaintext string) (string, error)
- func AesGcmEncryptBytes(key, nonce, plain []byte) ([]byte, error)
- func GenerateKey(curve elliptic.Curve) (*ecdsa.PrivateKey, *ecdsa.PublicKey, error)
- func MarshalBinary(pub *ecdsa.PublicKey) []byte
- func ReadCertFromBytes(pemBytes []byte) (*x509.Certificate, error)
- func ReadCertFromString(pemString string) (*x509.Certificate, error)
- func ReadEcdsaPrivKeyFromBytes(pemBytes []byte) (*ecdsa.PrivateKey, error)
- func ReadEcdsaPrivKeyFromString(key string) (*ecdsa.PrivateKey, error)
- func UnmarshalBinary(curve elliptic.Curve, data []byte) (*big.Int, *big.Int)
- type KeyAgreementClient
- type KeyAgreementVendor
- type MaaS
- func (cli *MaaS) Chat(req *api.ChatReq) (*api.ChatResp, int, error)
- func (cli *MaaS) ChatWithCtx(ctx context.Context, req *api.ChatReq) (*api.ChatResp, int, error)
- func (cli *MaaS) Classification(req *api.ClassificationReq) (*api.ClassificationResp, int, error)
- func (cli *MaaS) ClassificationWithCtx(ctx context.Context, req *api.ClassificationReq) (*api.ClassificationResp, int, error)
- func (cli *MaaS) SecretChat(req *api.ChatReq) (*api.ChatResp, int, error)
- func (cli *MaaS) SecretChatWithCtx(ctx context.Context, req *api.ChatReq) (*api.ChatResp, int, error)
- func (cli *MaaS) SecretStreamChat(req *api.ChatReq) (ch <-chan *api.ChatResp, err error)
- func (cli *MaaS) SecretStreamChatWithCtx(ctx context.Context, req *api.ChatReq) (ch <-chan *api.ChatResp, err error)
- func (cli *MaaS) StreamChat(req *api.ChatReq) (ch <-chan *api.ChatResp, err error)
- func (cli *MaaS) StreamChatWithCtx(ctx context.Context, req *api.ChatReq) (ch <-chan *api.ChatResp, err error)
- func (cli *MaaS) Tokenization(req *api.TokenizeReq) (*api.TokenizeResp, int, error)
- func (cli *MaaS) TokenizationWithCtx(ctx context.Context, req *api.TokenizeReq) (*api.TokenizeResp, int, error)
Constants ¶
const ( ServiceName = "ml_maas" APICert = "cert" APIChat = "chat" APIStreamChat = "stream_chat" APITokenization = "tokenization" APIClassification = "classification" ServiceTimeout = time.Minute ChatRoleOfUser = "user" ChatRoleOfAssistant = "assistant" ChatRoleOfSystem = "system" ChatRoleOfFunction = "function" )
Variables ¶
This section is empty.
Functions ¶
func AesGcmDecryptBase64String ¶ added in v1.0.113
AesGcmDecryptBase64String decrypt message(base64.std.string) using AES-GCM
func AesGcmDecryptBytes ¶ added in v1.0.113
AesGcmDecryptBytes Decrypt message using AES-GCM
func AesGcmEncryptBase64String ¶ added in v1.0.113
AesGcmEncryptBase64String Encrypt message from base64 string to string using AES-GCM
func AesGcmEncryptBytes ¶ added in v1.0.113
AesGcmEncryptBytes encrypt message using AES-GCM
func GenerateKey ¶ added in v1.0.113
GenerateKey is the constructor for Private-Public key pair
func MarshalBinary ¶ added in v1.0.113
func ReadCertFromBytes ¶ added in v1.0.113
func ReadCertFromBytes(pemBytes []byte) (*x509.Certificate, error)
func ReadCertFromString ¶ added in v1.0.113
func ReadCertFromString(pemString string) (*x509.Certificate, error)
func ReadEcdsaPrivKeyFromBytes ¶ added in v1.0.113
func ReadEcdsaPrivKeyFromBytes(pemBytes []byte) (*ecdsa.PrivateKey, error)
func ReadEcdsaPrivKeyFromString ¶ added in v1.0.113
func ReadEcdsaPrivKeyFromString(key string) (*ecdsa.PrivateKey, error)
Types ¶
type KeyAgreementClient ¶ added in v1.0.113
type KeyAgreementClient struct {
// contains filtered or unexported fields
}
func NewP256KeyAgreementClient ¶ added in v1.0.113
func NewP256KeyAgreementClient(pemString string) (*KeyAgreementClient, error)
NewP256KeyAgreementClient Load cert and extract public key
func (*KeyAgreementClient) CheckChain ¶ added in v1.0.113
func (k *KeyAgreementClient) CheckChain(pemChainString string) error
CheckChain validate cert and cert chain
func (*KeyAgreementClient) GenerateECIESKeyPair ¶ added in v1.0.113
func (k *KeyAgreementClient) GenerateECIESKeyPair() ([]byte, []byte, string, error)
GenerateECIESKeyPair generate ECIES key pair and return the tuple (key, nonce, session token, error)
type KeyAgreementVendor ¶ added in v1.0.113
type KeyAgreementVendor struct {
// contains filtered or unexported fields
}
func NewP256KeyAgreementVendor ¶ added in v1.0.113
func NewP256KeyAgreementVendor(key string) (*KeyAgreementVendor, error)
NewP256KeyAgreementVendor Load private key
func (*KeyAgreementVendor) DecryptString ¶ added in v1.0.113
func (k *KeyAgreementVendor) DecryptString(sessionToken string, ciphertext string) ([]byte, []byte, string, error)
DecryptString decide ciphered text with ECIES DH protocol and return the tuple of (key, nonce, decrypted text)
func (*KeyAgreementVendor) ExtractECIESKeyPair ¶ added in v1.0.113
func (k *KeyAgreementVendor) ExtractECIESKeyPair(sessionToken string) ([]byte, []byte, error)
ExtractECIESKeyPair extract ECIES key pair from session token and return the tuple of (key, nonce)
type MaaS ¶
MaaS ... use base client
func (*MaaS) ChatWithCtx ¶ added in v1.0.108
POST method ChatWithCtx ...
func (*MaaS) Classification ¶ added in v1.0.123
func (cli *MaaS) Classification(req *api.ClassificationReq) (*api.ClassificationResp, int, error)
POST method Classification
func (*MaaS) ClassificationWithCtx ¶ added in v1.0.123
func (cli *MaaS) ClassificationWithCtx(ctx context.Context, req *api.ClassificationReq) (*api.ClassificationResp, int, error)
func (*MaaS) SecretChat ¶ added in v1.0.113
POST method SecretChat is like `Chat`, except its messages are encrypted to ensure that messages are not intercepted by receivers other than the model.
func (*MaaS) SecretChatWithCtx ¶ added in v1.0.113
func (cli *MaaS) SecretChatWithCtx(ctx context.Context, req *api.ChatReq) (*api.ChatResp, int, error)
POST method SecretChatWithCtx is like `ChatWithCtx`, except its messages are encrypted to ensure that messages are not intercepted by receivers other than the model.
func (*MaaS) SecretStreamChat ¶ added in v1.0.113
POST method SecretStreamChat is like `StreamChat`, except its messages are encrypted to ensure that messages are not intercepted by receivers other than the model.
func (*MaaS) SecretStreamChatWithCtx ¶ added in v1.0.113
func (cli *MaaS) SecretStreamChatWithCtx(ctx context.Context, req *api.ChatReq) (ch <-chan *api.ChatResp, err error)
POST method SecretStreamChatWithCtx is like `StreamChatWithCtx`, except its messages are encrypted to ensure that messages are not intercepted by receivers other than the model.
func (*MaaS) StreamChat ¶
POST method StreamChat make stream chat request
- if any error returned, a channel=`nil` is returned;
- if no error returned, the channel are closed after all responses processed.
func (*MaaS) StreamChatWithCtx ¶ added in v1.0.108
func (cli *MaaS) StreamChatWithCtx(ctx context.Context, req *api.ChatReq) (ch <-chan *api.ChatResp, err error)
POST method StreamChat make stream chat request
- if any error returned, a channel=`nil` is returned;
- if no error returned, the channel are closed after all responses processed.
func (*MaaS) Tokenization ¶ added in v1.0.123
func (cli *MaaS) Tokenization(req *api.TokenizeReq) (*api.TokenizeResp, int, error)
POST method Tokenization
func (*MaaS) TokenizationWithCtx ¶ added in v1.0.123
func (cli *MaaS) TokenizationWithCtx(ctx context.Context, req *api.TokenizeReq) (*api.TokenizeResp, int, error)