all repos — website @ cd1125a213d742b5a89e8b60f0c7aafef13b8783

My website

fetch and build site on server start

Alan Pearce
commit

cd1125a213d742b5a89e8b60f0c7aafef13b8783

parent

83a4eef89b9906d8ad90411e9b256da6dab07b55

1 file changed, 40 insertions(+), 12 deletions(-)

changed files
M internal/server/server.gointernal/server/server.go
@@ -6,14 +6,17 @@ "fmt"
"net" "net/http" "net/url" + "os" "slices" "time" "website/internal/builder" cfg "website/internal/config" "website/internal/log" + "website/internal/vcs" "website/internal/website" + "github.com/ardanlabs/conf/v3" "github.com/osdevisnot/sorvor/pkg/livereload" "github.com/pkg/errors" "golang.org/x/net/http2"
@@ -72,8 +75,34 @@ wrappedHandler.ServeHTTP(w, r)
}) } +func rebuild(builderConfig builder.IOConfig, config *cfg.Config) error { + r, err := builder.BuildSite(builderConfig) + if err != nil { + return errors.WithMessage(err, "could not build site") + } + updateCSPHashes(config, r) + + return nil +} + func New(runtimeConfig *Config) (*Server, error) { - var err error + if !runtimeConfig.Development { + vcsConfig := &vcs.Config{} + _, err := conf.Parse("", vcsConfig) + if err != nil { + return nil, err + } + _, err = vcs.CloneOrUpdate(vcsConfig) + if err != nil { + return nil, err + } + err = os.Chdir(vcsConfig.LocalPath) + if err != nil { + return nil, err + } + runtimeConfig.Root = "website" + } + config, err := cfg.GetConfig() if err != nil { return nil, errors.WithMessage(err, "error parsing configuration file")
@@ -90,11 +119,7 @@ Destination: runtimeConfig.Root,
BaseURL: config.BaseURL, Development: true, } - r, err := builder.BuildSite(builderConfig) - if err != nil { - return nil, errors.WithMessage(err, "could not build site") - } - updateCSPHashes(config, r) + rebuild(builderConfig, config) liveReload := livereload.New() top.Handle("/_/reload", liveReload)
@@ -118,13 +143,16 @@ if err != nil {
return nil, errors.WithMessage(err, "could not add directory to file watcher") } go fw.Start(func(filename string) { - r, err := builder.BuildSite(builderConfig) - if err != nil { - log.Error("could not build site", "error", err) - } - updateCSPHashes(config, r) - liveReload.Reload() + rebuild(builderConfig, config) }) + } else { + builderConfig := builder.IOConfig{ + Source: "content", + Destination: runtimeConfig.Root, + BaseURL: config.BaseURL, + Development: false, + } + rebuild(builderConfig, config) } loggingMux := http.NewServeMux()