Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
caddy
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
caddy
Commits
e99b3af0
Commit
e99b3af0
authored
Oct 30, 2015
by
Matthew Holt
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
letsencrypt: Numerous bug fixes
parent
88c646c8
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
99 additions
and
77 deletions
+99
-77
caddy/caddy.go
caddy/caddy.go
+1
-1
caddy/caddyfile/json_test.go
caddy/caddyfile/json_test.go
+1
-1
caddy/config.go
caddy/config.go
+5
-4
caddy/letsencrypt/letsencrypt.go
caddy/letsencrypt/letsencrypt.go
+87
-66
caddy/letsencrypt/maintain.go
caddy/letsencrypt/maintain.go
+4
-4
main.go
main.go
+1
-1
No files found.
caddy/caddy.go
View file @
e99b3af0
...
@@ -276,7 +276,7 @@ func Wait() {
...
@@ -276,7 +276,7 @@ func Wait() {
// the Caddyfile. If loader does not return a Caddyfile, the
// the Caddyfile. If loader does not return a Caddyfile, the
// default one will be returned. Thus, if there are no other
// default one will be returned. Thus, if there are no other
// errors, this function always returns at least the default
// errors, this function always returns at least the default
// Caddyfile.
// Caddyfile
(not the previously-used Caddyfile)
.
func
LoadCaddyfile
(
loader
func
()
(
Input
,
error
))
(
cdyfile
Input
,
err
error
)
{
func
LoadCaddyfile
(
loader
func
()
(
Input
,
error
))
(
cdyfile
Input
,
err
error
)
{
// If we are a fork, finishing the restart is highest priority;
// If we are a fork, finishing the restart is highest priority;
// piped input is required in this case.
// piped input is required in this case.
...
...
caddy/caddyfile/json_test.go
View file @
e99b3af0
...
@@ -62,7 +62,7 @@ baz"
...
@@ -62,7 +62,7 @@ baz"
{
// 8
{
// 8
caddyfile
:
`http://host, https://host {
caddyfile
:
`http://host, https://host {
}`
,
}`
,
json
:
`[{"hosts":["host:http","host:https"],"body":{}}]`
,
// hosts in JSON are always host:port format (if port is specified)
json
:
`[{"hosts":["host:http","host:https"],"body":{}}]`
,
// hosts in JSON are always host:port format (if port is specified)
, for consistency
},
},
}
}
...
...
caddy/config.go
View file @
e99b3af0
...
@@ -89,10 +89,6 @@ func load(filename string, input io.Reader) ([]server.Config, error) {
...
@@ -89,10 +89,6 @@ func load(filename string, input io.Reader) ([]server.Config, error) {
}
}
}
}
if
config
.
Port
==
""
{
config
.
Port
=
Port
}
configs
=
append
(
configs
,
config
)
configs
=
append
(
configs
,
config
)
}
}
}
}
...
@@ -145,6 +141,11 @@ func arrangeBindings(allConfigs []server.Config) (Group, error) {
...
@@ -145,6 +141,11 @@ func arrangeBindings(allConfigs []server.Config) (Group, error) {
// Group configs by bind address
// Group configs by bind address
for
_
,
conf
:=
range
allConfigs
{
for
_
,
conf
:=
range
allConfigs
{
// use default port if none is specified
if
conf
.
Port
==
""
{
conf
.
Port
=
Port
}
bindAddr
,
warnErr
,
fatalErr
:=
resolveAddr
(
conf
)
bindAddr
,
warnErr
,
fatalErr
:=
resolveAddr
(
conf
)
if
fatalErr
!=
nil
{
if
fatalErr
!=
nil
{
return
groupings
,
fatalErr
return
groupings
,
fatalErr
...
...
caddy/letsencrypt/letsencrypt.go
View file @
e99b3af0
This diff is collapsed.
Click to expand it.
caddy/letsencrypt/maintain.go
View file @
e99b3af0
...
@@ -25,7 +25,7 @@ var OnChange func() error
...
@@ -25,7 +25,7 @@ var OnChange func() error
//
//
// You must pass in the server configs to maintain and the channel
// You must pass in the server configs to maintain and the channel
// which you'll close when maintenance should stop, to allow this
// which you'll close when maintenance should stop, to allow this
// goroutine to clean up after itself.
// goroutine to clean up after itself
and unblock
.
func
maintainAssets
(
configs
[]
server
.
Config
,
stopChan
chan
struct
{})
{
func
maintainAssets
(
configs
[]
server
.
Config
,
stopChan
chan
struct
{})
{
renewalTicker
:=
time
.
NewTicker
(
renewInterval
)
renewalTicker
:=
time
.
NewTicker
(
renewInterval
)
ocspTicker
:=
time
.
NewTicker
(
ocspInterval
)
ocspTicker
:=
time
.
NewTicker
(
ocspInterval
)
...
@@ -66,7 +66,7 @@ func maintainAssets(configs []server.Config, stopChan chan struct{}) {
...
@@ -66,7 +66,7 @@ func maintainAssets(configs []server.Config, stopChan chan struct{}) {
// renewCertificates loops through all configured site and
// renewCertificates loops through all configured site and
// looks for certificates to renew. Nothing is mutated
// looks for certificates to renew. Nothing is mutated
// through this function
. The
changes happen directly on disk.
// through this function
; all
changes happen directly on disk.
// It returns the number of certificates renewed and any errors
// It returns the number of certificates renewed and any errors
// that occurred. It only performs a renewal if necessary.
// that occurred. It only performs a renewal if necessary.
func
renewCertificates
(
configs
[]
server
.
Config
)
(
int
,
[]
error
)
{
func
renewCertificates
(
configs
[]
server
.
Config
)
(
int
,
[]
error
)
{
...
@@ -75,7 +75,7 @@ func renewCertificates(configs []server.Config) (int, []error) {
...
@@ -75,7 +75,7 @@ func renewCertificates(configs []server.Config) (int, []error) {
var
n
int
var
n
int
for
_
,
cfg
:=
range
configs
{
for
_
,
cfg
:=
range
configs
{
// Host must be TLS-enabled and have assets managed by LE
// Host must be TLS-enabled and have
existing
assets managed by LE
if
!
cfg
.
TLS
.
Enabled
||
!
existingCertAndKey
(
cfg
.
Host
)
{
if
!
cfg
.
TLS
.
Enabled
||
!
existingCertAndKey
(
cfg
.
Host
)
{
continue
continue
}
}
...
@@ -100,7 +100,7 @@ func renewCertificates(configs []server.Config) (int, []error) {
...
@@ -100,7 +100,7 @@ func renewCertificates(configs []server.Config) (int, []error) {
// Renew with a week or less remaining.
// Renew with a week or less remaining.
if
daysLeft
<=
7
{
if
daysLeft
<=
7
{
log
.
Printf
(
"[INFO] There are %d days left on the certificate of %s. Trying to renew now."
,
daysLeft
,
cfg
.
Host
)
log
.
Printf
(
"[INFO] There are %d days left on the certificate of %s. Trying to renew now."
,
daysLeft
,
cfg
.
Host
)
client
,
err
:=
newClient
(
getEmail
(
cfg
))
client
,
err
:=
newClient
(
""
)
// email not used for renewal
if
err
!=
nil
{
if
err
!=
nil
{
errs
=
append
(
errs
,
err
)
errs
=
append
(
errs
,
err
)
continue
continue
...
...
main.go
View file @
e99b3af0
...
@@ -41,7 +41,7 @@ func init() {
...
@@ -41,7 +41,7 @@ func init() {
// TODO: Production endpoint is: https://acme-v01.api.letsencrypt.org
// TODO: Production endpoint is: https://acme-v01.api.letsencrypt.org
flag
.
StringVar
(
&
letsencrypt
.
CAUrl
,
"ca"
,
"https://acme-staging.api.letsencrypt.org"
,
"Certificate authority ACME server"
)
flag
.
StringVar
(
&
letsencrypt
.
CAUrl
,
"ca"
,
"https://acme-staging.api.letsencrypt.org"
,
"Certificate authority ACME server"
)
flag
.
BoolVar
(
&
letsencrypt
.
Agreed
,
"agree"
,
false
,
"Agree to Let's Encrypt Subscriber Agreement"
)
flag
.
BoolVar
(
&
letsencrypt
.
Agreed
,
"agree"
,
false
,
"Agree to Let's Encrypt Subscriber Agreement"
)
flag
.
StringVar
(
&
letsencrypt
.
DefaultEmail
,
"email"
,
""
,
"Default
email address to use for Let's Encrypt transaction
s"
)
flag
.
StringVar
(
&
letsencrypt
.
DefaultEmail
,
"email"
,
""
,
"Default
Let's Encrypt account email addres
s"
)
flag
.
StringVar
(
&
revoke
,
"revoke"
,
""
,
"Hostname for which to revoke the certificate"
)
flag
.
StringVar
(
&
revoke
,
"revoke"
,
""
,
"Hostname for which to revoke the certificate"
)
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment