【调整】插件支持动态参数和参数类型

【调整】获取证书列表支持状态过滤
【新增】dns提供商腾讯云eo
This commit is contained in:
v-me-50
2025-12-17 15:07:12 +08:00
parent d01b42139c
commit a027bde148
29 changed files with 1318 additions and 892 deletions

View File

@@ -0,0 +1,65 @@
package cas
import (
"fmt"
cas "github.com/alibabacloud-go/cas-20200407/v4/client"
openapi "github.com/alibabacloud-go/darabonba-openapi/v2/client"
util "github.com/alibabacloud-go/tea-utils/v2/service"
"github.com/alibabacloud-go/tea/tea"
)
func CreateClient(accessKey, accessSecret, endpoint string) (*cas.Client, error) {
if endpoint == "" {
endpoint = "cas.ap-southeast-1.aliyuncs.com"
}
config := &openapi.Config{
AccessKeyId: tea.String(accessKey),
AccessKeySecret: tea.String(accessSecret),
Endpoint: tea.String(endpoint),
}
return cas.NewClient(config)
}
func Upload(client *cas.Client, cert, key, name string) error {
req := &cas.UploadUserCertificateRequest{
Name: tea.String(name),
Cert: tea.String(cert),
Key: tea.String(key),
}
runtime := &util.RuntimeOptions{}
_, err := client.UploadUserCertificateWithOptions(req, runtime)
return err
}
func Deploy(cfg map[string]any) error {
certPEM, ok := cfg["cert"].(string)
if !ok || certPEM == "" {
return fmt.Errorf("证书错误cert")
}
keyPEM, ok := cfg["key"].(string)
if !ok || keyPEM == "" {
return fmt.Errorf("证书错误key")
}
accessKey, ok := cfg["access_key_id"].(string)
if !ok || accessKey == "" {
return fmt.Errorf("参数错误access_key_id")
}
accessSecret, ok := cfg["access_key_secret"].(string)
if !ok || accessSecret == "" {
return fmt.Errorf("参数错误access_key_secret")
}
name, _ := cfg["name"].(string)
if name == "" {
name = "allinssl-certificate"
}
endpoint, _ := cfg["endpoint"].(string)
client, err := CreateClient(accessKey, accessSecret, endpoint)
if err != nil {
return err
}
if err := Upload(client, certPEM, keyPEM, name); err != nil {
return err
}
return nil
}