2022-01-03 13:55:44 +01:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/araddon/dateparse"
|
|
|
|
)
|
|
|
|
|
|
|
|
func (a *goBlog) initPostsDeleter() {
|
|
|
|
a.hourlyHooks = append(a.hourlyHooks, func() {
|
|
|
|
a.checkDeletedPosts()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *goBlog) checkDeletedPosts() {
|
|
|
|
// Get all posts with `deleted` parameter and a deleted status
|
|
|
|
postsToDelete, err := a.getPosts(&postsRequestConfig{
|
2022-09-23 11:05:07 +02:00
|
|
|
status: []postStatus{statusPublishedDeleted, statusDraftDeleted, statusScheduledDeleted},
|
2022-01-03 13:55:44 +01:00
|
|
|
parameter: "deleted",
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
log.Println("Error getting deleted posts:", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
for _, post := range postsToDelete {
|
|
|
|
// Check if post is deleted for more than 7 days
|
|
|
|
if deleted, err := dateparse.ParseLocal(post.firstParameter("deleted")); err == nil && deleted.Add(time.Hour*24*7).Before(time.Now()) {
|
2022-01-04 10:37:48 +01:00
|
|
|
if err := a.deletePost(post.Path); err != nil {
|
|
|
|
log.Println("Error deleting post:", err)
|
|
|
|
}
|
2022-01-03 13:55:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|