parent
e750a4c1bd
commit
eea77cc97c
3 changed files with 65 additions and 1 deletions
|
@ -17,7 +17,7 @@ signing operations are done online. Authenticated denial of existence is impleme
|
||||||
lies. Using ECDSA as an algorithm is preferred as this leads to smaller signatures (compared to
|
lies. Using ECDSA as an algorithm is preferred as this leads to smaller signatures (compared to
|
||||||
RSA). NSEC3 is *not* supported.
|
RSA). NSEC3 is *not* supported.
|
||||||
|
|
||||||
A signing key can be specified by using the `key` directive.
|
A single signing key can be specified by using the `key` directive.
|
||||||
|
|
||||||
NOTE: Key generation has not been implemented yet.
|
NOTE: Key generation has not been implemented yet.
|
||||||
|
|
||||||
|
|
45
middleware/fs.go
Normal file
45
middleware/fs.go
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
package middleware
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"runtime"
|
||||||
|
)
|
||||||
|
|
||||||
|
// dir wraps http.Dir that restrict file access to a specific directory tree.
|
||||||
|
type dir http.Dir
|
||||||
|
|
||||||
|
// CoreDir is the directory where middleware can store assets, like zone files after a zone transfer
|
||||||
|
// or public and private keys or anything else a middleware might need. The convention is to place
|
||||||
|
// assets in a subdirectory named after the fully qualified zone.
|
||||||
|
//
|
||||||
|
// example.org./Kexample<something>.key
|
||||||
|
//
|
||||||
|
// CoreDir will default to "$HOME/.coredns" on Unix, but it's location can be overriden with the COREDNSPATH
|
||||||
|
// environment variable.
|
||||||
|
var CoreDir dir = dir(fsPath())
|
||||||
|
|
||||||
|
// fsPath returns the path to the directory where the application may store data.
|
||||||
|
// If COREDNSPATH env variable. is set, that value is used. Otherwise, the path is
|
||||||
|
// the result of evaluating "$HOME/.coredns".
|
||||||
|
func fsPath() string {
|
||||||
|
if corePath := os.Getenv("COREDNSPATH"); corePath != "" {
|
||||||
|
return corePath
|
||||||
|
}
|
||||||
|
return filepath.Join(userHomeDir(), ".coredns")
|
||||||
|
}
|
||||||
|
|
||||||
|
// userHomeDir returns the user's home directory according to environment variables.
|
||||||
|
//
|
||||||
|
// Credit: http://stackoverflow.com/a/7922977/1048862
|
||||||
|
func userHomeDir() string {
|
||||||
|
if runtime.GOOS == "windows" {
|
||||||
|
home := os.Getenv("HOMEDRIVE") + os.Getenv("HOMEPATH")
|
||||||
|
if home == "" {
|
||||||
|
home = os.Getenv("USERPROFILE")
|
||||||
|
}
|
||||||
|
return home
|
||||||
|
}
|
||||||
|
return os.Getenv("HOME")
|
||||||
|
}
|
19
middleware/fs_test.go
Normal file
19
middleware/fs_test.go
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
package middleware
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestfsPath(t *testing.T) {
|
||||||
|
if actual := fsPath(); !strings.HasSuffix(actual, ".coredns") {
|
||||||
|
t.Errorf("Expected path to be a .coredns folder, got: %v", actual)
|
||||||
|
}
|
||||||
|
|
||||||
|
os.Setenv("COREDNSPATH", "testpath")
|
||||||
|
defer os.Setenv("COREDNSPATH", "")
|
||||||
|
if actual, expected := fsPath(), "testpath"; actual != expected {
|
||||||
|
t.Errorf("Expected path to be %v, got: %v", expected, actual)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue