mirror of
https://github.com/woodchen-ink/certimate.git
synced 2025-07-18 17:31:55 +08:00
feat: manage ca authorizations
This commit is contained in:
parent
7503d52857
commit
deb3b2f412
@ -1,25 +1,21 @@
|
|||||||
package applicant
|
package applicant
|
||||||
|
|
||||||
const (
|
import "github.com/usual2970/certimate/internal/domain"
|
||||||
sslProviderLetsEncrypt = "letsencrypt"
|
|
||||||
sslProviderLetsEncryptStaging = "letsencrypt_staging"
|
|
||||||
sslProviderZeroSSL = "zerossl"
|
|
||||||
sslProviderGoogleTrustServices = "gts"
|
|
||||||
)
|
|
||||||
const defaultSSLProvider = sslProviderLetsEncrypt
|
|
||||||
|
|
||||||
const (
|
const (
|
||||||
letsencryptUrl = "https://acme-v02.api.letsencrypt.org/directory"
|
sslProviderLetsEncrypt = string(domain.ApplyCAProviderTypeLetsEncrypt)
|
||||||
letsencryptStagingUrl = "https://acme-staging-v02.api.letsencrypt.org/directory"
|
sslProviderLetsEncryptStaging = string(domain.ApplyCAProviderTypeLetsEncryptStaging)
|
||||||
zerosslUrl = "https://acme.zerossl.com/v2/DV90"
|
sslProviderGoogleTrustServices = string(domain.ApplyCAProviderTypeGoogleTrustServices)
|
||||||
gtsUrl = "https://dv.acme-v02.api.pki.goog/directory"
|
sslProviderZeroSSL = string(domain.ApplyCAProviderTypeZeroSSL)
|
||||||
|
|
||||||
|
sslProviderDefault = sslProviderLetsEncrypt
|
||||||
)
|
)
|
||||||
|
|
||||||
var sslProviderUrls = map[string]string{
|
var sslProviderUrls = map[string]string{
|
||||||
sslProviderLetsEncrypt: letsencryptUrl,
|
sslProviderLetsEncrypt: "https://acme-v02.api.letsencrypt.org/directory",
|
||||||
sslProviderLetsEncryptStaging: letsencryptStagingUrl,
|
sslProviderLetsEncryptStaging: "https://acme-staging-v02.api.letsencrypt.org/directory",
|
||||||
sslProviderZeroSSL: zerosslUrl,
|
sslProviderGoogleTrustServices: "https://dv.acme-v02.api.pki.goog/directory",
|
||||||
sslProviderGoogleTrustServices: gtsUrl,
|
sslProviderZeroSSL: "https://acme.zerossl.com/v2/DV90",
|
||||||
}
|
}
|
||||||
|
|
||||||
type acmeSSLProviderConfig struct {
|
type acmeSSLProviderConfig struct {
|
||||||
@ -29,7 +25,7 @@ type acmeSSLProviderConfig struct {
|
|||||||
|
|
||||||
type acmeSSLProviderConfigContent struct {
|
type acmeSSLProviderConfigContent struct {
|
||||||
ZeroSSL acmeSSLProviderEabConfig `json:"zerossl"`
|
ZeroSSL acmeSSLProviderEabConfig `json:"zerossl"`
|
||||||
GoogleTrustServices acmeSSLProviderEabConfig `json:"gts"`
|
GoogleTrustServices acmeSSLProviderEabConfig `json:"googletrustservices"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type acmeSSLProviderEabConfig struct {
|
type acmeSSLProviderEabConfig struct {
|
||||||
|
@ -111,7 +111,7 @@ func apply(challengeProvider challenge.Provider, options *applicantOptions) (*Ap
|
|||||||
|
|
||||||
sslProviderConfig := &acmeSSLProviderConfig{
|
sslProviderConfig := &acmeSSLProviderConfig{
|
||||||
Config: acmeSSLProviderConfigContent{},
|
Config: acmeSSLProviderConfigContent{},
|
||||||
Provider: defaultSSLProvider,
|
Provider: sslProviderDefault,
|
||||||
}
|
}
|
||||||
if settings != nil {
|
if settings != nil {
|
||||||
if err := json.Unmarshal([]byte(settings.Content), sslProviderConfig); err != nil {
|
if err := json.Unmarshal([]byte(settings.Content), sslProviderConfig); err != nil {
|
||||||
@ -120,7 +120,7 @@ func apply(challengeProvider challenge.Provider, options *applicantOptions) (*Ap
|
|||||||
}
|
}
|
||||||
|
|
||||||
if sslProviderConfig.Provider == "" {
|
if sslProviderConfig.Provider == "" {
|
||||||
sslProviderConfig.Provider = defaultSSLProvider
|
sslProviderConfig.Provider = sslProviderDefault
|
||||||
}
|
}
|
||||||
|
|
||||||
acmeUser, err := newAcmeUser(sslProviderConfig.Provider, options.ContactEmail)
|
acmeUser, err := newAcmeUser(sslProviderConfig.Provider, options.ContactEmail)
|
||||||
|
@ -125,6 +125,11 @@ type AccessConfigForGoDaddy struct {
|
|||||||
ApiSecret string `json:"apiSecret"`
|
ApiSecret string `json:"apiSecret"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type AccessConfigForGoogleTrustServices struct {
|
||||||
|
EabKid string `json:"eabKid"`
|
||||||
|
EabHmacKey string `json:"eabHmacKey"`
|
||||||
|
}
|
||||||
|
|
||||||
type AccessConfigForHuaweiCloud struct {
|
type AccessConfigForHuaweiCloud struct {
|
||||||
AccessKeyId string `json:"accessKeyId"`
|
AccessKeyId string `json:"accessKeyId"`
|
||||||
SecretAccessKey string `json:"secretAccessKey"`
|
SecretAccessKey string `json:"secretAccessKey"`
|
||||||
@ -228,3 +233,8 @@ type AccessConfigForWestcn struct {
|
|||||||
Username string `json:"username"`
|
Username string `json:"username"`
|
||||||
ApiPassword string `json:"password"`
|
ApiPassword string `json:"password"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type AccessConfigForZeroSSL struct {
|
||||||
|
EabKid string `json:"eabKid"`
|
||||||
|
EabHmacKey string `json:"eabHmacKey"`
|
||||||
|
}
|
||||||
|
@ -9,55 +9,75 @@ type AccessProviderType string
|
|||||||
NOTICE: If you add new constant, please keep ASCII order.
|
NOTICE: If you add new constant, please keep ASCII order.
|
||||||
*/
|
*/
|
||||||
const (
|
const (
|
||||||
AccessProviderType1Panel = AccessProviderType("1panel")
|
AccessProviderType1Panel = AccessProviderType("1panel")
|
||||||
AccessProviderTypeACMEHttpReq = AccessProviderType("acmehttpreq")
|
AccessProviderTypeACMEHttpReq = AccessProviderType("acmehttpreq")
|
||||||
AccessProviderTypeAkamai = AccessProviderType("akamai") // Akamai(预留)
|
AccessProviderTypeAkamai = AccessProviderType("akamai") // Akamai(预留)
|
||||||
AccessProviderTypeAliyun = AccessProviderType("aliyun")
|
AccessProviderTypeAliyun = AccessProviderType("aliyun")
|
||||||
AccessProviderTypeAWS = AccessProviderType("aws")
|
AccessProviderTypeAWS = AccessProviderType("aws")
|
||||||
AccessProviderTypeAzure = AccessProviderType("azure")
|
AccessProviderTypeAzure = AccessProviderType("azure")
|
||||||
AccessProviderTypeBaiduCloud = AccessProviderType("baiducloud")
|
AccessProviderTypeBaiduCloud = AccessProviderType("baiducloud")
|
||||||
AccessProviderTypeBaishan = AccessProviderType("baishan")
|
AccessProviderTypeBaishan = AccessProviderType("baishan")
|
||||||
AccessProviderTypeBaotaPanel = AccessProviderType("baotapanel")
|
AccessProviderTypeBaotaPanel = AccessProviderType("baotapanel")
|
||||||
AccessProviderTypeBytePlus = AccessProviderType("byteplus")
|
AccessProviderTypeBytePlus = AccessProviderType("byteplus")
|
||||||
AccessProviderTypeCacheFly = AccessProviderType("cachefly")
|
AccessProviderTypeCacheFly = AccessProviderType("cachefly")
|
||||||
AccessProviderTypeCdnfly = AccessProviderType("cdnfly")
|
AccessProviderTypeCdnfly = AccessProviderType("cdnfly")
|
||||||
AccessProviderTypeCloudflare = AccessProviderType("cloudflare")
|
AccessProviderTypeCloudflare = AccessProviderType("cloudflare")
|
||||||
AccessProviderTypeClouDNS = AccessProviderType("cloudns")
|
AccessProviderTypeClouDNS = AccessProviderType("cloudns")
|
||||||
AccessProviderTypeCMCCCloud = AccessProviderType("cmcccloud")
|
AccessProviderTypeCMCCCloud = AccessProviderType("cmcccloud")
|
||||||
AccessProviderTypeCTCCCloud = AccessProviderType("ctcccloud") // 联通云(预留)
|
AccessProviderTypeCTCCCloud = AccessProviderType("ctcccloud") // 联通云(预留)
|
||||||
AccessProviderTypeCUCCCloud = AccessProviderType("cucccloud") // 天翼云(预留)
|
AccessProviderTypeCUCCCloud = AccessProviderType("cucccloud") // 天翼云(预留)
|
||||||
AccessProviderTypeDeSEC = AccessProviderType("desec")
|
AccessProviderTypeDeSEC = AccessProviderType("desec")
|
||||||
AccessProviderTypeDNSLA = AccessProviderType("dnsla")
|
AccessProviderTypeDNSLA = AccessProviderType("dnsla")
|
||||||
AccessProviderTypeDogeCloud = AccessProviderType("dogecloud")
|
AccessProviderTypeDogeCloud = AccessProviderType("dogecloud")
|
||||||
AccessProviderTypeDynv6 = AccessProviderType("dynv6")
|
AccessProviderTypeDynv6 = AccessProviderType("dynv6")
|
||||||
AccessProviderTypeEdgio = AccessProviderType("edgio")
|
AccessProviderTypeEdgio = AccessProviderType("edgio")
|
||||||
AccessProviderTypeFastly = AccessProviderType("fastly") // Fastly(预留)
|
AccessProviderTypeFastly = AccessProviderType("fastly") // Fastly(预留)
|
||||||
AccessProviderTypeGname = AccessProviderType("gname")
|
AccessProviderTypeGname = AccessProviderType("gname")
|
||||||
AccessProviderTypeGcore = AccessProviderType("gcore")
|
AccessProviderTypeGcore = AccessProviderType("gcore")
|
||||||
AccessProviderTypeGoDaddy = AccessProviderType("godaddy")
|
AccessProviderTypeGoDaddy = AccessProviderType("godaddy")
|
||||||
AccessProviderTypeGoEdge = AccessProviderType("goedge") // GoEdge(预留)
|
AccessProviderTypeGoEdge = AccessProviderType("goedge") // GoEdge(预留)
|
||||||
AccessProviderTypeHuaweiCloud = AccessProviderType("huaweicloud")
|
AccessProviderTypeGoogleTrustServices = AccessProviderType("googletrustservices")
|
||||||
AccessProviderTypeJDCloud = AccessProviderType("jdcloud")
|
AccessProviderTypeHuaweiCloud = AccessProviderType("huaweicloud")
|
||||||
AccessProviderTypeKubernetes = AccessProviderType("k8s")
|
AccessProviderTypeJDCloud = AccessProviderType("jdcloud")
|
||||||
AccessProviderTypeLocal = AccessProviderType("local")
|
AccessProviderTypeKubernetes = AccessProviderType("k8s")
|
||||||
AccessProviderTypeNamecheap = AccessProviderType("namecheap")
|
AccessProviderTypeLetsEncrypt = AccessProviderType("letsencrypt")
|
||||||
AccessProviderTypeNameDotCom = AccessProviderType("namedotcom")
|
AccessProviderTypeLetsEncryptStaging = AccessProviderType("letsencryptstaging")
|
||||||
AccessProviderTypeNameSilo = AccessProviderType("namesilo")
|
AccessProviderTypeLocal = AccessProviderType("local")
|
||||||
AccessProviderTypeNS1 = AccessProviderType("ns1")
|
AccessProviderTypeNamecheap = AccessProviderType("namecheap")
|
||||||
AccessProviderTypePorkbun = AccessProviderType("porkbun")
|
AccessProviderTypeNameDotCom = AccessProviderType("namedotcom")
|
||||||
AccessProviderTypePowerDNS = AccessProviderType("powerdns")
|
AccessProviderTypeNameSilo = AccessProviderType("namesilo")
|
||||||
AccessProviderTypeQiniu = AccessProviderType("qiniu")
|
AccessProviderTypeNS1 = AccessProviderType("ns1")
|
||||||
AccessProviderTypeQingCloud = AccessProviderType("qingcloud") // 青云(预留)
|
AccessProviderTypePorkbun = AccessProviderType("porkbun")
|
||||||
AccessProviderTypeRainYun = AccessProviderType("rainyun")
|
AccessProviderTypePowerDNS = AccessProviderType("powerdns")
|
||||||
AccessProviderTypeSafeLine = AccessProviderType("safeline")
|
AccessProviderTypeQiniu = AccessProviderType("qiniu")
|
||||||
AccessProviderTypeSSH = AccessProviderType("ssh")
|
AccessProviderTypeQingCloud = AccessProviderType("qingcloud") // 青云(预留)
|
||||||
AccessProviderTypeTencentCloud = AccessProviderType("tencentcloud")
|
AccessProviderTypeRainYun = AccessProviderType("rainyun")
|
||||||
AccessProviderTypeUCloud = AccessProviderType("ucloud")
|
AccessProviderTypeSafeLine = AccessProviderType("safeline")
|
||||||
AccessProviderTypeUpyun = AccessProviderType("upyun")
|
AccessProviderTypeSSH = AccessProviderType("ssh")
|
||||||
AccessProviderTypeVercel = AccessProviderType("vercel")
|
AccessProviderTypeTencentCloud = AccessProviderType("tencentcloud")
|
||||||
AccessProviderTypeVolcEngine = AccessProviderType("volcengine")
|
AccessProviderTypeUCloud = AccessProviderType("ucloud")
|
||||||
AccessProviderTypeWebhook = AccessProviderType("webhook")
|
AccessProviderTypeUpyun = AccessProviderType("upyun")
|
||||||
AccessProviderTypeWestcn = AccessProviderType("westcn")
|
AccessProviderTypeVercel = AccessProviderType("vercel")
|
||||||
|
AccessProviderTypeVolcEngine = AccessProviderType("volcengine")
|
||||||
|
AccessProviderTypeWebhook = AccessProviderType("webhook")
|
||||||
|
AccessProviderTypeWestcn = AccessProviderType("westcn")
|
||||||
|
AccessProviderTypeZeroSSL = AccessProviderType("zerossl")
|
||||||
|
)
|
||||||
|
|
||||||
|
type ApplyCAProviderType string
|
||||||
|
|
||||||
|
/*
|
||||||
|
申请证书 CA 提供商常量值。
|
||||||
|
始终等于授权提供商类型。
|
||||||
|
|
||||||
|
注意:如果追加新的常量值,请保持以 ASCII 排序。
|
||||||
|
NOTICE: If you add new constant, please keep ASCII order.
|
||||||
|
*/
|
||||||
|
const (
|
||||||
|
ApplyCAProviderTypeGoogleTrustServices = ApplyCAProviderType("googletrustservices")
|
||||||
|
ApplyCAProviderTypeLetsEncrypt = ApplyCAProviderType("letsencrypt")
|
||||||
|
ApplyCAProviderTypeLetsEncryptStaging = ApplyCAProviderType("letsencryptstaging")
|
||||||
|
ApplyCAProviderTypeZeroSSL = ApplyCAProviderType("zerossl")
|
||||||
)
|
)
|
||||||
|
|
||||||
type ApplyDNSProviderType string
|
type ApplyDNSProviderType string
|
||||||
@ -111,7 +131,7 @@ const (
|
|||||||
type DeployProviderType string
|
type DeployProviderType string
|
||||||
|
|
||||||
/*
|
/*
|
||||||
部署目标提供商常量值。
|
部署证书主机提供商常量值。
|
||||||
短横线前的部分始终等于授权提供商类型。
|
短横线前的部分始终等于授权提供商类型。
|
||||||
|
|
||||||
注意:如果追加新的常量值,请保持以 ASCII 排序。
|
注意:如果追加新的常量值,请保持以 ASCII 排序。
|
||||||
|
@ -7,8 +7,6 @@ import (
|
|||||||
|
|
||||||
"github.com/pocketbase/pocketbase/core"
|
"github.com/pocketbase/pocketbase/core"
|
||||||
m "github.com/pocketbase/pocketbase/migrations"
|
m "github.com/pocketbase/pocketbase/migrations"
|
||||||
|
|
||||||
"github.com/usual2970/certimate/internal/domain"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -179,20 +177,20 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, workflowRun := range workflowRuns {
|
for _, workflowRun := range workflowRuns {
|
||||||
type oldWorkflowRunLogRecord struct {
|
type dWorkflowRunLogRecord struct {
|
||||||
Time string `json:"time"`
|
Time string `json:"time"`
|
||||||
Level string `json:"level"`
|
Level string `json:"level"`
|
||||||
Content string `json:"content"`
|
Content string `json:"content"`
|
||||||
Error string `json:"error"`
|
Error string `json:"error"`
|
||||||
}
|
}
|
||||||
type oldWorkflowRunLog struct {
|
type dWorkflowRunLog struct {
|
||||||
NodeId string `json:"nodeId"`
|
NodeId string `json:"nodeId"`
|
||||||
NodeName string `json:"nodeName"`
|
NodeName string `json:"nodeName"`
|
||||||
Records []oldWorkflowRunLogRecord `json:"records"`
|
Records []dWorkflowRunLogRecord `json:"records"`
|
||||||
Error string `json:"error"`
|
Error string `json:"error"`
|
||||||
}
|
}
|
||||||
|
|
||||||
logs := make([]oldWorkflowRunLog, 0)
|
logs := make([]dWorkflowRunLog, 0)
|
||||||
if err := workflowRun.UnmarshalJSONField("logs", &logs); err != nil {
|
if err := workflowRun.UnmarshalJSONField("logs", &logs); err != nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@ -259,8 +257,20 @@ func init() {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type dWorkflowNode struct {
|
||||||
|
Id string `json:"id"`
|
||||||
|
Type string `json:"type"`
|
||||||
|
Name string `json:"name"`
|
||||||
|
Config map[string]any `json:"config"`
|
||||||
|
Inputs map[string]any `json:"inputs"`
|
||||||
|
Outputs map[string]any `json:"outputs"`
|
||||||
|
Next *dWorkflowNode `json:"next,omitempty"`
|
||||||
|
Branches []dWorkflowNode `json:"branches,omitempty"`
|
||||||
|
Validated bool `json:"validated"`
|
||||||
|
}
|
||||||
|
|
||||||
for _, workflowRun := range workflowRuns {
|
for _, workflowRun := range workflowRuns {
|
||||||
node := &domain.WorkflowNode{}
|
node := &dWorkflowNode{}
|
||||||
for _, workflowOutput := range workflowOutputs {
|
for _, workflowOutput := range workflowOutputs {
|
||||||
if workflowOutput.GetString("runId") != workflowRun.Get("id") {
|
if workflowOutput.GetString("runId") != workflowRun.Get("id") {
|
||||||
continue
|
continue
|
||||||
@ -270,8 +280,8 @@ func init() {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if node.Type != domain.WorkflowNodeTypeApply {
|
if node.Type != "apply" {
|
||||||
node = &domain.WorkflowNode{}
|
node = &dWorkflowNode{}
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -286,7 +296,7 @@ func init() {
|
|||||||
} else {
|
} else {
|
||||||
workflow, _ := app.FindRecordById("workflow", workflowRun.GetString("workflowId"))
|
workflow, _ := app.FindRecordById("workflow", workflowRun.GetString("workflowId"))
|
||||||
if workflow != nil {
|
if workflow != nil {
|
||||||
rootNode := &domain.WorkflowNode{}
|
rootNode := &dWorkflowNode{}
|
||||||
if err := workflow.UnmarshalJSONField("content", rootNode); err != nil {
|
if err := workflow.UnmarshalJSONField("content", rootNode); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -294,9 +304,9 @@ func init() {
|
|||||||
rootNode.Next = node
|
rootNode.Next = node
|
||||||
workflowRun.Set("detail", rootNode)
|
workflowRun.Set("detail", rootNode)
|
||||||
} else {
|
} else {
|
||||||
rootNode := &domain.WorkflowNode{
|
rootNode := &dWorkflowNode{
|
||||||
Id: core.GenerateDefaultRandomId(),
|
Id: core.GenerateDefaultRandomId(),
|
||||||
Type: domain.WorkflowNodeTypeStart,
|
Type: "start",
|
||||||
Name: "开始",
|
Name: "开始",
|
||||||
Config: map[string]any{
|
Config: map[string]any{
|
||||||
"trigger": "manual",
|
"trigger": "manual",
|
||||||
|
171
migrations/1743264000_upgrade.go
Normal file
171
migrations/1743264000_upgrade.go
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
package migrations
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/pocketbase/pocketbase/core"
|
||||||
|
m "github.com/pocketbase/pocketbase/migrations"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
m.Register(func(app core.App) error {
|
||||||
|
// update collection `settings`
|
||||||
|
{
|
||||||
|
collection, err := app.FindCollectionByNameOrId("dy6ccjb60spfy6p")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
records, err := app.FindRecordsByFilter(collection, "name='sslProvider'", "-created", 1, 0)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(records) == 1 {
|
||||||
|
record := records[0]
|
||||||
|
|
||||||
|
content := make(map[string]any)
|
||||||
|
if err := record.UnmarshalJSONField("content", &content); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if provider, ok := content["provider"]; ok {
|
||||||
|
if providerStr, ok := provider.(string); ok {
|
||||||
|
if providerStr == "letsencrypt_staging" {
|
||||||
|
content["provider"] = "letsencryptstaging"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if config, ok := content["config"]; ok {
|
||||||
|
if configMap, ok := config.(map[string]any); ok {
|
||||||
|
if _, ok := configMap["letsencrypt_staging"]; ok {
|
||||||
|
configMap["letsencryptstaging"] = configMap["letsencrypt_staging"]
|
||||||
|
delete(configMap, "letsencrypt_staging")
|
||||||
|
}
|
||||||
|
if _, ok := configMap["gts"]; ok {
|
||||||
|
configMap["googletrustservices"] = configMap["gts"]
|
||||||
|
delete(configMap, "gts")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
record.Set("content", content)
|
||||||
|
if err := app.Save(record); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// update collection `access`
|
||||||
|
{
|
||||||
|
collection, err := app.FindCollectionByNameOrId("4yzbv8urny5ja1e")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// update field
|
||||||
|
if err := collection.Fields.AddMarshaledJSONAt(2, []byte(`{
|
||||||
|
"hidden": false,
|
||||||
|
"id": "hwy7m03o",
|
||||||
|
"maxSelect": 1,
|
||||||
|
"name": "provider",
|
||||||
|
"presentable": false,
|
||||||
|
"required": false,
|
||||||
|
"system": false,
|
||||||
|
"type": "select",
|
||||||
|
"values": [
|
||||||
|
"1panel",
|
||||||
|
"acmehttpreq",
|
||||||
|
"akamai",
|
||||||
|
"aliyun",
|
||||||
|
"aws",
|
||||||
|
"azure",
|
||||||
|
"baiducloud",
|
||||||
|
"baishan",
|
||||||
|
"baotapanel",
|
||||||
|
"byteplus",
|
||||||
|
"cachefly",
|
||||||
|
"cdnfly",
|
||||||
|
"cloudflare",
|
||||||
|
"cloudns",
|
||||||
|
"cmcccloud",
|
||||||
|
"ctcccloud",
|
||||||
|
"cucccloud",
|
||||||
|
"desec",
|
||||||
|
"dnsla",
|
||||||
|
"dogecloud",
|
||||||
|
"dynv6",
|
||||||
|
"edgio",
|
||||||
|
"fastly",
|
||||||
|
"gname",
|
||||||
|
"gcore",
|
||||||
|
"godaddy",
|
||||||
|
"goedge",
|
||||||
|
"googletrustservices",
|
||||||
|
"huaweicloud",
|
||||||
|
"jdcloud",
|
||||||
|
"k8s",
|
||||||
|
"letsencrypt",
|
||||||
|
"letsencryptstaging",
|
||||||
|
"local",
|
||||||
|
"namecheap",
|
||||||
|
"namedotcom",
|
||||||
|
"namesilo",
|
||||||
|
"ns1",
|
||||||
|
"porkbun",
|
||||||
|
"powerdns",
|
||||||
|
"qiniu",
|
||||||
|
"qingcloud",
|
||||||
|
"rainyun",
|
||||||
|
"safeline",
|
||||||
|
"ssh",
|
||||||
|
"tencentcloud",
|
||||||
|
"ucloud",
|
||||||
|
"upyun",
|
||||||
|
"vercel",
|
||||||
|
"volcengine",
|
||||||
|
"webhook",
|
||||||
|
"westcn",
|
||||||
|
"zerossl"
|
||||||
|
]
|
||||||
|
}`)); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := app.Save(collection); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// update collection `acme_accounts`
|
||||||
|
{
|
||||||
|
collection, err := app.FindCollectionByNameOrId("012d7abbod1hwvr")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
records, err := app.FindRecordsByFilter(collection, "ca='letsencrypt_staging' || ca='gts'", "-created", 0, 0)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, record := range records {
|
||||||
|
ca := record.GetString("ca")
|
||||||
|
if ca == "letsencrypt_staging" {
|
||||||
|
record.Set("ca", "letsencryptstaging")
|
||||||
|
} else if ca == "gts" {
|
||||||
|
record.Set("ca", "googletrustservices")
|
||||||
|
} else {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := app.Save(record); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}, func(app core.App) error {
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
}
|
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1.0 KiB |
@ -31,6 +31,7 @@ import AccessFormEdgioConfig from "./AccessFormEdgioConfig";
|
|||||||
import AccessFormGcoreConfig from "./AccessFormGcoreConfig";
|
import AccessFormGcoreConfig from "./AccessFormGcoreConfig";
|
||||||
import AccessFormGnameConfig from "./AccessFormGnameConfig";
|
import AccessFormGnameConfig from "./AccessFormGnameConfig";
|
||||||
import AccessFormGoDaddyConfig from "./AccessFormGoDaddyConfig";
|
import AccessFormGoDaddyConfig from "./AccessFormGoDaddyConfig";
|
||||||
|
import AccessFormGoogleTrustServicesConfig from "./AccessFormGoogleTrustServicesConfig";
|
||||||
import AccessFormHuaweiCloudConfig from "./AccessFormHuaweiCloudConfig";
|
import AccessFormHuaweiCloudConfig from "./AccessFormHuaweiCloudConfig";
|
||||||
import AccessFormJDCloudConfig from "./AccessFormJDCloudConfig";
|
import AccessFormJDCloudConfig from "./AccessFormJDCloudConfig";
|
||||||
import AccessFormKubernetesConfig from "./AccessFormKubernetesConfig";
|
import AccessFormKubernetesConfig from "./AccessFormKubernetesConfig";
|
||||||
@ -52,6 +53,7 @@ import AccessFormVercelConfig from "./AccessFormVercelConfig";
|
|||||||
import AccessFormVolcEngineConfig from "./AccessFormVolcEngineConfig";
|
import AccessFormVolcEngineConfig from "./AccessFormVolcEngineConfig";
|
||||||
import AccessFormWebhookConfig from "./AccessFormWebhookConfig";
|
import AccessFormWebhookConfig from "./AccessFormWebhookConfig";
|
||||||
import AccessFormWestcnConfig from "./AccessFormWestcnConfig";
|
import AccessFormWestcnConfig from "./AccessFormWestcnConfig";
|
||||||
|
import AccessFormZeroSSLConfig from "./AccessFormZeroSSLConfig";
|
||||||
|
|
||||||
type AccessFormFieldValues = Partial<MaybeModelRecord<AccessModel>>;
|
type AccessFormFieldValues = Partial<MaybeModelRecord<AccessModel>>;
|
||||||
type AccessFormPresets = "add" | "edit";
|
type AccessFormPresets = "add" | "edit";
|
||||||
@ -147,6 +149,8 @@ const AccessForm = forwardRef<AccessFormInstance, AccessFormProps>(({ className,
|
|||||||
return <AccessFormGnameConfig {...nestedFormProps} />;
|
return <AccessFormGnameConfig {...nestedFormProps} />;
|
||||||
case ACCESS_PROVIDERS.GODADDY:
|
case ACCESS_PROVIDERS.GODADDY:
|
||||||
return <AccessFormGoDaddyConfig {...nestedFormProps} />;
|
return <AccessFormGoDaddyConfig {...nestedFormProps} />;
|
||||||
|
case ACCESS_PROVIDERS.GOOGLETRUSTSERVICES:
|
||||||
|
return <AccessFormGoogleTrustServicesConfig {...nestedFormProps} />;
|
||||||
case ACCESS_PROVIDERS.EDGIO:
|
case ACCESS_PROVIDERS.EDGIO:
|
||||||
return <AccessFormEdgioConfig {...nestedFormProps} />;
|
return <AccessFormEdgioConfig {...nestedFormProps} />;
|
||||||
case ACCESS_PROVIDERS.HUAWEICLOUD:
|
case ACCESS_PROVIDERS.HUAWEICLOUD:
|
||||||
@ -191,6 +195,8 @@ const AccessForm = forwardRef<AccessFormInstance, AccessFormProps>(({ className,
|
|||||||
return <AccessFormWebhookConfig {...nestedFormProps} />;
|
return <AccessFormWebhookConfig {...nestedFormProps} />;
|
||||||
case ACCESS_PROVIDERS.WESTCN:
|
case ACCESS_PROVIDERS.WESTCN:
|
||||||
return <AccessFormWestcnConfig {...nestedFormProps} />;
|
return <AccessFormWestcnConfig {...nestedFormProps} />;
|
||||||
|
case ACCESS_PROVIDERS.ZEROSSL:
|
||||||
|
return <AccessFormZeroSSLConfig {...nestedFormProps} />;
|
||||||
}
|
}
|
||||||
}, [disabled, initialValues?.config, fieldProvider, nestedFormInst, nestedFormName]);
|
}, [disabled, initialValues?.config, fieldProvider, nestedFormInst, nestedFormName]);
|
||||||
|
|
||||||
|
@ -0,0 +1,82 @@
|
|||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { Form, type FormInstance, Input } from "antd";
|
||||||
|
import { createSchemaFieldRule } from "antd-zod";
|
||||||
|
import { z } from "zod";
|
||||||
|
|
||||||
|
import { type AccessConfigForGoogleTrustServices } from "@/domain/access";
|
||||||
|
|
||||||
|
type AccessFormGoogleTrustServicesConfigFieldValues = Nullish<AccessConfigForGoogleTrustServices>;
|
||||||
|
|
||||||
|
export type AccessFormGoogleTrustServicesConfigProps = {
|
||||||
|
form: FormInstance;
|
||||||
|
formName: string;
|
||||||
|
disabled?: boolean;
|
||||||
|
initialValues?: AccessFormGoogleTrustServicesConfigFieldValues;
|
||||||
|
onValuesChange?: (values: AccessFormGoogleTrustServicesConfigFieldValues) => void;
|
||||||
|
};
|
||||||
|
|
||||||
|
const initFormModel = (): AccessFormGoogleTrustServicesConfigFieldValues => {
|
||||||
|
return {
|
||||||
|
eabKid: "",
|
||||||
|
eabHmacKey: "",
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
const AccessFormGoogleTrustServicesConfig = ({
|
||||||
|
form: formInst,
|
||||||
|
formName,
|
||||||
|
disabled,
|
||||||
|
initialValues,
|
||||||
|
onValuesChange,
|
||||||
|
}: AccessFormGoogleTrustServicesConfigProps) => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const formSchema = z.object({
|
||||||
|
eabKid: z
|
||||||
|
.string()
|
||||||
|
.min(1, t("access.form.googletrustservices_eab_kid.placeholder"))
|
||||||
|
.max(256, t("common.errmsg.string_max", { max: 256 }))
|
||||||
|
.trim(),
|
||||||
|
eabHmacKey: z
|
||||||
|
.string()
|
||||||
|
.min(1, t("access.form.googletrustservices_eab_hmac_key.placeholder"))
|
||||||
|
.max(256, t("common.errmsg.string_max", { max: 256 }))
|
||||||
|
.trim(),
|
||||||
|
});
|
||||||
|
const formRule = createSchemaFieldRule(formSchema);
|
||||||
|
|
||||||
|
const handleFormChange = (_: unknown, values: z.infer<typeof formSchema>) => {
|
||||||
|
onValuesChange?.(values);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Form
|
||||||
|
form={formInst}
|
||||||
|
disabled={disabled}
|
||||||
|
initialValues={initialValues ?? initFormModel()}
|
||||||
|
layout="vertical"
|
||||||
|
name={formName}
|
||||||
|
onValuesChange={handleFormChange}
|
||||||
|
>
|
||||||
|
<Form.Item
|
||||||
|
name="eabKid"
|
||||||
|
label={t("access.form.googletrustservices_eab_kid.label")}
|
||||||
|
rules={[formRule]}
|
||||||
|
tooltip={<span dangerouslySetInnerHTML={{ __html: t("access.form.googletrustservices_eab_kid.tooltip") }}></span>}
|
||||||
|
>
|
||||||
|
<Input autoComplete="new-password" placeholder={t("access.form.googletrustservices_eab_kid.placeholder")} />
|
||||||
|
</Form.Item>
|
||||||
|
|
||||||
|
<Form.Item
|
||||||
|
name="eabHmacKey"
|
||||||
|
label={t("access.form.googletrustservices_eab_hmac_key.label")}
|
||||||
|
rules={[formRule]}
|
||||||
|
tooltip={<span dangerouslySetInnerHTML={{ __html: t("access.form.googletrustservices_eab_hmac_key.tooltip") }}></span>}
|
||||||
|
>
|
||||||
|
<Input.Password autoComplete="new-password" placeholder={t("access.form.googletrustservices_eab_hmac_key.placeholder")} />
|
||||||
|
</Form.Item>
|
||||||
|
</Form>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default AccessFormGoogleTrustServicesConfig;
|
76
ui/src/components/access/AccessFormZeroSSLConfig.tsx
Normal file
76
ui/src/components/access/AccessFormZeroSSLConfig.tsx
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
import { Form, type FormInstance, Input } from "antd";
|
||||||
|
import { createSchemaFieldRule } from "antd-zod";
|
||||||
|
import { z } from "zod";
|
||||||
|
|
||||||
|
import { type AccessConfigForZeroSSL } from "@/domain/access";
|
||||||
|
|
||||||
|
type AccessFormZeroSSLConfigFieldValues = Nullish<AccessConfigForZeroSSL>;
|
||||||
|
|
||||||
|
export type AccessFormZeroSSLConfigProps = {
|
||||||
|
form: FormInstance;
|
||||||
|
formName: string;
|
||||||
|
disabled?: boolean;
|
||||||
|
initialValues?: AccessFormZeroSSLConfigFieldValues;
|
||||||
|
onValuesChange?: (values: AccessFormZeroSSLConfigFieldValues) => void;
|
||||||
|
};
|
||||||
|
|
||||||
|
const initFormModel = (): AccessFormZeroSSLConfigFieldValues => {
|
||||||
|
return {
|
||||||
|
eabKid: "",
|
||||||
|
eabHmacKey: "",
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
const AccessFormZeroSSLConfig = ({ form: formInst, formName, disabled, initialValues, onValuesChange }: AccessFormZeroSSLConfigProps) => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const formSchema = z.object({
|
||||||
|
eabKid: z
|
||||||
|
.string()
|
||||||
|
.min(1, t("access.form.zerossl_eab_kid.placeholder"))
|
||||||
|
.max(256, t("common.errmsg.string_max", { max: 256 }))
|
||||||
|
.trim(),
|
||||||
|
eabHmacKey: z
|
||||||
|
.string()
|
||||||
|
.min(1, t("access.form.zerossl_eab_hmac_key.placeholder"))
|
||||||
|
.max(256, t("common.errmsg.string_max", { max: 256 }))
|
||||||
|
.trim(),
|
||||||
|
});
|
||||||
|
const formRule = createSchemaFieldRule(formSchema);
|
||||||
|
|
||||||
|
const handleFormChange = (_: unknown, values: z.infer<typeof formSchema>) => {
|
||||||
|
onValuesChange?.(values);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Form
|
||||||
|
form={formInst}
|
||||||
|
disabled={disabled}
|
||||||
|
initialValues={initialValues ?? initFormModel()}
|
||||||
|
layout="vertical"
|
||||||
|
name={formName}
|
||||||
|
onValuesChange={handleFormChange}
|
||||||
|
>
|
||||||
|
<Form.Item
|
||||||
|
name="eabKid"
|
||||||
|
label={t("access.form.zerossl_eab_kid.label")}
|
||||||
|
rules={[formRule]}
|
||||||
|
tooltip={<span dangerouslySetInnerHTML={{ __html: t("access.form.zerossl_eab_kid.tooltip") }}></span>}
|
||||||
|
>
|
||||||
|
<Input autoComplete="new-password" placeholder={t("access.form.zerossl_eab_kid.placeholder")} />
|
||||||
|
</Form.Item>
|
||||||
|
|
||||||
|
<Form.Item
|
||||||
|
name="eabHmacKey"
|
||||||
|
label={t("access.form.zerossl_eab_hmac_key.label")}
|
||||||
|
rules={[formRule]}
|
||||||
|
tooltip={<span dangerouslySetInnerHTML={{ __html: t("access.form.zerossl_eab_hmac_key.tooltip") }}></span>}
|
||||||
|
>
|
||||||
|
<Input.Password autoComplete="new-password" placeholder={t("access.form.zerossl_eab_hmac_key.placeholder")} />
|
||||||
|
</Form.Item>
|
||||||
|
</Form>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default AccessFormZeroSSLConfig;
|
@ -9,9 +9,10 @@ export type AccessProviderSelectProps = Omit<
|
|||||||
"filterOption" | "filterSort" | "labelRender" | "options" | "optionFilterProp" | "optionLabelProp" | "optionRender"
|
"filterOption" | "filterSort" | "labelRender" | "options" | "optionFilterProp" | "optionLabelProp" | "optionRender"
|
||||||
> & {
|
> & {
|
||||||
filter?: (record: AccessProvider) => boolean;
|
filter?: (record: AccessProvider) => boolean;
|
||||||
|
showOptionTags?: boolean;
|
||||||
};
|
};
|
||||||
|
|
||||||
const AccessProviderSelect = ({ filter, ...props }: AccessProviderSelectProps) => {
|
const AccessProviderSelect = ({ filter, showOptionTags, ...props }: AccessProviderSelectProps = { showOptionTags: true }) => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
|
|
||||||
const [options, setOptions] = useState<Array<{ key: string; value: string; label: string; data: AccessProvider }>>([]);
|
const [options, setOptions] = useState<Array<{ key: string; value: string; label: string; data: AccessProvider }>>([]);
|
||||||
@ -38,18 +39,14 @@ const AccessProviderSelect = ({ filter, ...props }: AccessProviderSelectProps) =
|
|||||||
{t(provider?.name ?? "")}
|
{t(provider?.name ?? "")}
|
||||||
</Typography.Text>
|
</Typography.Text>
|
||||||
</Space>
|
</Space>
|
||||||
<div>
|
{!showOptionTags && (
|
||||||
{provider?.usages?.includes(ACCESS_USAGES.APPLY) && (
|
<div>
|
||||||
<>
|
{provider?.usages?.includes(ACCESS_USAGES.DNS) && <Tag color="peru">{t("access.props.provider.usage.dns")}</Tag>}
|
||||||
<Tag color="orange">{t("access.props.provider.usage.dns")}</Tag>
|
{provider?.usages?.includes(ACCESS_USAGES.HOSTING) && <Tag color="royalblue">{t("access.props.provider.usage.hosting")}</Tag>}
|
||||||
</>
|
{/* {provider?.usages?.includes(ACCESS_USAGES.CA) && <Tag color="crimson">{t("access.props.provider.usage.ca")}</Tag>} */}
|
||||||
)}
|
{/* {provider?.usages?.includes(ACCESS_USAGES.NOTIFICATION) && <Tag color="mediumaquamarine">{t("access.props.provider.usage.notification")}</Tag>} */}
|
||||||
{provider?.usages?.includes(ACCESS_USAGES.DEPLOY) && (
|
</div>
|
||||||
<>
|
)}
|
||||||
<Tag color="blue">{t("access.props.provider.usage.host")}</Tag>
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@ -28,6 +28,7 @@ export interface AccessModel extends BaseModel {
|
|||||||
| AccessConfigForGcore
|
| AccessConfigForGcore
|
||||||
| AccessConfigForGname
|
| AccessConfigForGname
|
||||||
| AccessConfigForGoDaddy
|
| AccessConfigForGoDaddy
|
||||||
|
| AccessConfigForGoogleTrustServices
|
||||||
| AccessConfigForHuaweiCloud
|
| AccessConfigForHuaweiCloud
|
||||||
| AccessConfigForJDCloud
|
| AccessConfigForJDCloud
|
||||||
| AccessConfigForKubernetes
|
| AccessConfigForKubernetes
|
||||||
@ -48,6 +49,7 @@ export interface AccessModel extends BaseModel {
|
|||||||
| AccessConfigForVolcEngine
|
| AccessConfigForVolcEngine
|
||||||
| AccessConfigForWebhook
|
| AccessConfigForWebhook
|
||||||
| AccessConfigForWestcn
|
| AccessConfigForWestcn
|
||||||
|
| AccessConfigForZeroSSL
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,6 +165,11 @@ export type AccessConfigForGoDaddy = {
|
|||||||
apiSecret: string;
|
apiSecret: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type AccessConfigForGoogleTrustServices = {
|
||||||
|
eabKid: string;
|
||||||
|
eabHmacKey: string;
|
||||||
|
};
|
||||||
|
|
||||||
export type AccessConfigForHuaweiCloud = {
|
export type AccessConfigForHuaweiCloud = {
|
||||||
accessKeyId: string;
|
accessKeyId: string;
|
||||||
secretAccessKey: string;
|
secretAccessKey: string;
|
||||||
@ -266,4 +273,9 @@ export type AccessConfigForWestcn = {
|
|||||||
username: string;
|
username: string;
|
||||||
apiPassword: string;
|
apiPassword: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type AccessConfigForZeroSSL = {
|
||||||
|
eabKid: string;
|
||||||
|
eabHmacKey: string;
|
||||||
|
};
|
||||||
// #endregion
|
// #endregion
|
||||||
|
@ -22,13 +22,16 @@ export const ACCESS_PROVIDERS = Object.freeze({
|
|||||||
DNSLA: "dnsla",
|
DNSLA: "dnsla",
|
||||||
DOGECLOUD: "dogecloud",
|
DOGECLOUD: "dogecloud",
|
||||||
DYNV6: "dynv6",
|
DYNV6: "dynv6",
|
||||||
|
EDGIO: "edgio",
|
||||||
GCORE: "gcore",
|
GCORE: "gcore",
|
||||||
GNAME: "gname",
|
GNAME: "gname",
|
||||||
GODADDY: "godaddy",
|
GODADDY: "godaddy",
|
||||||
EDGIO: "edgio",
|
GOOGLETRUSTSERVICES: "googletrustservices",
|
||||||
HUAWEICLOUD: "huaweicloud",
|
HUAWEICLOUD: "huaweicloud",
|
||||||
JDCLOUD: "jdcloud",
|
JDCLOUD: "jdcloud",
|
||||||
KUBERNETES: "k8s",
|
KUBERNETES: "k8s",
|
||||||
|
LETSENCRYPT: "letsencrypt",
|
||||||
|
LETSENCRYPTSTAGING: "letsencryptstaging",
|
||||||
LOCAL: "local",
|
LOCAL: "local",
|
||||||
NAMECHEAP: "namecheap",
|
NAMECHEAP: "namecheap",
|
||||||
NAMEDOTCOM: "namedotcom",
|
NAMEDOTCOM: "namedotcom",
|
||||||
@ -47,13 +50,16 @@ export const ACCESS_PROVIDERS = Object.freeze({
|
|||||||
VOLCENGINE: "volcengine",
|
VOLCENGINE: "volcengine",
|
||||||
WEBHOOK: "webhook",
|
WEBHOOK: "webhook",
|
||||||
WESTCN: "westcn",
|
WESTCN: "westcn",
|
||||||
|
ZEROSSL: "zerossl",
|
||||||
} as const);
|
} as const);
|
||||||
|
|
||||||
export type AccessProviderType = (typeof ACCESS_PROVIDERS)[keyof typeof ACCESS_PROVIDERS];
|
export type AccessProviderType = (typeof ACCESS_PROVIDERS)[keyof typeof ACCESS_PROVIDERS];
|
||||||
|
|
||||||
export const ACCESS_USAGES = Object.freeze({
|
export const ACCESS_USAGES = Object.freeze({
|
||||||
APPLY: "apply",
|
DNS: "dns",
|
||||||
DEPLOY: "deploy",
|
HOSTING: "hosting",
|
||||||
|
CA: "ca",
|
||||||
|
NOTIFICATION: "notification",
|
||||||
} as const);
|
} as const);
|
||||||
|
|
||||||
export type AccessUsageType = (typeof ACCESS_USAGES)[keyof typeof ACCESS_USAGES];
|
export type AccessUsageType = (typeof ACCESS_USAGES)[keyof typeof ACCESS_USAGES];
|
||||||
@ -67,55 +73,61 @@ export type AccessProvider = {
|
|||||||
|
|
||||||
export const accessProvidersMap: Map<AccessProvider["type"] | string, AccessProvider> = new Map(
|
export const accessProvidersMap: Map<AccessProvider["type"] | string, AccessProvider> = new Map(
|
||||||
/*
|
/*
|
||||||
注意:此处的顺序决定显示在前端的顺序。
|
注意:此处的顺序决定显示在前端的顺序。
|
||||||
NOTICE: The following order determines the order displayed at the frontend.
|
NOTICE: The following order determines the order displayed at the frontend.
|
||||||
*/
|
*/
|
||||||
[
|
[
|
||||||
[ACCESS_PROVIDERS.LOCAL, "provider.local", "/imgs/providers/local.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.LOCAL, "provider.local", "/imgs/providers/local.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.SSH, "provider.ssh", "/imgs/providers/ssh.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.SSH, "provider.ssh", "/imgs/providers/ssh.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.WEBHOOK, "provider.webhook", "/imgs/providers/webhook.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.WEBHOOK, "provider.webhook", "/imgs/providers/webhook.svg", [ACCESS_USAGES.HOSTING, ACCESS_USAGES.NOTIFICATION]],
|
||||||
[ACCESS_PROVIDERS.KUBERNETES, "provider.kubernetes", "/imgs/providers/kubernetes.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.KUBERNETES, "provider.kubernetes", "/imgs/providers/kubernetes.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.ALIYUN, "provider.aliyun", "/imgs/providers/aliyun.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.TENCENTCLOUD, "provider.tencentcloud", "/imgs/providers/tencentcloud.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.BAIDUCLOUD, "provider.baiducloud", "/imgs/providers/baiducloud.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.HUAWEICLOUD, "provider.huaweicloud", "/imgs/providers/huaweicloud.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.VOLCENGINE, "provider.volcengine", "/imgs/providers/volcengine.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.JDCLOUD, "provider.jdcloud", "/imgs/providers/jdcloud.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.AWS, "provider.aws", "/imgs/providers/aws.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.AZURE, "provider.azure", "/imgs/providers/azure.svg", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.GCORE, "provider.gcore", "/imgs/providers/gcore.png", [ACCESS_USAGES.APPLY, ACCESS_USAGES.DEPLOY]],
|
|
||||||
|
|
||||||
[ACCESS_PROVIDERS.QINIU, "provider.qiniu", "/imgs/providers/qiniu.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.ALIYUN, "provider.aliyun", "/imgs/providers/aliyun.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.UPYUN, "provider.upyun", "/imgs/providers/upyun.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.TENCENTCLOUD, "provider.tencentcloud", "/imgs/providers/tencentcloud.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.BAISHAN, "provider.baishan", "/imgs/providers/baishan.png", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.BAIDUCLOUD, "provider.baiducloud", "/imgs/providers/baiducloud.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.DOGECLOUD, "provider.dogecloud", "/imgs/providers/dogecloud.png", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.HUAWEICLOUD, "provider.huaweicloud", "/imgs/providers/huaweicloud.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.BYTEPLUS, "provider.byteplus", "/imgs/providers/byteplus.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.VOLCENGINE, "provider.volcengine", "/imgs/providers/volcengine.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.UCLOUD, "provider.ucloud", "/imgs/providers/ucloud.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.JDCLOUD, "provider.jdcloud", "/imgs/providers/jdcloud.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.SAFELINE, "provider.safeline", "/imgs/providers/safeline.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.AWS, "provider.aws", "/imgs/providers/aws.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS["1PANEL"], "provider.1panel", "/imgs/providers/1panel.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.AZURE, "provider.azure", "/imgs/providers/azure.svg", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.BAOTAPANEL, "provider.baotapanel", "/imgs/providers/baotapanel.svg", [ACCESS_USAGES.DEPLOY]],
|
[ACCESS_PROVIDERS.GCORE, "provider.gcore", "/imgs/providers/gcore.png", [ACCESS_USAGES.DNS, ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.CACHEFLY, "provider.cachefly", "/imgs/providers/cachefly.png", [ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.CDNFLY, "provider.cdnfly", "/imgs/providers/cdnfly.png", [ACCESS_USAGES.DEPLOY]],
|
|
||||||
[ACCESS_PROVIDERS.EDGIO, "provider.edgio", "/imgs/providers/edgio.svg", [ACCESS_USAGES.DEPLOY]],
|
|
||||||
|
|
||||||
[ACCESS_PROVIDERS.CLOUDFLARE, "provider.cloudflare", "/imgs/providers/cloudflare.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.QINIU, "provider.qiniu", "/imgs/providers/qiniu.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.CLOUDNS, "provider.cloudns", "/imgs/providers/cloudns.png", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.UPYUN, "provider.upyun", "/imgs/providers/upyun.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.DESEC, "provider.desec", "/imgs/providers/desec.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.BAISHAN, "provider.baishan", "/imgs/providers/baishan.png", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.DNSLA, "provider.dnsla", "/imgs/providers/dnsla.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.DOGECLOUD, "provider.dogecloud", "/imgs/providers/dogecloud.png", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.DYNV6, "provider.dynv6", "/imgs/providers/dynv6.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.BYTEPLUS, "provider.byteplus", "/imgs/providers/byteplus.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.GNAME, "provider.gname", "/imgs/providers/gname.png", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.UCLOUD, "provider.ucloud", "/imgs/providers/ucloud.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.GODADDY, "provider.godaddy", "/imgs/providers/godaddy.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.SAFELINE, "provider.safeline", "/imgs/providers/safeline.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.NAMECHEAP, "provider.namecheap", "/imgs/providers/namecheap.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS["1PANEL"], "provider.1panel", "/imgs/providers/1panel.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.NAMEDOTCOM, "provider.namedotcom", "/imgs/providers/namedotcom.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.BAOTAPANEL, "provider.baotapanel", "/imgs/providers/baotapanel.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.NAMESILO, "provider.namesilo", "/imgs/providers/namesilo.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.CACHEFLY, "provider.cachefly", "/imgs/providers/cachefly.png", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.NS1, "provider.ns1", "/imgs/providers/ns1.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.CDNFLY, "provider.cdnfly", "/imgs/providers/cdnfly.png", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.PORKBUN, "provider.porkbun", "/imgs/providers/porkbun.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.EDGIO, "provider.edgio", "/imgs/providers/edgio.svg", [ACCESS_USAGES.HOSTING]],
|
||||||
[ACCESS_PROVIDERS.VERCEL, "provider.vercel", "/imgs/providers/vercel.svg", [ACCESS_USAGES.APPLY]],
|
|
||||||
[ACCESS_PROVIDERS.CMCCCLOUD, "provider.cmcccloud", "/imgs/providers/cmcccloud.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.CLOUDFLARE, "provider.cloudflare", "/imgs/providers/cloudflare.svg", [ACCESS_USAGES.DNS]],
|
||||||
[ACCESS_PROVIDERS.RAINYUN, "provider.rainyun", "/imgs/providers/rainyun.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.CLOUDNS, "provider.cloudns", "/imgs/providers/cloudns.png", [ACCESS_USAGES.DNS]],
|
||||||
[ACCESS_PROVIDERS.WESTCN, "provider.westcn", "/imgs/providers/westcn.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.DESEC, "provider.desec", "/imgs/providers/desec.svg", [ACCESS_USAGES.DNS]],
|
||||||
[ACCESS_PROVIDERS.POWERDNS, "provider.powerdns", "/imgs/providers/powerdns.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.DNSLA, "provider.dnsla", "/imgs/providers/dnsla.svg", [ACCESS_USAGES.DNS]],
|
||||||
[ACCESS_PROVIDERS.ACMEHTTPREQ, "provider.acmehttpreq", "/imgs/providers/acmehttpreq.svg", [ACCESS_USAGES.APPLY]],
|
[ACCESS_PROVIDERS.DYNV6, "provider.dynv6", "/imgs/providers/dynv6.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.GNAME, "provider.gname", "/imgs/providers/gname.png", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.GODADDY, "provider.godaddy", "/imgs/providers/godaddy.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.NAMECHEAP, "provider.namecheap", "/imgs/providers/namecheap.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.NAMEDOTCOM, "provider.namedotcom", "/imgs/providers/namedotcom.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.NAMESILO, "provider.namesilo", "/imgs/providers/namesilo.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.NS1, "provider.ns1", "/imgs/providers/ns1.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.PORKBUN, "provider.porkbun", "/imgs/providers/porkbun.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.VERCEL, "provider.vercel", "/imgs/providers/vercel.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.CMCCCLOUD, "provider.cmcccloud", "/imgs/providers/cmcccloud.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.RAINYUN, "provider.rainyun", "/imgs/providers/rainyun.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.WESTCN, "provider.westcn", "/imgs/providers/westcn.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.POWERDNS, "provider.powerdns", "/imgs/providers/powerdns.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
[ACCESS_PROVIDERS.ACMEHTTPREQ, "provider.acmehttpreq", "/imgs/providers/acmehttpreq.svg", [ACCESS_USAGES.DNS]],
|
||||||
|
|
||||||
|
[ACCESS_PROVIDERS.LETSENCRYPT, "provider.letsencrypt", "/imgs/providers/letsencrypt.svg", [ACCESS_USAGES.CA]],
|
||||||
|
[ACCESS_PROVIDERS.LETSENCRYPTSTAGING, "provider.letsencryptstaging", "/imgs/providers/letsencrypt.svg", [ACCESS_USAGES.CA]],
|
||||||
|
[ACCESS_PROVIDERS.GOOGLETRUSTSERVICES, "provider.googletrustservices", "/imgs/providers/google.svg", [ACCESS_USAGES.CA]],
|
||||||
|
[ACCESS_PROVIDERS.ZEROSSL, "provider.zerossl", "/imgs/providers/zerossl.svg", [ACCESS_USAGES.CA]],
|
||||||
].map((e) => [
|
].map((e) => [
|
||||||
e[0] as string,
|
e[0] as string,
|
||||||
{
|
{
|
||||||
|
@ -136,9 +136,9 @@ export const notifyChannelsMap: Map<NotifyChannel["type"], NotifyChannel> = new
|
|||||||
// #region Settings: SSLProvider
|
// #region Settings: SSLProvider
|
||||||
export const SSLPROVIDERS = Object.freeze({
|
export const SSLPROVIDERS = Object.freeze({
|
||||||
LETS_ENCRYPT: "letsencrypt",
|
LETS_ENCRYPT: "letsencrypt",
|
||||||
LETS_ENCRYPT_STAGING: "letsencrypt_staging",
|
LETS_ENCRYPT_STAGING: "letsencryptstaging",
|
||||||
ZERO_SSL: "zerossl",
|
ZERO_SSL: "zerossl",
|
||||||
GOOGLE_TRUST_SERVICES: "gts",
|
GOOGLE_TRUST_SERVICES: "googletrustservices",
|
||||||
} as const);
|
} as const);
|
||||||
|
|
||||||
export type SSLProviders = (typeof SSLPROVIDERS)[keyof typeof SSLPROVIDERS];
|
export type SSLProviders = (typeof SSLPROVIDERS)[keyof typeof SSLPROVIDERS];
|
||||||
|
@ -14,7 +14,11 @@
|
|||||||
"access.props.name": "Name",
|
"access.props.name": "Name",
|
||||||
"access.props.provider": "Provider",
|
"access.props.provider": "Provider",
|
||||||
"access.props.provider.usage.dns": "DNS provider",
|
"access.props.provider.usage.dns": "DNS provider",
|
||||||
"access.props.provider.usage.host": "Host provider",
|
"access.props.provider.usage.hosting": "Hosting provider",
|
||||||
|
"access.props.provider.usage.ca": "CA",
|
||||||
|
"access.props.provider.usage.notification": "Notification channel",
|
||||||
|
"access.props.ca": "Certificate authority",
|
||||||
|
"access.props.channel": "Notification channel",
|
||||||
"access.props.created_at": "Created at",
|
"access.props.created_at": "Created at",
|
||||||
"access.props.updated_at": "Updated at",
|
"access.props.updated_at": "Updated at",
|
||||||
|
|
||||||
@ -165,6 +169,12 @@
|
|||||||
"access.form.godaddy_api_secret.label": "GoDaddy API secret",
|
"access.form.godaddy_api_secret.label": "GoDaddy API secret",
|
||||||
"access.form.godaddy_api_secret.placeholder": "Please enter GoDaddy API secret",
|
"access.form.godaddy_api_secret.placeholder": "Please enter GoDaddy API secret",
|
||||||
"access.form.godaddy_api_secret.tooltip": "For more information, see <a href=\"https://developer.godaddy.com/\" target=\"_blank\">https://developer.godaddy.com/</a>",
|
"access.form.godaddy_api_secret.tooltip": "For more information, see <a href=\"https://developer.godaddy.com/\" target=\"_blank\">https://developer.godaddy.com/</a>",
|
||||||
|
"access.form.googletrustservices_eab_kid.label": "ACME EAB KID",
|
||||||
|
"access.form.googletrustservices_eab_kid.placeholder": "Please enter ACME EAB KID",
|
||||||
|
"access.form.googletrustservices_eab_kid.tooltip": "For more information, see <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
||||||
|
"access.form.googletrustservices_eab_hmac_key.label": "ACME EAB HMAC key",
|
||||||
|
"access.form.googletrustservices_eab_hmac_key.placeholder": "Please enter ACME EAB HMAC key",
|
||||||
|
"access.form.googletrustservices_eab_hmac_key.tooltip": "For more information, see <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
||||||
"access.form.huaweicloud_access_key_id.label": "Huawei Cloud AccessKeyId",
|
"access.form.huaweicloud_access_key_id.label": "Huawei Cloud AccessKeyId",
|
||||||
"access.form.huaweicloud_access_key_id.placeholder": "Please enter Huawei Cloud AccessKeyId",
|
"access.form.huaweicloud_access_key_id.placeholder": "Please enter Huawei Cloud AccessKeyId",
|
||||||
"access.form.huaweicloud_access_key_id.tooltip": "For more information, see <a href=\"https://support.huaweicloud.com/intl/en-us/usermanual-ca/ca_01_0003.html\" target=\"_blank\">https://support.huaweicloud.com/intl/en-us/usermanual-ca/ca_01_0003.html</a>",
|
"access.form.huaweicloud_access_key_id.tooltip": "For more information, see <a href=\"https://support.huaweicloud.com/intl/en-us/usermanual-ca/ca_01_0003.html\" target=\"_blank\">https://support.huaweicloud.com/intl/en-us/usermanual-ca/ca_01_0003.html</a>",
|
||||||
@ -284,5 +294,11 @@
|
|||||||
"access.form.westcn_username.tooltip": "For more information, see <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>",
|
"access.form.westcn_username.tooltip": "For more information, see <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>",
|
||||||
"access.form.westcn_api_password.label": "West.cn API password",
|
"access.form.westcn_api_password.label": "West.cn API password",
|
||||||
"access.form.westcn_api_password.placeholder": "Please enter West.cn API password",
|
"access.form.westcn_api_password.placeholder": "Please enter West.cn API password",
|
||||||
"access.form.westcn_api_password.tooltip": "For more information, see <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>"
|
"access.form.westcn_api_password.tooltip": "For more information, see <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>",
|
||||||
|
"access.form.zerossl_eab_kid.label": "ACME EAB KID",
|
||||||
|
"access.form.zerossl_eab_kid.placeholder": "Please enter ACME EAB KID",
|
||||||
|
"access.form.zerossl_eab_kid.tooltip": "For more information, see <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>",
|
||||||
|
"access.form.zerossl_eab_hmac_key.label": "ACME EAB HMAC key",
|
||||||
|
"access.form.zerossl_eab_hmac_key.placeholder": "Please enter ACME EAB HMAC key",
|
||||||
|
"access.form.zerossl_eab_hmac_key.tooltip": "For more information, see <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>"
|
||||||
}
|
}
|
||||||
|
@ -61,6 +61,7 @@
|
|||||||
"provider.godaddy": "GoDaddy",
|
"provider.godaddy": "GoDaddy",
|
||||||
"provider.goedge": "GoEdge",
|
"provider.goedge": "GoEdge",
|
||||||
"provider.goedge.cdn": "GoEdge - CDN (Content Delivery Network)",
|
"provider.goedge.cdn": "GoEdge - CDN (Content Delivery Network)",
|
||||||
|
"provider.googletrustservices": "Google Trust Services",
|
||||||
"provider.huaweicloud": "Huawei Cloud",
|
"provider.huaweicloud": "Huawei Cloud",
|
||||||
"provider.huaweicloud.cdn": "Huawei Cloud - CDN (Content Delivery Network)",
|
"provider.huaweicloud.cdn": "Huawei Cloud - CDN (Content Delivery Network)",
|
||||||
"provider.huaweicloud.dns": "Huawei Cloud - DNS (Domain Name Service)",
|
"provider.huaweicloud.dns": "Huawei Cloud - DNS (Domain Name Service)",
|
||||||
@ -75,6 +76,8 @@
|
|||||||
"provider.jdcloud.vod": "JD Cloud - VOD (Video on Demand)",
|
"provider.jdcloud.vod": "JD Cloud - VOD (Video on Demand)",
|
||||||
"provider.kubernetes": "Kubernetes",
|
"provider.kubernetes": "Kubernetes",
|
||||||
"provider.kubernetes.secret": "Kubernetes - Secret",
|
"provider.kubernetes.secret": "Kubernetes - Secret",
|
||||||
|
"provider.letsencrypt": "Let's Encrypt",
|
||||||
|
"provider.letsencryptstaging": "Let's Encrypt Staging Environment",
|
||||||
"provider.local": "Local deployment",
|
"provider.local": "Local deployment",
|
||||||
"provider.namecheap": "Namecheap",
|
"provider.namecheap": "Namecheap",
|
||||||
"provider.namedotcom": "Name.com",
|
"provider.namedotcom": "Name.com",
|
||||||
@ -121,6 +124,7 @@
|
|||||||
"provider.volcengine.tos": "Volcengine - TOS (Tinder Object Storage)",
|
"provider.volcengine.tos": "Volcengine - TOS (Tinder Object Storage)",
|
||||||
"provider.webhook": "Webhook",
|
"provider.webhook": "Webhook",
|
||||||
"provider.westcn": "West.cn",
|
"provider.westcn": "West.cn",
|
||||||
|
"provider.zerossl": "ZeroSSL",
|
||||||
|
|
||||||
"provider.category.all": "All",
|
"provider.category.all": "All",
|
||||||
"provider.category.cdn": "CDN",
|
"provider.category.cdn": "CDN",
|
||||||
|
@ -82,14 +82,14 @@
|
|||||||
"settings.sslprovider.form.zerossl_eab_kid.label": "EAB KID",
|
"settings.sslprovider.form.zerossl_eab_kid.label": "EAB KID",
|
||||||
"settings.sslprovider.form.zerossl_eab_kid.placeholder": "Please enter EAB KID",
|
"settings.sslprovider.form.zerossl_eab_kid.placeholder": "Please enter EAB KID",
|
||||||
"settings.sslprovider.form.zerossl_eab_kid.tooltip": "For more information, see <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>",
|
"settings.sslprovider.form.zerossl_eab_kid.tooltip": "For more information, see <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>",
|
||||||
"settings.sslprovider.form.zerossl_eab_hmac_key.label": "EAB HMAC Key",
|
"settings.sslprovider.form.zerossl_eab_hmac_key.label": "EAB HMAC key",
|
||||||
"settings.sslprovider.form.zerossl_eab_hmac_key.placeholder": "Please enter EAB HMAC Key",
|
"settings.sslprovider.form.zerossl_eab_hmac_key.placeholder": "Please enter EAB HMAC key",
|
||||||
"settings.sslprovider.form.zerossl_eab_hmac_key.tooltip": "For more information, see <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>",
|
"settings.sslprovider.form.zerossl_eab_hmac_key.tooltip": "For more information, see <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>",
|
||||||
"settings.sslprovider.form.gts_eab_kid.label": "EAB KID",
|
"settings.sslprovider.form.gts_eab_kid.label": "EAB KID",
|
||||||
"settings.sslprovider.form.gts_eab_kid.placeholder": "Please enter EAB KID",
|
"settings.sslprovider.form.gts_eab_kid.placeholder": "Please enter EAB KID",
|
||||||
"settings.sslprovider.form.gts_eab_kid.tooltip": "For more information, see <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
"settings.sslprovider.form.gts_eab_kid.tooltip": "For more information, see <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
||||||
"settings.sslprovider.form.gts_eab_hmac_key.label": "EAB HMAC Key",
|
"settings.sslprovider.form.gts_eab_hmac_key.label": "EAB HMAC key",
|
||||||
"settings.sslprovider.form.gts_eab_hmac_key.placeholder": "Please enter EAB HMAC Key",
|
"settings.sslprovider.form.gts_eab_hmac_key.placeholder": "Please enter EAB HMAC key",
|
||||||
"settings.sslprovider.form.gts_eab_hmac_key.tooltip": "For more information, see <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
"settings.sslprovider.form.gts_eab_hmac_key.tooltip": "For more information, see <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
||||||
|
|
||||||
"settings.persistence.tab": "Persistence",
|
"settings.persistence.tab": "Persistence",
|
||||||
|
@ -14,7 +14,11 @@
|
|||||||
"access.props.name": "名称",
|
"access.props.name": "名称",
|
||||||
"access.props.provider": "提供商",
|
"access.props.provider": "提供商",
|
||||||
"access.props.provider.usage.dns": "DNS 提供商",
|
"access.props.provider.usage.dns": "DNS 提供商",
|
||||||
"access.props.provider.usage.host": "主机提供商",
|
"access.props.provider.usage.hosting": "主机提供商",
|
||||||
|
"access.props.provider.usage.ca": "证书颁发机构",
|
||||||
|
"access.props.provider.usage.notification": "通知渠道",
|
||||||
|
"access.props.ca": "证书颁发机构",
|
||||||
|
"access.props.channel": "通知渠道",
|
||||||
"access.props.created_at": "创建时间",
|
"access.props.created_at": "创建时间",
|
||||||
"access.props.updated_at": "更新时间",
|
"access.props.updated_at": "更新时间",
|
||||||
|
|
||||||
@ -159,6 +163,12 @@
|
|||||||
"access.form.godaddy_api_secret.label": "GoDaddy API Secret",
|
"access.form.godaddy_api_secret.label": "GoDaddy API Secret",
|
||||||
"access.form.godaddy_api_secret.placeholder": "请输入 GoDaddy API Secret",
|
"access.form.godaddy_api_secret.placeholder": "请输入 GoDaddy API Secret",
|
||||||
"access.form.godaddy_api_secret.tooltip": "这是什么?请参阅 <a href=\"https://developer.godaddy.com/\" target=\"_blank\">https://developer.godaddy.com/</a>",
|
"access.form.godaddy_api_secret.tooltip": "这是什么?请参阅 <a href=\"https://developer.godaddy.com/\" target=\"_blank\">https://developer.godaddy.com/</a>",
|
||||||
|
"access.form.googletrustservices_eab_kid.label": "ACME EAB KID",
|
||||||
|
"access.form.googletrustservices_eab_kid.placeholder": "请输入 ACME EAB KID",
|
||||||
|
"access.form.googletrustservices_eab_kid.tooltip": "这是什么?请参阅 <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
||||||
|
"access.form.googletrustservices_eab_hmac_key.label": "ACME EAB HMAC Key",
|
||||||
|
"access.form.googletrustservices_eab_hmac_key.placeholder": "请输入 ACME EAB HMAC Key",
|
||||||
|
"access.form.googletrustservices_eab_hmac_key.tooltip": "这是什么?请参阅 <a href=\"https://cloud.google.com/certificate-manager/docs/public-ca-tutorial\" target=\"_blank\">https://cloud.google.com/certificate-manager/docs/public-ca-tutorial</a>",
|
||||||
"access.form.huaweicloud_access_key_id.label": "华为云 AccessKeyId",
|
"access.form.huaweicloud_access_key_id.label": "华为云 AccessKeyId",
|
||||||
"access.form.huaweicloud_access_key_id.placeholder": "请输入华为云 AccessKeyId",
|
"access.form.huaweicloud_access_key_id.placeholder": "请输入华为云 AccessKeyId",
|
||||||
"access.form.huaweicloud_access_key_id.tooltip": "这是什么?请参阅 <a href=\"https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html\" target=\"_blank\">https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html</a>",
|
"access.form.huaweicloud_access_key_id.tooltip": "这是什么?请参阅 <a href=\"https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html\" target=\"_blank\">https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html</a>",
|
||||||
@ -284,5 +294,11 @@
|
|||||||
"access.form.westcn_username.tooltip": "这是什么?请参阅 <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>",
|
"access.form.westcn_username.tooltip": "这是什么?请参阅 <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>",
|
||||||
"access.form.westcn_api_password.label": "西部数码 API 密码",
|
"access.form.westcn_api_password.label": "西部数码 API 密码",
|
||||||
"access.form.westcn_api_password.placeholder": "请输入西部数码 API 密码",
|
"access.form.westcn_api_password.placeholder": "请输入西部数码 API 密码",
|
||||||
"access.form.westcn_api_password.tooltip": "这是什么?请参阅 <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>"
|
"access.form.westcn_api_password.tooltip": "这是什么?请参阅 <a href=\"https://www.west.cn/CustomerCenter/doc/apiv2.html#12u3001u8eabu4efdu9a8cu8bc10a3ca20id3d12u3001u8eabu4efdu9a8cu8bc13e203ca3e\" target=\"_blank\">https://www.west.cn/CustomerCenter/doc/apiv2.html</a>",
|
||||||
|
"access.form.zerossl_eab_kid.label": "ACME EAB KID",
|
||||||
|
"access.form.zerossl_eab_kid.placeholder": "请输入 ACME EAB KID",
|
||||||
|
"access.form.zerossl_eab_kid.tooltip": "这是什么?请参阅 <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>",
|
||||||
|
"access.form.zerossl_eab_hmac_key.label": "ACME EAB HMAC Key",
|
||||||
|
"access.form.zerossl_eab_hmac_key.placeholder": "请输入 ACME EAB HMAC Key",
|
||||||
|
"access.form.zerossl_eab_hmac_key.tooltip": "这是什么?请参阅 <a href=\"https://zerossl.com/documentation/acme/\" target=\"_blank\">https://zerossl.com/documentation/acme/</a>"
|
||||||
}
|
}
|
||||||
|
@ -61,6 +61,7 @@
|
|||||||
"provider.godaddy": "GoDaddy",
|
"provider.godaddy": "GoDaddy",
|
||||||
"provider.goedge": "GoEdge",
|
"provider.goedge": "GoEdge",
|
||||||
"provider.goedge.cdn": "GoEdge - 内容分发网络 CDN",
|
"provider.goedge.cdn": "GoEdge - 内容分发网络 CDN",
|
||||||
|
"provider.googletrustservices": "Google Trust Services",
|
||||||
"provider.huaweicloud": "华为云",
|
"provider.huaweicloud": "华为云",
|
||||||
"provider.huaweicloud.cdn": "华为云 - 内容分发网络 CDN",
|
"provider.huaweicloud.cdn": "华为云 - 内容分发网络 CDN",
|
||||||
"provider.huaweicloud.dns": "华为云 - 云解析 DNS",
|
"provider.huaweicloud.dns": "华为云 - 云解析 DNS",
|
||||||
@ -75,11 +76,13 @@
|
|||||||
"provider.jdcloud.vod": "京东云 - 视频点播",
|
"provider.jdcloud.vod": "京东云 - 视频点播",
|
||||||
"provider.kubernetes": "Kubernetes",
|
"provider.kubernetes": "Kubernetes",
|
||||||
"provider.kubernetes.secret": "Kubernetes - Secret",
|
"provider.kubernetes.secret": "Kubernetes - Secret",
|
||||||
|
"provider.letsencrypt": "Let's Encrypt",
|
||||||
|
"provider.letsencryptstaging": "Let's Encrypt 测试环境",
|
||||||
"provider.local": "本地部署",
|
"provider.local": "本地部署",
|
||||||
"provider.namecheap": "Namecheap",
|
"provider.namecheap": "Namecheap",
|
||||||
"provider.namedotcom": "Name.com",
|
"provider.namedotcom": "Name.com",
|
||||||
"provider.namesilo": "NameSilo",
|
"provider.namesilo": "NameSilo",
|
||||||
"provider.ns1": "NS1(IBM NS1 Connect)",
|
"provider.ns1": "NS1 (IBM NS1 Connect)",
|
||||||
"provider.porkbun": "Porkbun",
|
"provider.porkbun": "Porkbun",
|
||||||
"provider.powerdns": "PowerDNS",
|
"provider.powerdns": "PowerDNS",
|
||||||
"provider.qiniu": "七牛云",
|
"provider.qiniu": "七牛云",
|
||||||
@ -121,6 +124,7 @@
|
|||||||
"provider.volcengine.tos": "火山引擎 - 对象存储 TOS",
|
"provider.volcengine.tos": "火山引擎 - 对象存储 TOS",
|
||||||
"provider.webhook": "Webhook",
|
"provider.webhook": "Webhook",
|
||||||
"provider.westcn": "西部数码",
|
"provider.westcn": "西部数码",
|
||||||
|
"provider.zerossl": "ZeroSSL",
|
||||||
|
|
||||||
"provider.category.all": "全部",
|
"provider.category.all": "全部",
|
||||||
"provider.category.cdn": "CDN",
|
"provider.category.cdn": "CDN",
|
||||||
|
@ -317,28 +317,28 @@ const SettingsSSLProvider = () => {
|
|||||||
<Form.Item className="mb-2" name="provider" label={t("settings.sslprovider.form.provider.label")}>
|
<Form.Item className="mb-2" name="provider" label={t("settings.sslprovider.form.provider.label")}>
|
||||||
<CheckCard.Group className="w-full" onChange={(value) => setProviderType(value as SSLProviders)}>
|
<CheckCard.Group className="w-full" onChange={(value) => setProviderType(value as SSLProviders)}>
|
||||||
<CheckCard
|
<CheckCard
|
||||||
avatar={<img src={"/imgs/acme/letsencrypt.svg"} className="size-8" />}
|
avatar={<img src={"/imgs/providers/letsencrypt.svg"} className="size-8" />}
|
||||||
size="small"
|
size="small"
|
||||||
title={t("settings.sslprovider.form.provider.option.letsencrypt.label")}
|
title={t("settings.sslprovider.form.provider.option.letsencrypt.label")}
|
||||||
description="letsencrypt.org"
|
description="letsencrypt.org"
|
||||||
value={SSLPROVIDERS.LETS_ENCRYPT}
|
value={SSLPROVIDERS.LETS_ENCRYPT}
|
||||||
/>
|
/>
|
||||||
<CheckCard
|
<CheckCard
|
||||||
avatar={<img src={"/imgs/acme/letsencrypt.svg"} className="size-8" />}
|
avatar={<img src={"/imgs/providers/letsencrypt.svg"} className="size-8" />}
|
||||||
size="small"
|
size="small"
|
||||||
title={t("settings.sslprovider.form.provider.option.letsencrypt_staging.label")}
|
title={t("settings.sslprovider.form.provider.option.letsencrypt_staging.label")}
|
||||||
description="letsencrypt.org"
|
description="letsencrypt.org"
|
||||||
value={SSLPROVIDERS.LETS_ENCRYPT_STAGING}
|
value={SSLPROVIDERS.LETS_ENCRYPT_STAGING}
|
||||||
/>
|
/>
|
||||||
<CheckCard
|
<CheckCard
|
||||||
avatar={<img src={"/imgs/acme/zerossl.svg"} className="size-8" />}
|
avatar={<img src={"/imgs/providers/zerossl.svg"} className="size-8" />}
|
||||||
size="small"
|
size="small"
|
||||||
title={t("settings.sslprovider.form.provider.option.zerossl.label")}
|
title={t("settings.sslprovider.form.provider.option.zerossl.label")}
|
||||||
description="zerossl.com"
|
description="zerossl.com"
|
||||||
value={SSLPROVIDERS.ZERO_SSL}
|
value={SSLPROVIDERS.ZERO_SSL}
|
||||||
/>
|
/>
|
||||||
<CheckCard
|
<CheckCard
|
||||||
avatar={<img src={"/imgs/acme/google.svg"} className="size-8" />}
|
avatar={<img src={"/imgs/providers/google.svg"} className="size-8" />}
|
||||||
size="small"
|
size="small"
|
||||||
title={t("settings.sslprovider.form.provider.option.gts.label")}
|
title={t("settings.sslprovider.form.provider.option.gts.label")}
|
||||||
description="pki.goog"
|
description="pki.goog"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user