mirror of https://github.com/caddyserver/caddy.git
75 lines
2.0 KiB
Go
75 lines
2.0 KiB
Go
|
package caddy2
|
||
|
|
||
|
import (
|
||
|
"os"
|
||
|
"path/filepath"
|
||
|
"runtime"
|
||
|
|
||
|
"github.com/mholt/certmagic"
|
||
|
)
|
||
|
|
||
|
func init() {
|
||
|
RegisterModule(Module{
|
||
|
Name: "caddy.storage.file_system",
|
||
|
New: func() (interface{}, error) { return new(fileStorage), nil },
|
||
|
})
|
||
|
}
|
||
|
|
||
|
// StorageConverter is a type that can convert itself
|
||
|
// to a valid, usable certmagic.Storage value. The
|
||
|
// value might be short-lived.
|
||
|
type StorageConverter interface {
|
||
|
CertMagicStorage() (certmagic.Storage, error)
|
||
|
}
|
||
|
|
||
|
// TODO: Wrappers other than file_system should be enterprise-only.
|
||
|
|
||
|
// It may seem trivial to wrap these, but the benefits are:
|
||
|
// 1. We don't need to change the actual CertMagic storage implementions
|
||
|
// to a structure that is operable with Caddy's config (including JSON
|
||
|
// tags), and
|
||
|
// 2. We don't need to rely on rely on maintainers of third-party
|
||
|
// certmagic.Storage implementations. We can make any certmagic.Storage
|
||
|
// work with Caddy this way.
|
||
|
|
||
|
// fileStorage is a certmagic.Storage wrapper for certmagic.FileStorage.
|
||
|
type fileStorage struct {
|
||
|
Root string `json:"root"`
|
||
|
}
|
||
|
|
||
|
func (s fileStorage) CertMagicStorage() (certmagic.Storage, error) {
|
||
|
return &certmagic.FileStorage{Path: s.Root}, nil
|
||
|
}
|
||
|
|
||
|
// homeDir returns the best guess of the current user's home
|
||
|
// directory from environment variables. If unknown, "." (the
|
||
|
// current directory) is returned instead.
|
||
|
func homeDir() string {
|
||
|
home := os.Getenv("HOME")
|
||
|
if home == "" && runtime.GOOS == "windows" {
|
||
|
drive := os.Getenv("HOMEDRIVE")
|
||
|
path := os.Getenv("HOMEPATH")
|
||
|
home = drive + path
|
||
|
if drive == "" || path == "" {
|
||
|
home = os.Getenv("USERPROFILE")
|
||
|
}
|
||
|
}
|
||
|
if home == "" {
|
||
|
home = "."
|
||
|
}
|
||
|
return home
|
||
|
}
|
||
|
|
||
|
// dataDir returns a directory path that is suitable for storage.
|
||
|
// https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html#variables
|
||
|
func dataDir() string {
|
||
|
baseDir := filepath.Join(homeDir(), ".local", "share")
|
||
|
if xdgData := os.Getenv("XDG_DATA_HOME"); xdgData != "" {
|
||
|
baseDir = xdgData
|
||
|
}
|
||
|
return filepath.Join(baseDir, "caddy")
|
||
|
}
|
||
|
|
||
|
// Interface guard
|
||
|
var _ StorageConverter = fileStorage{}
|