2020-09-20 16:46:25 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2020-10-19 18:25:30 +00:00
|
|
|
"bytes"
|
|
|
|
"html/template"
|
2020-09-20 16:46:25 +00:00
|
|
|
"log"
|
|
|
|
"os/exec"
|
2020-10-18 15:22:24 +00:00
|
|
|
"time"
|
2020-09-20 16:46:25 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func preStartHooks() {
|
|
|
|
for _, cmd := range appConfig.Hooks.PreStart {
|
2020-10-19 18:25:30 +00:00
|
|
|
go func(cmd string) {
|
|
|
|
log.Println("Executing pre-start hook:", cmd)
|
|
|
|
executeCommand(cmd)
|
|
|
|
}(cmd)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-09 15:40:12 +00:00
|
|
|
func (p *post) postPostHooks() {
|
2020-10-19 18:25:30 +00:00
|
|
|
for _, cmdTmplString := range appConfig.Hooks.PostPost {
|
2020-11-09 15:40:12 +00:00
|
|
|
go func(p *post, cmdTmplString string) {
|
|
|
|
executeTemplateCommand("post-post", cmdTmplString, map[string]interface{}{
|
|
|
|
"URL": appConfig.Server.PublicAddress + p.Path,
|
|
|
|
"Post": p,
|
2020-10-19 18:25:30 +00:00
|
|
|
})
|
2020-11-09 15:40:12 +00:00
|
|
|
}(p, cmdTmplString)
|
2020-10-19 18:25:30 +00:00
|
|
|
}
|
2020-11-09 15:40:12 +00:00
|
|
|
go p.apPost()
|
2020-11-09 18:54:06 +00:00
|
|
|
go p.tgPost()
|
2020-11-09 15:40:12 +00:00
|
|
|
go p.sendWebmentions()
|
2020-10-19 18:25:30 +00:00
|
|
|
}
|
|
|
|
|
2020-11-09 15:40:12 +00:00
|
|
|
func (p *post) postUpdateHooks() {
|
|
|
|
for _, cmdTmplString := range appConfig.Hooks.PostUpdate {
|
|
|
|
go func(p *post, cmdTmplString string) {
|
|
|
|
executeTemplateCommand("post-update", cmdTmplString, map[string]interface{}{
|
|
|
|
"URL": appConfig.Server.PublicAddress + p.Path,
|
|
|
|
"Post": p,
|
|
|
|
})
|
|
|
|
}(p, cmdTmplString)
|
|
|
|
}
|
|
|
|
go p.apUpdate()
|
|
|
|
go p.sendWebmentions()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *post) postDeleteHooks() {
|
2020-10-19 18:25:30 +00:00
|
|
|
for _, cmdTmplString := range appConfig.Hooks.PostDelete {
|
2020-11-09 15:40:12 +00:00
|
|
|
go func(p *post, cmdTmplString string) {
|
|
|
|
executeTemplateCommand("post-delete", cmdTmplString, map[string]interface{}{
|
|
|
|
"URL": appConfig.Server.PublicAddress + p.Path,
|
|
|
|
"Post": p,
|
2020-10-19 18:25:30 +00:00
|
|
|
})
|
2020-11-09 15:40:12 +00:00
|
|
|
}(p, cmdTmplString)
|
2020-10-19 18:25:30 +00:00
|
|
|
}
|
2020-11-09 15:40:12 +00:00
|
|
|
go p.apDelete()
|
|
|
|
go p.sendWebmentions()
|
2020-10-19 18:25:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type hookTemplateData struct {
|
|
|
|
URL string
|
|
|
|
}
|
|
|
|
|
2020-11-09 15:40:12 +00:00
|
|
|
func 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-09-20 16:46:25 +00:00
|
|
|
}
|
2020-10-19 18:25:30 +00:00
|
|
|
var cmdBuf bytes.Buffer
|
|
|
|
cmdTmpl.Execute(&cmdBuf, data)
|
|
|
|
cmd := cmdBuf.String()
|
|
|
|
log.Println("Executing "+hookType+" hook:", cmd)
|
|
|
|
executeCommand(cmd)
|
2020-09-20 16:46:25 +00:00
|
|
|
}
|
|
|
|
|
2020-10-18 15:22:24 +00:00
|
|
|
func startHourlyHooks() {
|
|
|
|
for _, cmd := range appConfig.Hooks.Hourly {
|
|
|
|
go func(cmd string) {
|
|
|
|
run := func() {
|
|
|
|
log.Println("Executing hourly hook:", cmd)
|
|
|
|
executeCommand(cmd)
|
|
|
|
}
|
|
|
|
// Execute once
|
2020-10-19 18:25:30 +00:00
|
|
|
go run()
|
2020-10-18 15:22:24 +00:00
|
|
|
// Start ticker and execute regularly
|
|
|
|
ticker := time.NewTicker(1 * time.Hour)
|
|
|
|
for range ticker.C {
|
2020-10-19 18:25:30 +00:00
|
|
|
go run()
|
2020-10-18 15:22:24 +00:00
|
|
|
}
|
|
|
|
}(cmd)
|
2020-09-20 16:46:25 +00:00
|
|
|
}
|
2020-10-18 15:22:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func executeCommand(cmd string) {
|
|
|
|
out, err := exec.Command(appConfig.Hooks.Shell, "-c", cmd).CombinedOutput()
|
|
|
|
if err != nil {
|
|
|
|
log.Println("Failed to execute command:", err.Error())
|
2020-09-20 16:46:25 +00:00
|
|
|
}
|
2020-10-18 15:22:24 +00:00
|
|
|
log.Println("Output:")
|
|
|
|
log.Print(string(out))
|
2020-09-20 16:46:25 +00:00
|
|
|
}
|