updates on #71

pull/78/head
Henrique Dias 2016-06-07 16:08:52 +01:00
parent 5953045264
commit 8ed78288a7
4 changed files with 39 additions and 27 deletions

View File

@ -5,7 +5,8 @@ import (
"path/filepath" "path/filepath"
"strings" "strings"
"github.com/mholt/caddy/caddy/setup" "github.com/hacdias/caddy-hugo/tools/installer"
"github.com/mholt/caddy"
) )
// Config is the add-on configuration set on Caddyfile // Config is the add-on configuration set on Caddyfile
@ -19,16 +20,16 @@ type Config struct {
Git bool // Is this site a git repository Git bool // Is this site a git repository
} }
// ParseHugo parses the configuration file // Parse parses the configuration file
func ParseHugo(c *setup.Controller) (*Config, error) { func Parse(c *caddy.Controller, root string) (*Config, error) {
conf := &Config{ conf := &Config{
Public: strings.Replace(c.Root, "./", "", -1), Public: strings.Replace(root, "./", "", -1),
Admin: "/admin", Admin: "/admin",
Path: "./", Path: "./",
Git: false, Git: false,
} }
conf.Hugo = GetPath() conf.Hugo = installer.GetPath()
for c.Next() { for c.Next() {
args := c.RemainingArgs() args := c.RemainingArgs()

45
hugo.go
View File

@ -23,50 +23,61 @@ import (
"github.com/hacdias/caddy-hugo/tools/commands" "github.com/hacdias/caddy-hugo/tools/commands"
"github.com/hacdias/caddy-hugo/tools/hugo" "github.com/hacdias/caddy-hugo/tools/hugo"
"github.com/hacdias/caddy-hugo/tools/server" "github.com/hacdias/caddy-hugo/tools/server"
"github.com/mholt/caddy/caddy/setup" "github.com/mholt/caddy"
"github.com/mholt/caddy/middleware" "github.com/mholt/caddy/caddyhttp/httpserver"
) )
func init() {
caddy.RegisterPlugin("hugo", caddy.Plugin{
ServerType: "http",
Action: setup,
})
}
// Setup is the init function of Caddy plugins and it configures the whole // Setup is the init function of Caddy plugins and it configures the whole
// middleware thing. // middleware thing.
func Setup(c *setup.Controller) (middleware.Middleware, error) { func setup(c *caddy.Controller) error {
config, _ := config.ParseHugo(c) cnf := httpserver.GetConfig(c.Key)
conf, _ := config.Parse(c, cnf.Root)
// Checks if there is an Hugo website in the path that is provided. // Checks if there is an Hugo website in the path that is provided.
// If not, a new website will be created. // If not, a new website will be created.
create := true create := true
if _, err := os.Stat(config.Path + "config.yaml"); err == nil { if _, err := os.Stat(conf.Path + "config.yaml"); err == nil {
create = false create = false
} }
if _, err := os.Stat(config.Path + "config.json"); err == nil { if _, err := os.Stat(conf.Path + "config.json"); err == nil {
create = false create = false
} }
if _, err := os.Stat(config.Path + "config.toml"); err == nil { if _, err := os.Stat(conf.Path + "config.toml"); err == nil {
create = false create = false
} }
if create { if create {
err := commands.Run(config.Hugo, []string{"new", "site", config.Path, "--force"}, ".") err := commands.Run(conf.Hugo, []string{"new", "site", conf.Path, "--force"}, ".")
if err != nil { if err != nil {
log.Panic(err) log.Panic(err)
} }
} }
// Generates the Hugo website for the first time the plugin is activated. // Generates the Hugo website for the first time the plugin is activated.
go hugo.Run(config, true) go hugo.Run(conf, true)
return func(next middleware.Handler) middleware.Handler { mid := func(next httpserver.Handler) httpserver.Handler {
return &CaddyHugo{Next: next, Config: config} return CaddyHugo{Next: next, Config: conf}
}, nil }
cnf.AddMiddleware(mid)
return nil
} }
// CaddyHugo contais the next middleware to be run and the configuration // CaddyHugo contais the next middleware to be run and the configuration
// of the current one. // of the current one.
type CaddyHugo struct { type CaddyHugo struct {
Next middleware.Handler Next httpserver.Handler
Config *config.Config Config *config.Config
} }
@ -74,7 +85,7 @@ type CaddyHugo struct {
// request to its function. // request to its function.
func (h CaddyHugo) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) { func (h CaddyHugo) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
// Only handle /{admin} path // Only handle /{admin} path
if middleware.Path(r.URL.Path).Matches(h.Config.Admin) { if httpserver.Path(r.URL.Path).Matches(h.Config.Admin) {
var err error var err error
var page string var page string
code := 404 code := 404
@ -108,15 +119,15 @@ func (h CaddyHugo) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error
if r.URL.Path == h.Config.Admin+"/settings/" { if r.URL.Path == h.Config.Admin+"/settings/" {
var frontmatter string var frontmatter string
if _, err := os.Stat(h.Config.Path + "config.yaml"); err == nil { if _, err = os.Stat(h.Config.Path + "config.yaml"); err == nil {
frontmatter = "yaml" frontmatter = "yaml"
} }
if _, err := os.Stat(h.Config.Path + "config.json"); err == nil { if _, err = os.Stat(h.Config.Path + "config.json"); err == nil {
frontmatter = "json" frontmatter = "json"
} }
if _, err := os.Stat(h.Config.Path + "config.toml"); err == nil { if _, err = os.Stat(h.Config.Path + "config.toml"); err == nil {
frontmatter = "toml" frontmatter = "toml"
} }

View File

@ -6,8 +6,8 @@ import (
"github.com/hacdias/caddy-hugo/tools/templates" "github.com/hacdias/caddy-hugo/tools/templates"
"github.com/hacdias/caddy-hugo/tools/variables" "github.com/hacdias/caddy-hugo/tools/variables"
"github.com/mholt/caddy/middleware" "github.com/mholt/caddy/caddyhttp/browse"
"github.com/mholt/caddy/middleware/browse" "github.com/mholt/caddy/caddyhttp/httpserver"
) )
// GET handles the GET method on browse page and shows the files listing Using // GET handles the GET method on browse page and shows the files listing Using
@ -26,7 +26,7 @@ func GET(w http.ResponseWriter, r *http.Request) (int, error) {
// Using Caddy's Browse middleware // Using Caddy's Browse middleware
b := browse.Browse{ b := browse.Browse{
Next: middleware.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) { Next: httpserver.HandlerFunc(func(w http.ResponseWriter, r *http.Request) (int, error) {
return 404, nil return 404, nil
}), }),
Configs: []browse.Config{ Configs: []browse.Config{

View File

@ -1,4 +1,4 @@
package config package installer
import ( import (
"crypto/sha256" "crypto/sha256"