GoBlog/hooks.go

128 lines
3.0 KiB
Go
Raw Normal View History

package main
import (
2020-10-19 18:25:30 +00:00
"bytes"
"html/template"
"log"
"os/exec"
"time"
)
func (a *goBlog) preStartHooks() {
for _, cmd := range a.cfg.Hooks.PreStart {
2020-11-17 15:39:16 +00:00
func(cmd string) {
2020-10-19 18:25:30 +00:00
log.Println("Executing pre-start hook:", cmd)
a.cfg.Hooks.executeCommand(cmd)
2020-10-19 18:25:30 +00:00
}(cmd)
}
}
2021-05-24 10:54:43 +00:00
type postHookFunc func(*post)
2020-11-17 21:10:13 +00:00
func (a *goBlog) postPostHooks(p *post) {
2021-01-15 20:56:46 +00:00
// Hooks after post published
for _, cmdTmplString := range a.cfg.Hooks.PostPost {
go func(p *post, cmdTmplString string) {
a.cfg.Hooks.executeTemplateCommand("post-post", cmdTmplString, map[string]interface{}{
"URL": a.fullPostURL(p),
"Post": p,
2020-10-19 18:25:30 +00:00
})
}(p, cmdTmplString)
2020-10-19 18:25:30 +00:00
}
for _, f := range a.pPostHooks {
2020-11-17 21:10:13 +00:00
go f(p)
2020-11-11 17:37:17 +00:00
}
2020-10-19 18:25:30 +00:00
}
func (a *goBlog) postUpdateHooks(p *post) {
2021-01-15 20:56:46 +00:00
// Hooks after post updated
for _, cmdTmplString := range a.cfg.Hooks.PostUpdate {
go func(p *post, cmdTmplString string) {
a.cfg.Hooks.executeTemplateCommand("post-update", cmdTmplString, map[string]interface{}{
"URL": a.fullPostURL(p),
"Post": p,
})
}(p, cmdTmplString)
}
for _, f := range a.pUpdateHooks {
2020-11-17 21:10:13 +00:00
go f(p)
2020-11-11 17:37:17 +00:00
}
}
func (a *goBlog) postDeleteHooks(p *post) {
for _, cmdTmplString := range a.cfg.Hooks.PostDelete {
go func(p *post, cmdTmplString string) {
a.cfg.Hooks.executeTemplateCommand("post-delete", cmdTmplString, map[string]interface{}{
"URL": a.fullPostURL(p),
"Post": p,
2020-10-19 18:25:30 +00:00
})
}(p, cmdTmplString)
2020-10-19 18:25:30 +00:00
}
for _, f := range a.pDeleteHooks {
2020-11-17 21:10:13 +00:00
go f(p)
}
2020-10-19 18:25:30 +00:00
}
func (cfg *configHooks) executeTemplateCommand(hookType string, tmpl string, data map[string]interface{}) {
2020-10-19 18:25:30 +00:00
cmdTmpl, err := template.New("cmd").Parse(tmpl)
if err != nil {
log.Println("Failed to parse cmd template:", err.Error())
return
}
2020-10-19 18:25:30 +00:00
var cmdBuf bytes.Buffer
2021-02-08 17:51:07 +00:00
if err = cmdTmpl.Execute(&cmdBuf, data); err != nil {
log.Println("Failed to execute cmd template:", err.Error())
return
}
2020-10-19 18:25:30 +00:00
cmd := cmdBuf.String()
log.Println("Executing "+hookType+" hook:", cmd)
cfg.executeCommand(cmd)
}
2021-03-26 08:33:46 +00:00
var hourlyHooks = []func(){}
func (a *goBlog) startHourlyHooks() {
2021-03-26 08:33:46 +00:00
// Add configured hourly hooks
for _, cmd := range a.cfg.Hooks.Hourly {
2021-03-26 08:33:46 +00:00
c := cmd
f := func() {
log.Println("Executing hourly hook:", c)
a.cfg.Hooks.executeCommand(c)
2021-03-26 08:33:46 +00:00
}
hourlyHooks = append(hourlyHooks, f)
}
// Calculate waiting time for first exec
2021-01-30 17:54:05 +00:00
n := time.Now()
f := time.Date(n.Year(), n.Month(), n.Day(), n.Hour(), 0, 0, 0, n.Location()).Add(time.Hour)
w := f.Sub(n)
2021-03-26 08:33:46 +00:00
// When there are hooks, start ticker
if len(hourlyHooks) > 0 {
go func() {
2021-01-30 17:54:05 +00:00
// Wait for next hour to begin
time.Sleep(w)
// Execute once
2021-03-26 08:33:46 +00:00
for _, f := range hourlyHooks {
go f()
}
// Start ticker and execute regularly
ticker := time.NewTicker(1 * time.Hour)
for range ticker.C {
2021-03-26 08:33:46 +00:00
for _, f := range hourlyHooks {
go f()
}
}
2021-03-26 08:33:46 +00:00
}()
}
}
func (cfg *configHooks) executeCommand(cmd string) {
out, err := exec.Command(cfg.Shell, "-c", cmd).CombinedOutput()
if err != nil {
log.Println("Failed to execute command:", err.Error())
}
if len(out) > 0 {
log.Println("Output:")
log.Print(string(out))
}
}