mirror of
https://github.com/eiblog/eiblog.git
synced 2026-03-01 00:34:58 +08:00
fix: feed & sitemap not generate
This commit is contained in:
@@ -25,79 +25,8 @@ func startTimer() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
logrus.Error("startTimer.generateCrossdomain: ", err)
|
logrus.Error("startTimer.generateCrossdomain: ", err)
|
||||||
}
|
}
|
||||||
|
// 定时刷新
|
||||||
ticker := time.NewTicker(time.Hour)
|
refreshFeedAndSitemap()
|
||||||
for now := range ticker.C {
|
|
||||||
// generate feed & sitemap
|
|
||||||
if now.Hour()%4 == 0 {
|
|
||||||
err = generateFeed()
|
|
||||||
if err != nil {
|
|
||||||
logrus.Error("startTimer.generateFeed: ", err)
|
|
||||||
}
|
|
||||||
err = generateSitemap()
|
|
||||||
if err != nil {
|
|
||||||
logrus.Error("startTimer.generateSitemap: ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// clean expired articles
|
|
||||||
exp := now.Add(-48 * time.Hour)
|
|
||||||
err := Store.CleanArticles(context.Background(), exp)
|
|
||||||
if err != nil {
|
|
||||||
logrus.Error("startTimer.CleanArticles: ", err)
|
|
||||||
}
|
|
||||||
// fetch disqus count
|
|
||||||
if now.Hour()%5 == 0 {
|
|
||||||
err = DisqusClient.PostsCount(Ei.ArticlesMap)
|
|
||||||
if err != nil {
|
|
||||||
logrus.Error("startTimer.PostsCount: ", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// generateFeed 定时刷新feed
|
|
||||||
func generateFeed() error {
|
|
||||||
tpl := XMLTemplate.Lookup("feedTpl.xml")
|
|
||||||
if tpl == nil {
|
|
||||||
return errors.New("not found: feedTpl.xml")
|
|
||||||
}
|
|
||||||
|
|
||||||
_, _, articles := Ei.PageArticleFE(1, 20)
|
|
||||||
params := map[string]interface{}{
|
|
||||||
"Title": Ei.Blogger.BTitle,
|
|
||||||
"SubTitle": Ei.Blogger.SubTitle,
|
|
||||||
"Host": config.Conf.Host,
|
|
||||||
"FeedrURL": config.Conf.FeedRPC.FeedrURL,
|
|
||||||
"BuildDate": time.Now().Format(time.RFC1123Z),
|
|
||||||
"Articles": articles,
|
|
||||||
}
|
|
||||||
path := filepath.Join(config.EtcDir, "assets", "feed.xml")
|
|
||||||
f, err := os.OpenFile(path, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0666)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
defer f.Close()
|
|
||||||
return tpl.Execute(f, params)
|
|
||||||
}
|
|
||||||
|
|
||||||
// generateSitemap 定时刷新sitemap
|
|
||||||
func generateSitemap() error {
|
|
||||||
tpl := XMLTemplate.Lookup("sitemapTpl.xml")
|
|
||||||
if tpl == nil {
|
|
||||||
return errors.New("not found: sitemapTpl.xml")
|
|
||||||
}
|
|
||||||
|
|
||||||
params := map[string]interface{}{
|
|
||||||
"Articles": Ei.Articles,
|
|
||||||
"Host": config.Conf.Host,
|
|
||||||
}
|
|
||||||
path := filepath.Join(config.EtcDir, "assets", "sitemap.xml")
|
|
||||||
f, err := os.OpenFile(path, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0666)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
defer f.Close()
|
|
||||||
return tpl.Execute(f, params)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// generateOpensearch 生成opensearch.xml
|
// generateOpensearch 生成opensearch.xml
|
||||||
@@ -158,3 +87,79 @@ func generateCrossdomain() error {
|
|||||||
defer f.Close()
|
defer f.Close()
|
||||||
return tpl.Execute(f, params)
|
return tpl.Execute(f, params)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// refreshFeedAndSitemap 定时刷新feed和sitemap
|
||||||
|
func refreshFeedAndSitemap() {
|
||||||
|
defer time.AfterFunc(time.Hour, refreshFeedAndSitemap)
|
||||||
|
|
||||||
|
now := time.Now()
|
||||||
|
// generate feed & sitemap
|
||||||
|
if now.Hour()%4 == 0 {
|
||||||
|
err := generateFeed()
|
||||||
|
if err != nil {
|
||||||
|
logrus.Error("startTimer.generateFeed: ", err)
|
||||||
|
}
|
||||||
|
err = generateSitemap()
|
||||||
|
if err != nil {
|
||||||
|
logrus.Error("startTimer.generateSitemap: ", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// clean expired articles
|
||||||
|
exp := now.Add(-48 * time.Hour)
|
||||||
|
err := Store.CleanArticles(context.Background(), exp)
|
||||||
|
if err != nil {
|
||||||
|
logrus.Error("startTimer.CleanArticles: ", err)
|
||||||
|
}
|
||||||
|
// fetch disqus count
|
||||||
|
if now.Hour()%5 == 0 {
|
||||||
|
err = DisqusClient.PostsCount(Ei.ArticlesMap)
|
||||||
|
if err != nil {
|
||||||
|
logrus.Error("startTimer.PostsCount: ", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// generateFeed 定时刷新feed
|
||||||
|
func generateFeed() error {
|
||||||
|
tpl := XMLTemplate.Lookup("feedTpl.xml")
|
||||||
|
if tpl == nil {
|
||||||
|
return errors.New("not found: feedTpl.xml")
|
||||||
|
}
|
||||||
|
|
||||||
|
_, _, articles := Ei.PageArticleFE(1, 20)
|
||||||
|
params := map[string]interface{}{
|
||||||
|
"Title": Ei.Blogger.BTitle,
|
||||||
|
"SubTitle": Ei.Blogger.SubTitle,
|
||||||
|
"Host": config.Conf.Host,
|
||||||
|
"FeedrURL": config.Conf.FeedRPC.FeedrURL,
|
||||||
|
"BuildDate": time.Now().Format(time.RFC1123Z),
|
||||||
|
"Articles": articles,
|
||||||
|
}
|
||||||
|
path := filepath.Join(config.EtcDir, "assets", "feed.xml")
|
||||||
|
f, err := os.OpenFile(path, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0666)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
return tpl.Execute(f, params)
|
||||||
|
}
|
||||||
|
|
||||||
|
// generateSitemap 定时刷新sitemap
|
||||||
|
func generateSitemap() error {
|
||||||
|
tpl := XMLTemplate.Lookup("sitemapTpl.xml")
|
||||||
|
if tpl == nil {
|
||||||
|
return errors.New("not found: sitemapTpl.xml")
|
||||||
|
}
|
||||||
|
|
||||||
|
params := map[string]interface{}{
|
||||||
|
"Articles": Ei.Articles,
|
||||||
|
"Host": config.Conf.Host,
|
||||||
|
}
|
||||||
|
path := filepath.Join(config.EtcDir, "assets", "sitemap.xml")
|
||||||
|
f, err := os.OpenFile(path, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0666)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
return tpl.Execute(f, params)
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user