pages: some fixups

This commit is contained in:
Leon Mika 2025-02-18 21:26:24 +11:00
parent 68aa9c0e13
commit 295811411e
7 changed files with 64 additions and 39 deletions

View file

@ -10,6 +10,7 @@ type Config struct {
NetlifyAuthToken string `env:"NETLIFY_AUTH_TOKEN"`
DataDir string `env:"DATA_DIR"`
EncryptedCookieKey string `env:"ENCRYPTED_COOKIE_KEY"`
BaseURL string `env:"BASE_URL,default=http://localhost:3000/"`
DataStagingDir string `env:"DATA_STAGING_DIR,default=staging"`
DataScratchDir string `env:"DATA_SCRATCH_DIR,default=scratch"`

View file

@ -72,7 +72,7 @@ func main() {
return
}
hugoProvider, err := hugo.New(cfg.StagingDir(), cfg.PreviewDir(), cfg.ScratchDir())
hugoProvider, err := hugo.New(cfg.StagingDir(), cfg.BaseURL, cfg.PreviewDir(), cfg.ScratchDir())
if err != nil {
log.Fatal(err)
}

View file

@ -2,10 +2,10 @@ package hugo
import (
"context"
"fmt"
"gopkg.in/yaml.v3"
"lmika.dev/lmika/hugo-cms/models"
"log"
"net/url"
"os"
"os/exec"
"path/filepath"
@ -14,12 +14,19 @@ import (
type Provider struct {
stagingDir string
previewDir string
previewBaseURL *url.URL
scratchDir string
}
func New(stagingDir, previewDir, scratchDir string) (*Provider, error) {
func New(stagingDir, previewBaseURL, previewDir, scratchDir string) (*Provider, error) {
baseURL, err := url.Parse(previewBaseURL)
if err != nil {
return nil, err
}
return &Provider{
stagingDir: stagingDir,
previewBaseURL: baseURL,
previewDir: previewDir,
scratchDir: scratchDir,
}, nil
@ -51,8 +58,12 @@ func (p *Provider) NewSite(ctx context.Context, site models.Site) error {
}
func (p *Provider) PreviewSite(ctx context.Context, site models.Site) (outDir string, err error) {
previewURL, err := p.previewBaseURL.Parse("preview/" + site.Name)
if err != nil {
return "", err
}
previewTarget := models.PublishTarget{
URL: fmt.Sprintf("http://localhost:3000/preview/%s", site.Name),
URL: previewURL.String(),
}
return p.publishSiteAt(ctx, p.previewDir, site, previewTarget, "hugoPreview.yaml")
@ -80,6 +91,7 @@ func (p *Provider) publishSiteAt(ctx context.Context, dir string, site models.Si
cmd := exec.CommandContext(ctx, "hugo",
"--source", baseSiteDir,
"--destination", outDir,
"--quiet",
"--config", filepath.Join(baseSiteDir, configFile),
"--baseURL", target.URL)
cmd.Stderr = os.Stderr
@ -91,12 +103,11 @@ func (p *Provider) publishSiteAt(ctx context.Context, dir string, site models.Si
return outDir, nil
}
func (p *Provider) ReconfigureSite(ctx context.Context, configBase string, site models.Site) error {
func (p *Provider) ReconfigureSite(ctx context.Context, isPreviewConfig bool, configBase string, site models.Site) error {
hugoCfg := hugoConfig{
Title: site.Title,
LanguageCode: "en",
Theme: site.Theme,
CanonifyURLs: configBase == "hugoPreview",
Markup: hugoConfigMarkup{
Goldmark: hugoGoldmarkConfig{
Renderer: hugoGoldmarkRendererConfig{
@ -106,6 +117,10 @@ func (p *Provider) ReconfigureSite(ctx context.Context, configBase string, site
},
}
if isPreviewConfig {
hugoCfg.CanonifyURLs = true
}
ymlBytes, err := yaml.Marshal(hugoCfg)
if err != nil {
return err

View file

@ -172,11 +172,11 @@ func (s *Service) createSite(ctx context.Context, site models.Site) error {
return err
}
if err := s.hugo.ReconfigureSite(ctx, "hugo", site); err != nil {
if err := s.hugo.ReconfigureSite(ctx, false, "hugo", site); err != nil {
return err
}
if err := s.hugo.ReconfigureSite(ctx, "hugoPreview", site); err != nil {
if err := s.hugo.ReconfigureSite(ctx, true, "hugoPreview", site); err != nil {
return err
}

View file

@ -61,6 +61,7 @@ func (s *Service) SaveSettings(ctx context.Context, site models.Site, newSetting
return err
}
if newSettings.TargetRef != "" && newSettings.TargetURL != "" {
pubTarget, err := s.db.GetPublishTargetBySiteRole(ctx, newSite.ID, models.TargetRoleProduction)
if err == nil {
pubTarget.TargetRef = newSettings.TargetRef
@ -82,6 +83,7 @@ func (s *Service) SaveSettings(ctx context.Context, site models.Site, newSetting
} else {
return err
}
}
return s.jobs.Queue(ctx, s.sb.RebuildSite(site, newSite))
}

View file

@ -3,6 +3,10 @@ CREATE TYPE post_state AS ENUM (
'published'
);
CREATE TYPE post_format AS ENUM (
'markdown'
);
CREATE TYPE target_role AS ENUM (
'production'
);
@ -53,6 +57,7 @@ CREATE TABLE posts (
site_id BIGINT NOT NULL,
title TEXT,
post_type_id BIGINT,
format post_format NOT NULL DEFAULT 'markdown',
body TEXT NOT NULL,
state post_state NOT NULL,
props JSON NOT NULL,
@ -80,6 +85,7 @@ CREATE TABLE pages (
bundle_id BIGINT NOT NULL,
name TEXT NOT NULL,
name_provenance page_name_provenance NOT NULL,
format post_format NOT NULL DEFAULT 'markdown',
title TEXT,
post_type_id BIGINT,
body TEXT NOT NULL,

View file

@ -14,6 +14,7 @@
<h1>Hugo CMS</h1>
<nav>
<span>{{.site.Title}}</span>
<a href="/preview/{{.site.Name}}" target="_blank">Preview</a>
{{ if .prodTarget }}
<a href="{{.prodTarget.URL}}" target="_blank">Visit</a>
{{ end }}