tls_acme.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package option
  2. import (
  3. "github.com/sagernet/sing-box/common/json"
  4. C "github.com/sagernet/sing-box/constant"
  5. E "github.com/sagernet/sing/common/exceptions"
  6. )
  7. type InboundACMEOptions struct {
  8. Domain Listable[string] `json:"domain,omitempty"`
  9. DataDirectory string `json:"data_directory,omitempty"`
  10. DefaultServerName string `json:"default_server_name,omitempty"`
  11. Email string `json:"email,omitempty"`
  12. Provider string `json:"provider,omitempty"`
  13. DisableHTTPChallenge bool `json:"disable_http_challenge,omitempty"`
  14. DisableTLSALPNChallenge bool `json:"disable_tls_alpn_challenge,omitempty"`
  15. AlternativeHTTPPort uint16 `json:"alternative_http_port,omitempty"`
  16. AlternativeTLSPort uint16 `json:"alternative_tls_port,omitempty"`
  17. ExternalAccount *ACMEExternalAccountOptions `json:"external_account,omitempty"`
  18. DNS01Challenge *ACMEDNS01ChallengeOptions `json:"dns01_challenge,omitempty"`
  19. }
  20. type ACMEExternalAccountOptions struct {
  21. KeyID string `json:"key_id,omitempty"`
  22. MACKey string `json:"mac_key,omitempty"`
  23. }
  24. type _ACMEDNS01ChallengeOptions struct {
  25. Provider string `json:"provider,omitempty"`
  26. AliDNSOptions ACMEDNS01AliDNSOptions `json:"-"`
  27. CloudflareOptions ACMEDNS01CloudflareOptions `json:"-"`
  28. }
  29. type ACMEDNS01ChallengeOptions _ACMEDNS01ChallengeOptions
  30. func (o ACMEDNS01ChallengeOptions) MarshalJSON() ([]byte, error) {
  31. var v any
  32. switch o.Provider {
  33. case C.DNSProviderAliDNS:
  34. v = o.AliDNSOptions
  35. case C.DNSProviderCloudflare:
  36. v = o.CloudflareOptions
  37. default:
  38. return nil, E.New("unknown provider type: " + o.Provider)
  39. }
  40. return MarshallObjects((_ACMEDNS01ChallengeOptions)(o), v)
  41. }
  42. func (o *ACMEDNS01ChallengeOptions) UnmarshalJSON(bytes []byte) error {
  43. err := json.Unmarshal(bytes, (*_ACMEDNS01ChallengeOptions)(o))
  44. if err != nil {
  45. return err
  46. }
  47. var v any
  48. switch o.Provider {
  49. case C.DNSProviderAliDNS:
  50. v = &o.AliDNSOptions
  51. case C.DNSProviderCloudflare:
  52. v = &o.CloudflareOptions
  53. default:
  54. return E.New("unknown provider type: " + o.Provider)
  55. }
  56. err = UnmarshallExcluded(bytes, (*_ACMEDNS01ChallengeOptions)(o), v)
  57. if err != nil {
  58. return E.Cause(err, "DNS01 challenge options")
  59. }
  60. return nil
  61. }
  62. type ACMEDNS01AliDNSOptions struct {
  63. AccessKeyID string `json:"access_key_id,omitempty"`
  64. AccessKeySecret string `json:"access_key_secret,omitempty"`
  65. RegionID string `json:"region_id,omitempty"`
  66. }
  67. type ACMEDNS01CloudflareOptions struct {
  68. APIToken string `json:"api_token,omitempty"`
  69. }