mirror of
https://github.com/eiblog/eiblog.git
synced 2026-02-23 06:32:28 +08:00
fixed #6,发布文章异步提交,随机 session key等
This commit is contained in:
34
api.go
34
api.go
@@ -231,12 +231,15 @@ func apiPostAdd(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
cid = int(artc.ID)
|
cid = int(artc.ID)
|
||||||
if !artc.IsDraft {
|
if !artc.IsDraft {
|
||||||
// elastic
|
// 异步执行,快
|
||||||
ElasticIndex(artc)
|
go func() {
|
||||||
// rss
|
// elastic
|
||||||
DoPings(slug)
|
ElasticIndex(artc)
|
||||||
// disqus
|
// rss
|
||||||
ThreadCreate(artc)
|
DoPings(slug)
|
||||||
|
// disqus
|
||||||
|
ThreadCreate(artc)
|
||||||
|
}()
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -260,14 +263,17 @@ func apiPostAdd(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
if !artc.IsDraft {
|
if !artc.IsDraft {
|
||||||
ReplaceArticle(a, artc)
|
ReplaceArticle(a, artc)
|
||||||
// elastic
|
// 异步执行,快
|
||||||
ElasticIndex(artc)
|
go func() {
|
||||||
// rss
|
// elastic
|
||||||
DoPings(slug)
|
ElasticIndex(artc)
|
||||||
// disqus
|
// rss
|
||||||
if a == nil {
|
DoPings(slug)
|
||||||
ThreadCreate(artc)
|
// disqus
|
||||||
}
|
if a == nil {
|
||||||
|
ThreadCreate(artc)
|
||||||
|
}
|
||||||
|
}()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
50
db.go
50
db.go
@@ -75,9 +75,9 @@ func init() {
|
|||||||
logd.Fatal(err)
|
logd.Fatal(err)
|
||||||
}
|
}
|
||||||
// 读取帐号信息
|
// 读取帐号信息
|
||||||
Ei = loadAccount()
|
loadAccount()
|
||||||
// 获取文章数据
|
// 获取文章数据
|
||||||
Ei.Articles = loadArticles()
|
loadArticles()
|
||||||
// 生成markdown文档
|
// 生成markdown文档
|
||||||
go generateMarkdown()
|
go generateMarkdown()
|
||||||
// 启动定时器
|
// 启动定时器
|
||||||
@@ -87,12 +87,13 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 读取或初始化帐号信息
|
// 读取或初始化帐号信息
|
||||||
func loadAccount() (a *Account) {
|
func loadAccount() {
|
||||||
a = &Account{}
|
Ei = &Account{}
|
||||||
err := mgo.FindOne(DB, COLLECTION_ACCOUNT, mgo.M{"username": setting.Conf.Account.Username}, a)
|
err := mgo.FindOne(DB, COLLECTION_ACCOUNT, mgo.M{"username": setting.Conf.Account.Username}, Ei)
|
||||||
// 初始化用户数据
|
// 初始化用户数据
|
||||||
if err == mgo.ErrNotFound {
|
if err == mgo.ErrNotFound {
|
||||||
a = &Account{
|
logd.Printf("Initializing account: %s\n", setting.Conf.Account.Username)
|
||||||
|
Ei = &Account{
|
||||||
Username: setting.Conf.Account.Username,
|
Username: setting.Conf.Account.Username,
|
||||||
Password: EncryptPasswd(setting.Conf.Account.Username, setting.Conf.Account.Password),
|
Password: EncryptPasswd(setting.Conf.Account.Username, setting.Conf.Account.Password),
|
||||||
Email: setting.Conf.Account.Email,
|
Email: setting.Conf.Account.Email,
|
||||||
@@ -100,29 +101,28 @@ func loadAccount() (a *Account) {
|
|||||||
Address: setting.Conf.Account.Address,
|
Address: setting.Conf.Account.Address,
|
||||||
CreateTime: time.Now(),
|
CreateTime: time.Now(),
|
||||||
}
|
}
|
||||||
a.BlogName = setting.Conf.Blogger.BlogName
|
Ei.BlogName = setting.Conf.Blogger.BlogName
|
||||||
a.SubTitle = setting.Conf.Blogger.SubTitle
|
Ei.SubTitle = setting.Conf.Blogger.SubTitle
|
||||||
a.BeiAn = setting.Conf.Blogger.BeiAn
|
Ei.BeiAn = setting.Conf.Blogger.BeiAn
|
||||||
a.BTitle = setting.Conf.Blogger.BTitle
|
Ei.BTitle = setting.Conf.Blogger.BTitle
|
||||||
a.Copyright = setting.Conf.Blogger.Copyright
|
Ei.Copyright = setting.Conf.Blogger.Copyright
|
||||||
err = mgo.Insert(DB, COLLECTION_ACCOUNT, a)
|
err = mgo.Insert(DB, COLLECTION_ACCOUNT, Ei)
|
||||||
generateTopic()
|
generateTopic()
|
||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
logd.Fatal(err)
|
logd.Fatal(err)
|
||||||
}
|
}
|
||||||
a.CH = make(chan string, 2)
|
Ei.CH = make(chan string, 2)
|
||||||
a.MapArticles = make(map[string]*Article)
|
Ei.MapArticles = make(map[string]*Article)
|
||||||
a.Tags = make(map[string]SortArticles)
|
Ei.Tags = make(map[string]SortArticles)
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadArticles() (artcs SortArticles) {
|
func loadArticles() {
|
||||||
err := mgo.FindAll(DB, COLLECTION_ARTICLE, mgo.M{"isdraft": false, "deletetime": mgo.M{"$eq": time.Time{}}}, &artcs)
|
err := mgo.FindAll(DB, COLLECTION_ARTICLE, mgo.M{"isdraft": false, "deletetime": mgo.M{"$eq": time.Time{}}}, &Ei.Articles)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logd.Fatal(err)
|
logd.Fatal(err)
|
||||||
}
|
}
|
||||||
sort.Sort(artcs)
|
sort.Sort(Ei.Articles)
|
||||||
for i, v := range artcs {
|
for i, v := range Ei.Articles {
|
||||||
// 渲染文章
|
// 渲染文章
|
||||||
GenerateExcerptAndRender(v)
|
GenerateExcerptAndRender(v)
|
||||||
Ei.MapArticles[v.Slug] = v
|
Ei.MapArticles[v.Slug] = v
|
||||||
@@ -131,16 +131,15 @@ func loadArticles() (artcs SortArticles) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if i > 0 {
|
if i > 0 {
|
||||||
v.Prev = artcs[i-1]
|
v.Prev = Ei.Articles[i-1]
|
||||||
}
|
}
|
||||||
if artcs[i+1].ID >= setting.Conf.General.StartID {
|
if Ei.Articles[i+1].ID >= setting.Conf.General.StartID {
|
||||||
v.Next = artcs[i+1]
|
v.Next = Ei.Articles[i+1]
|
||||||
}
|
}
|
||||||
upArticle(v, false)
|
upArticle(v, false)
|
||||||
}
|
}
|
||||||
Ei.CH <- SERIES_MD
|
Ei.CH <- SERIES_MD
|
||||||
Ei.CH <- ARCHIVE_MD
|
Ei.CH <- ARCHIVE_MD
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// generate series,archive markdown
|
// generate series,archive markdown
|
||||||
@@ -209,6 +208,9 @@ func generateTopic() {
|
|||||||
CreateTime: time.Time{},
|
CreateTime: time.Time{},
|
||||||
UpdateTime: time.Time{},
|
UpdateTime: time.Time{},
|
||||||
}
|
}
|
||||||
|
// 推送到 disqus
|
||||||
|
go func() { ThreadCreate(about) }()
|
||||||
|
|
||||||
blogroll := &Article{
|
blogroll := &Article{
|
||||||
ID: mgo.NextVal(DB, COUNTER_ARTICLE),
|
ID: mgo.NextVal(DB, COUNTER_ARTICLE),
|
||||||
Author: setting.Conf.Account.Username,
|
Author: setting.Conf.Account.Username,
|
||||||
|
|||||||
@@ -6,8 +6,6 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- /data/eiblog/mgodb:/data/db
|
- /data/eiblog/mgodb:/data/db
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
|
||||||
- 27017:27017
|
|
||||||
elasticsearch:
|
elasticsearch:
|
||||||
image: elasticsearch:2.4.1
|
image: elasticsearch:2.4.1
|
||||||
container_name: eisearch
|
container_name: eisearch
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"regexp"
|
"regexp"
|
||||||
"strings"
|
"strings"
|
||||||
@@ -23,10 +24,20 @@ const (
|
|||||||
ES_DATE = `{"range":{"date":{"gte":"%s","lte": "%s","format": "yyyy-MM-dd||yyyy-MM||yyyy"}}}` // 2016-10||/M
|
ES_DATE = `{"range":{"date":{"gte":"%s","lte": "%s","format": "yyyy-MM-dd||yyyy-MM||yyyy"}}}` // 2016-10||/M
|
||||||
)
|
)
|
||||||
|
|
||||||
var es *ElasticService
|
var (
|
||||||
|
ErrUninitializedES = errors.New("uninitialized elasticsearch")
|
||||||
|
|
||||||
|
es *ElasticService
|
||||||
|
)
|
||||||
|
|
||||||
// 初始化 Elasticsearch 服务器
|
// 初始化 Elasticsearch 服务器
|
||||||
func init() {
|
func init() {
|
||||||
|
_, err := net.LookupIP("elasticsearch")
|
||||||
|
if err != nil {
|
||||||
|
logd.Info(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
es = &ElasticService{url: "http://elasticsearch:9200", c: new(http.Client)}
|
es = &ElasticService{url: "http://elasticsearch:9200", c: new(http.Client)}
|
||||||
initIndex()
|
initIndex()
|
||||||
}
|
}
|
||||||
@@ -41,7 +52,11 @@ func initIndex() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 查询
|
// 查询
|
||||||
func Elasticsearch(qStr string, size, from int) *ESSearchResult {
|
func Elasticsearch(qStr string, size, from int) (*ESSearchResult, error) {
|
||||||
|
if es == nil {
|
||||||
|
return nil, ErrUninitializedES
|
||||||
|
}
|
||||||
|
|
||||||
// 分析查询字符串
|
// 分析查询字符串
|
||||||
reg := regexp.MustCompile(`(tag|slug|date):`)
|
reg := regexp.MustCompile(`(tag|slug|date):`)
|
||||||
indexs := reg.FindAllStringIndex(qStr, -1)
|
indexs := reg.FindAllStringIndex(qStr, -1)
|
||||||
@@ -92,14 +107,17 @@ func Elasticsearch(qStr string, size, from int) *ESSearchResult {
|
|||||||
}
|
}
|
||||||
docs, err := IndexQueryDSL(INDEX, TYPE, size, from, []byte(dsl))
|
docs, err := IndexQueryDSL(INDEX, TYPE, size, from, []byte(dsl))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logd.Error(err)
|
return nil, err
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
return docs
|
return docs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// 添加或更新索引
|
// 添加或更新索引
|
||||||
func ElasticIndex(artc *Article) error {
|
func ElasticIndex(artc *Article) error {
|
||||||
|
if es == nil {
|
||||||
|
return ErrUninitializedES
|
||||||
|
}
|
||||||
|
|
||||||
img := PickFirstImage(artc.Content)
|
img := PickFirstImage(artc.Content)
|
||||||
mapping := map[string]interface{}{
|
mapping := map[string]interface{}{
|
||||||
"title": artc.Title,
|
"title": artc.Title,
|
||||||
@@ -115,6 +133,10 @@ func ElasticIndex(artc *Article) error {
|
|||||||
|
|
||||||
// 删除索引
|
// 删除索引
|
||||||
func ElasticDelIndex(ids []int32) error {
|
func ElasticDelIndex(ids []int32) error {
|
||||||
|
if es == nil {
|
||||||
|
return ErrUninitializedES
|
||||||
|
}
|
||||||
|
|
||||||
var target []string
|
var target []string
|
||||||
for _, id := range ids {
|
for _, id := range ids {
|
||||||
target = append(target, fmt.Sprint(id))
|
target = append(target, fmt.Sprint(id))
|
||||||
|
|||||||
8
front.go
8
front.go
@@ -199,10 +199,12 @@ func HandleSearchPage(c *gin.Context) {
|
|||||||
start = 1
|
start = 1
|
||||||
}
|
}
|
||||||
h["Word"] = q
|
h["Word"] = q
|
||||||
var result *ESSearchResult
|
|
||||||
vals := c.Request.URL.Query()
|
vals := c.Request.URL.Query()
|
||||||
result = Elasticsearch(q, setting.Conf.General.PageNum, start-1)
|
result, err := Elasticsearch(q, setting.Conf.General.PageNum, start-1)
|
||||||
if result != nil {
|
if err != nil {
|
||||||
|
logd.Error(err)
|
||||||
|
} else {
|
||||||
result.Took /= 1000
|
result.Took /= 1000
|
||||||
for i, v := range result.Hits.Hits {
|
for i, v := range result.Hits.Hits {
|
||||||
if artc := Ei.MapArticles[result.Hits.Hits[i].Source.Slug]; len(v.Highlight.Content) == 0 && artc != nil {
|
if artc := Ei.MapArticles[result.Hits.Hits[i].Source.Slug]; len(v.Highlight.Content) == 0 && artc != nil {
|
||||||
|
|||||||
10
router.go
10
router.go
@@ -2,6 +2,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/rand"
|
||||||
"fmt"
|
"fmt"
|
||||||
"text/template"
|
"text/template"
|
||||||
"time"
|
"time"
|
||||||
@@ -27,7 +28,12 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
router = gin.Default()
|
router = gin.Default()
|
||||||
store := sessions.NewCookieStore([]byte("eiblog321"))
|
b := make([]byte, 16)
|
||||||
|
_, err := rand.Read(b)
|
||||||
|
if err != nil {
|
||||||
|
logd.Fatal(err)
|
||||||
|
}
|
||||||
|
store := sessions.NewCookieStore(b)
|
||||||
store.Options(sessions.Options{
|
store.Options(sessions.Options{
|
||||||
MaxAge: 86400 * 7,
|
MaxAge: 86400 * 7,
|
||||||
Path: "/",
|
Path: "/",
|
||||||
@@ -43,7 +49,7 @@ func init() {
|
|||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
})
|
})
|
||||||
_, err := Tmpl.ParseFiles(files...)
|
_, err = Tmpl.ParseFiles(files...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logd.Fatal(err)
|
logd.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user