Compare commits
3 Commits
2808530540
...
7aa6471696
| Author | SHA1 | Date | |
|---|---|---|---|
| 7aa6471696 | |||
| 309b034180 | |||
| 35d8d0d8d8 |
|
|
@ -13,6 +13,7 @@ import (
|
|||
"os"
|
||||
"strconv"
|
||||
"strings"
|
||||
"sync"
|
||||
"time"
|
||||
)
|
||||
|
||||
|
|
@ -43,8 +44,11 @@ type Stat struct {
|
|||
}
|
||||
|
||||
type subscriptionHandler struct {
|
||||
LockSubs sync.Mutex
|
||||
Subscribers map[string][]Subscriber
|
||||
Stats map[string]Stat
|
||||
|
||||
LockStats sync.Mutex
|
||||
Stats map[string]Stat
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) handlePublish(w http.ResponseWriter, r *http.Request) error {
|
||||
|
|
@ -66,12 +70,12 @@ func (handler *subscriptionHandler) handlePublish(w http.ResponseWriter, r *http
|
|||
return err
|
||||
}
|
||||
|
||||
// handler.incStat(fmt.Sprintf("publish.%s", topic))
|
||||
handler.incStat("published")
|
||||
|
||||
if subs, e := handler.Subscribers[topic]; e {
|
||||
for _, sub := range subs {
|
||||
|
||||
// handler.incStat(fmt.Sprintf("publish.post.%s.%s", topic, sub.Callback))
|
||||
handler.incStat("publish.post")
|
||||
log.Printf("publish: creating post to %s\n", sub.Callback)
|
||||
postReq, err := http.NewRequest("POST", sub.Callback, strings.NewReader(string(feedContent)))
|
||||
if err != nil {
|
||||
|
|
@ -147,6 +151,7 @@ func (handler *subscriptionHandler) handleUnsubscription(w http.ResponseWriter,
|
|||
|
||||
func (handler *subscriptionHandler) handleSubscription(w http.ResponseWriter, r *http.Request) error {
|
||||
log.Printf("subscription request received: %s %#v\n", r.URL.String(), r.Form)
|
||||
|
||||
callback := r.Form.Get("hub.callback")
|
||||
topic := r.Form.Get("hub.topic")
|
||||
secret := r.Form.Get("hub.secret")
|
||||
|
|
@ -252,23 +257,27 @@ func (handler *subscriptionHandler) addSubscriberCallback(topic string, subscrib
|
|||
}
|
||||
|
||||
func (handler *subscriptionHandler) incStat(name string) {
|
||||
// if v, e := handler.Stats[name]; e {
|
||||
// handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: v.Updates + 1}
|
||||
// } else {
|
||||
// handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: 1}
|
||||
// }
|
||||
// handler.saveStats()
|
||||
handler.LockStats.Lock()
|
||||
defer handler.LockStats.Unlock()
|
||||
|
||||
if v, e := handler.Stats[name]; e {
|
||||
handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: v.Updates + 1}
|
||||
} else {
|
||||
handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: 1}
|
||||
}
|
||||
|
||||
handler.saveStats()
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||
if r.Method == http.MethodGet {
|
||||
fmt.Fprintln(w, "WebSub hub")
|
||||
_, _ = fmt.Fprintln(w, "WebSub hub")
|
||||
if r.URL.Query().Get("debug") == "1" {
|
||||
// handler.incStat("http.index.debug")
|
||||
handler.incStat("http.index.debug")
|
||||
enc := json.NewEncoder(w)
|
||||
enc.SetIndent("", " ")
|
||||
enc.Encode(handler.Subscribers)
|
||||
//enc.Encode(handler.Stats)
|
||||
_ = enc.Encode(handler.Subscribers)
|
||||
_ = enc.Encode(handler.Stats)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
|
@ -287,14 +296,14 @@ func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Req
|
|||
mode := r.Form.Get("hub.mode")
|
||||
|
||||
if mode == "subscribe" {
|
||||
handler.handleSubscription(w, r)
|
||||
err = handler.handleSubscription(w, r)
|
||||
return
|
||||
} else if mode == "unsubscribe" {
|
||||
handler.handleUnsubscription(w, r)
|
||||
err = handler.handleUnsubscription(w, r)
|
||||
return
|
||||
} else if mode == "publish" {
|
||||
log.Println("hub.mode=publish received")
|
||||
handler.handlePublish(w, r)
|
||||
err = handler.handlePublish(w, r)
|
||||
return
|
||||
} else {
|
||||
http.Error(w, "Unknown hub.mode", 400)
|
||||
|
|
@ -303,6 +312,9 @@ func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Req
|
|||
}
|
||||
|
||||
func (handler *subscriptionHandler) loadStats() error {
|
||||
handler.LockStats.Lock()
|
||||
defer handler.LockStats.Unlock()
|
||||
|
||||
file, err := os.Open("./stats.json")
|
||||
if err != nil {
|
||||
if os.IsNotExist(err) {
|
||||
|
|
@ -316,7 +328,25 @@ func (handler *subscriptionHandler) loadStats() error {
|
|||
return err
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) saveStats() error {
|
||||
handler.LockStats.Lock()
|
||||
defer handler.LockStats.Unlock()
|
||||
|
||||
file, err := os.Create("./stats.json")
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer file.Close()
|
||||
dec := json.NewEncoder(file)
|
||||
dec.SetIndent("", " ")
|
||||
err = dec.Encode(&handler.Stats)
|
||||
return err
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) loadSubscriptions() error {
|
||||
handler.LockSubs.Lock()
|
||||
defer handler.LockSubs.Unlock()
|
||||
|
||||
file, err := os.Open("./subscription.json")
|
||||
if err != nil {
|
||||
if os.IsNotExist(err) {
|
||||
|
|
@ -330,28 +360,11 @@ func (handler *subscriptionHandler) loadSubscriptions() error {
|
|||
return err
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) load() error {
|
||||
err := handler.loadSubscriptions()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return nil //handler.loadStats()
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) saveStats() error {
|
||||
// file, err := os.Create("./stats.json")
|
||||
// if err != nil {
|
||||
// return err
|
||||
// }
|
||||
// defer file.Close()
|
||||
// dec := json.NewEncoder(file)
|
||||
// dec.SetIndent("", " ")
|
||||
// err = dec.Encode(&handler.Stats)
|
||||
// return err
|
||||
return nil
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) saveSubscriptions() error {
|
||||
handler.LockSubs.Lock()
|
||||
defer handler.LockSubs.Unlock()
|
||||
|
||||
file, err := os.Create("./subscription.json")
|
||||
if err != nil {
|
||||
return err
|
||||
|
|
@ -363,6 +376,14 @@ func (handler *subscriptionHandler) saveSubscriptions() error {
|
|||
return err
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) load() error {
|
||||
err := handler.loadSubscriptions()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return handler.loadStats()
|
||||
}
|
||||
|
||||
func (handler *subscriptionHandler) save() error {
|
||||
handler.saveSubscriptions()
|
||||
return handler.saveStats()
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user