2024-05-17 18:28:59 +08:00
|
|
|
// Copyright 2021 GoEdge CDN goedge.cdn@gmail.com. All rights reserved.
|
2021-10-19 16:31:33 +08:00
|
|
|
|
|
|
|
|
package nodeutils
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"encoding/base64"
|
|
|
|
|
"encoding/json"
|
|
|
|
|
"errors"
|
2023-08-11 15:26:59 +08:00
|
|
|
"fmt"
|
2021-10-19 16:31:33 +08:00
|
|
|
"github.com/iwind/TeaGo/maps"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
2023-03-02 10:28:15 +08:00
|
|
|
// EncryptMap 加密
|
|
|
|
|
func EncryptMap(nodeUniqueId string, nodeSecret string, data maps.Map, timeout int32) (string, error) {
|
2021-10-19 16:31:33 +08:00
|
|
|
if data == nil {
|
|
|
|
|
data = maps.Map{}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var expiresAt int64
|
|
|
|
|
if timeout > 0 {
|
|
|
|
|
expiresAt = time.Now().Unix() + int64(timeout)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dataJSON, err := json.Marshal(maps.Map{
|
|
|
|
|
"expiresAt": expiresAt,
|
|
|
|
|
"data": data,
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
2023-08-11 15:26:59 +08:00
|
|
|
return "", fmt.Errorf("marshal data to json failed: %w", err)
|
2021-10-19 16:31:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var method = &AES256CFBMethod{}
|
|
|
|
|
err = method.Init([]byte(nodeUniqueId), []byte(nodeSecret))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return "", err
|
|
|
|
|
}
|
|
|
|
|
result, err := method.Encrypt(dataJSON)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return "", err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return base64.StdEncoding.EncodeToString(result), nil
|
|
|
|
|
}
|
|
|
|
|
|
2023-03-02 10:28:15 +08:00
|
|
|
// DecryptMap 解密
|
|
|
|
|
func DecryptMap(nodeUniqueId string, nodeSecret string, encodedString string) (maps.Map, error) {
|
2021-10-19 16:31:33 +08:00
|
|
|
var method = &AES256CFBMethod{}
|
|
|
|
|
err := method.Init([]byte(nodeUniqueId), []byte(nodeSecret))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
encodedData, err := base64.StdEncoding.DecodeString(encodedString)
|
|
|
|
|
if err != nil {
|
2023-08-11 15:26:59 +08:00
|
|
|
return nil, fmt.Errorf("base64 decode failed: %w", err)
|
2021-10-19 16:31:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dataJSON, err := method.Decrypt(encodedData)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var result = maps.Map{}
|
|
|
|
|
err = json.Unmarshal(dataJSON, &result)
|
|
|
|
|
if err != nil {
|
2023-08-11 15:26:59 +08:00
|
|
|
return nil, fmt.Errorf("unmarshal data failed: %w", err)
|
2021-10-19 16:31:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var expiresAt = result.GetInt64("expiresAt")
|
|
|
|
|
if expiresAt > 0 && expiresAt < time.Now().Unix() {
|
|
|
|
|
return nil, errors.New("data is expired")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result.GetMap("data"), nil
|
|
|
|
|
}
|
2023-03-02 10:28:15 +08:00
|
|
|
|
|
|
|
|
// EncryptData 加密
|
|
|
|
|
func EncryptData(nodeUniqueId string, nodeSecret string, data []byte) (string, error) {
|
|
|
|
|
if len(data) == 0 {
|
|
|
|
|
return "", nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var method = &AES256CFBMethod{}
|
|
|
|
|
err := method.Init([]byte(nodeUniqueId), []byte(nodeSecret))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return "", err
|
|
|
|
|
}
|
|
|
|
|
result, err := method.Encrypt(data)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return "", err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return base64.StdEncoding.EncodeToString(result), nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// DecryptData 解密
|
|
|
|
|
func DecryptData(nodeUniqueId string, nodeSecret string, encodedString string) ([]byte, error) {
|
|
|
|
|
if len(encodedString) == 0 {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var method = &AES256CFBMethod{}
|
|
|
|
|
err := method.Init([]byte(nodeUniqueId), []byte(nodeSecret))
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
encodedData, err := base64.StdEncoding.DecodeString(encodedString)
|
|
|
|
|
if err != nil {
|
2023-08-11 15:26:59 +08:00
|
|
|
return nil, fmt.Errorf("base64 decode failed: %w", err)
|
2023-03-02 10:28:15 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return method.Decrypt(encodedData)
|
|
|
|
|
}
|