aboutsummaryrefslogtreecommitdiff
path: root/cmd
diff options
context:
space:
mode:
authorDimitri Sokolyuk <demon@dim13.org>2016-01-08 10:22:05 +0100
committerDimitri Sokolyuk <demon@dim13.org>2016-01-08 10:22:05 +0100
commitaf05fe47b225a9aaf922f965bf0e25672fdd907d (patch)
tree484acbf883d27783ebbaf35b33d6213366237d1e /cmd
parenta893ae16a82829628953911a2cff954df835618b (diff)
Add webroot solver
Diffstat (limited to 'cmd')
-rw-r--r--cmd/acme/solve_http.go8
-rw-r--r--cmd/acme/solve_webroot.go28
2 files changed, 35 insertions, 1 deletions
diff --git a/cmd/acme/solve_http.go b/cmd/acme/solve_http.go
index 24e9555..39efb4e 100644
--- a/cmd/acme/solve_http.go
+++ b/cmd/acme/solve_http.go
@@ -1,5 +1,11 @@
package main
-func Solve(token string) error {
+import "net/http"
+
+type httpChallenge struct {
+ http.Server
+}
+
+func (c *httpChallenge) Solve(token, keyAuth string) error {
return nil
}
diff --git a/cmd/acme/solve_webroot.go b/cmd/acme/solve_webroot.go
new file mode 100644
index 0000000..4d62f64
--- /dev/null
+++ b/cmd/acme/solve_webroot.go
@@ -0,0 +1,28 @@
+package main
+
+import (
+ "os"
+ "path"
+
+ "dim13.org/acme"
+)
+
+type webrootChallenge struct {
+ Webroot string
+ file string
+}
+
+func (c *webrootChallenge) Solve(token, keyAuth string) error {
+ c.file = path.Join(c.Webroot, acme.WellKnown, token)
+ fd, err := acme.CreatePubFile(c.file)
+ if err != nil {
+ return err
+ }
+ defer fd.Close()
+ _, err := fd.WriteString(keyAuth)
+ return err
+}
+
+func (c *webrootChallenge) Finish() error {
+ return os.Remove(c.file)
+}