mirror of
https://github.com/caddyserver/caddy.git
synced 2025-05-28 06:40:01 +08:00
Initial commit of Storage, TLS, and automatic HTTPS implementations
This commit is contained in:
74
storage.go
Normal file
74
storage.go
Normal file
@ -0,0 +1,74 @@
|
||||
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{}
|
Reference in New Issue
Block a user