Fix acme.json file automatic creation

This commit is contained in:
NicoMen 2018-04-10 10:52:04 +02:00 committed by Traefiker Bot
parent b1be062437
commit 3be74bb275
16 changed files with 61 additions and 38 deletions

View file

@ -46,9 +46,9 @@ type ACME struct {
OnHostRule bool `description:"Enable certificate generation on frontends Host rules."` OnHostRule bool `description:"Enable certificate generation on frontends Host rules."`
CAServer string `description:"CA server to use."` CAServer string `description:"CA server to use."`
EntryPoint string `description:"Entrypoint to proxy acme challenge to."` EntryPoint string `description:"Entrypoint to proxy acme challenge to."`
DNSChallenge *acmeprovider.DNSChallenge `description:"Activate DNS-01 Challenge"` DNSChallenge *acmeprovider.DNSChallenge `description:"Activate DNS-02 Challenge"`
HTTPChallenge *acmeprovider.HTTPChallenge `description:"Activate HTTP-01 Challenge"` HTTPChallenge *acmeprovider.HTTPChallenge `description:"Activate HTTP-01 Challenge"`
DNSProvider string `description:"Activate DNS-01 Challenge (Deprecated)"` // deprecated DNSProvider string `description:"Activate DNS-02 Challenge (Deprecated)"` // deprecated
DelayDontCheckDNS flaeg.Duration `description:"Assume DNS propagates after a delay in seconds rather than finding and querying nameservers."` // deprecated DelayDontCheckDNS flaeg.Duration `description:"Assume DNS propagates after a delay in seconds rather than finding and querying nameservers."` // deprecated
ACMELogging bool `description:"Enable debug logging of ACME actions."` ACMELogging bool `description:"Enable debug logging of ACME actions."`
client *acme.Client client *acme.Client

View file

@ -26,7 +26,7 @@ func NewLocalStore(file string) *LocalStore {
func (s *LocalStore) Get() (*Account, error) { func (s *LocalStore) Get() (*Account, error) {
account := &Account{} account := &Account{}
hasData, err := checkFile(s.file) hasData, err := acme.CheckFile(s.file)
if err != nil { if err != nil {
return nil, err return nil, err
} }

View file

@ -195,6 +195,8 @@ func (s *AcmeSuite) retrieveAcmeCertificate(c *check.C, testCase AcmeTestCase) {
err := cmd.Start() err := cmd.Start()
c.Assert(err, checker.IsNil) c.Assert(err, checker.IsNil)
defer cmd.Process.Kill() defer cmd.Process.Kill()
// A real file is needed to have the right mode on acme.json file
defer os.Remove("/tmp/acme.json")
backend := startTestServer("9010", http.StatusOK) backend := startTestServer("9010", http.StatusOK)
defer backend.Close() defer backend.Close()

View file

@ -12,7 +12,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}

View file

@ -11,7 +11,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}

View file

@ -14,7 +14,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}

View file

@ -12,7 +12,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}

View file

@ -14,7 +14,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onHostRule = true onHostRule = true
caServer = "http://{{.BoulderHost}}:4001/directory" caServer = "http://{{.BoulderHost}}:4001/directory"

View file

@ -14,7 +14,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onHostRule = true onHostRule = true
caServer = "http://wrongurl:4001/directory" caServer = "http://wrongurl:4001/directory"

View file

@ -12,7 +12,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}

View file

@ -12,7 +12,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = false onDemand = false
onHostRule = false onHostRule = false

View file

@ -12,7 +12,7 @@ defaultEntryPoints = ["http", "https"]
[acme] [acme]
email = "test@traefik.io" email = "test@traefik.io"
storage = "/dev/null" storage = "/tmp/acme.json"
entryPoint = "https" entryPoint = "https"
onDemand = {{.OnDemand}} onDemand = {{.OnDemand}}
onHostRule = {{.OnHostRule}} onHostRule = {{.OnHostRule}}

View file

@ -16,7 +16,7 @@ var _ Store = (*LocalStore)(nil)
type LocalStore struct { type LocalStore struct {
filename string filename string
storedData *StoredData storedData *StoredData
SaveDataChan chan *StoredData SaveDataChan chan *StoredData `json:"-"`
} }
// NewLocalStore initializes a new LocalStore with a file name // NewLocalStore initializes a new LocalStore with a file name
@ -30,6 +30,12 @@ func (s *LocalStore) get() (*StoredData, error) {
if s.storedData == nil { if s.storedData == nil {
s.storedData = &StoredData{HTTPChallenges: make(map[string]map[string][]byte)} s.storedData = &StoredData{HTTPChallenges: make(map[string]map[string][]byte)}
hasData, err := CheckFile(s.filename)
if err != nil {
return nil, err
}
if hasData {
f, err := os.Open(s.filename) f, err := os.Open(s.filename)
if err != nil { if err != nil {
return nil, err return nil, err
@ -58,6 +64,7 @@ func (s *LocalStore) get() (*StoredData, error) {
} }
} }
} }
}
return s.storedData, nil return s.storedData, nil
} }

View file

@ -7,10 +7,17 @@ import (
"os" "os"
) )
// Check file permissions and content size // CheckFile checks file permissions and content size
func checkFile(name string) (bool, error) { func CheckFile(name string) (bool, error) {
f, err := os.Open(name) f, err := os.Open(name)
if err != nil { if err != nil {
if os.IsNotExist(err) {
f, err = os.Create(name)
if err != nil {
return false, err
}
return false, f.Chmod(0600)
}
return false, err return false, err
} }
defer f.Close() defer f.Close()

View file

@ -2,11 +2,18 @@ package acme
import "os" import "os"
// Check file content size // CheckFile checks file content size
// Do not check file permissions on Windows right now // Do not check file permissions on Windows right now
func checkFile(name string) (bool, error) { func CheckFile(name string) (bool, error) {
f, err := os.Open(name) f, err := os.Open(name)
if err != nil { if err != nil {
if os.IsNotExist(err) {
f, err = os.Create(name)
if err != nil {
return false, err
}
return false, f.Chmod(0600)
}
return false, err return false, err
} }
defer f.Close() defer f.Close()

View file

@ -42,7 +42,7 @@ type Configuration struct {
EntryPoint string `description:"EntryPoint to use."` EntryPoint string `description:"EntryPoint to use."`
OnHostRule bool `description:"Enable certificate generation on frontends Host rules."` OnHostRule bool `description:"Enable certificate generation on frontends Host rules."`
OnDemand bool `description:"Enable on demand certificate generation. This will request a certificate from Let's Encrypt during the first TLS handshake for a hostname that does not yet have a certificate."` //deprecated OnDemand bool `description:"Enable on demand certificate generation. This will request a certificate from Let's Encrypt during the first TLS handshake for a hostname that does not yet have a certificate."` //deprecated
DNSChallenge *DNSChallenge `description:"Activate DNS-01 Challenge"` DNSChallenge *DNSChallenge `description:"Activate DNS-02 Challenge"`
HTTPChallenge *HTTPChallenge `description:"Activate HTTP-01 Challenge"` HTTPChallenge *HTTPChallenge `description:"Activate HTTP-01 Challenge"`
Domains []types.Domain `description:"CN and SANs (alternative domains) to each main domain using format: --acme.domains='main.com,san1.com,san2.com' --acme.domains='*.main.net'. No SANs for wildcards domain. Wildcard domains only accepted with DNSChallenge"` Domains []types.Domain `description:"CN and SANs (alternative domains) to each main domain using format: --acme.domains='main.com,san1.com,san2.com' --acme.domains='*.main.net'. No SANs for wildcards domain. Wildcard domains only accepted with DNSChallenge"`
} }
@ -72,7 +72,7 @@ type Certificate struct {
// DNSChallenge contains DNS challenge Configuration // DNSChallenge contains DNS challenge Configuration
type DNSChallenge struct { type DNSChallenge struct {
Provider string `description:"Use a DNS-01 based challenge provider rather than HTTPS."` Provider string `description:"Use a DNS-02 based challenge provider rather than HTTPS."`
DelayBeforeCheck flaeg.Duration `description:"Assume DNS propagates after a delay in seconds rather than finding and querying nameservers."` DelayBeforeCheck flaeg.Duration `description:"Assume DNS propagates after a delay in seconds rather than finding and querying nameservers."`
} }
@ -116,7 +116,7 @@ func (p *Provider) init() error {
p.certificates, err = p.Store.GetCertificates() p.certificates, err = p.Store.GetCertificates()
if err != nil { if err != nil {
return fmt.Errorf("unable to get ACME account : %v", err) return fmt.Errorf("unable to get ACME certificates : %v", err)
} }
p.watchCertificate() p.watchCertificate()