Cleanup (and re-enable stats)
All checks were successful
the build was successful

This commit is contained in:
Peter Stuifzand 2018-12-10 19:39:34 +01:00
parent 309b034180
commit 7aa6471696

View File

@ -70,12 +70,12 @@ func (handler *subscriptionHandler) handlePublish(w http.ResponseWriter, r *http
return err return err
} }
// handler.incStat(fmt.Sprintf("publish.%s", topic)) handler.incStat("published")
if subs, e := handler.Subscribers[topic]; e { if subs, e := handler.Subscribers[topic]; e {
for _, sub := range subs { 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) log.Printf("publish: creating post to %s\n", sub.Callback)
postReq, err := http.NewRequest("POST", sub.Callback, strings.NewReader(string(feedContent))) postReq, err := http.NewRequest("POST", sub.Callback, strings.NewReader(string(feedContent)))
if err != nil { if err != nil {
@ -257,23 +257,27 @@ func (handler *subscriptionHandler) addSubscriberCallback(topic string, subscrib
} }
func (handler *subscriptionHandler) incStat(name string) { func (handler *subscriptionHandler) incStat(name string) {
// if v, e := handler.Stats[name]; e { handler.LockStats.Lock()
// handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: v.Updates + 1} defer handler.LockStats.Unlock()
// } else {
// handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: 1} if v, e := handler.Stats[name]; e {
// } handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: v.Updates + 1}
// handler.saveStats() } else {
handler.Stats[name] = Stat{LastUpdate: time.Now(), Updates: 1}
}
handler.saveStats()
} }
func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
if r.Method == http.MethodGet { if r.Method == http.MethodGet {
fmt.Fprintln(w, "WebSub hub") _, _ = fmt.Fprintln(w, "WebSub hub")
if r.URL.Query().Get("debug") == "1" { if r.URL.Query().Get("debug") == "1" {
// handler.incStat("http.index.debug") handler.incStat("http.index.debug")
enc := json.NewEncoder(w) enc := json.NewEncoder(w)
enc.SetIndent("", " ") enc.SetIndent("", " ")
enc.Encode(handler.Subscribers) _ = enc.Encode(handler.Subscribers)
//enc.Encode(handler.Stats) _ = enc.Encode(handler.Stats)
} }
return return
} }
@ -292,14 +296,14 @@ func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Req
mode := r.Form.Get("hub.mode") mode := r.Form.Get("hub.mode")
if mode == "subscribe" { if mode == "subscribe" {
handler.handleSubscription(w, r) err = handler.handleSubscription(w, r)
return return
} else if mode == "unsubscribe" { } else if mode == "unsubscribe" {
handler.handleUnsubscription(w, r) err = handler.handleUnsubscription(w, r)
return return
} else if mode == "publish" { } else if mode == "publish" {
log.Println("hub.mode=publish received") log.Println("hub.mode=publish received")
handler.handlePublish(w, r) err = handler.handlePublish(w, r)
return return
} else { } else {
http.Error(w, "Unknown hub.mode", 400) http.Error(w, "Unknown hub.mode", 400)
@ -308,6 +312,9 @@ func (handler *subscriptionHandler) ServeHTTP(w http.ResponseWriter, r *http.Req
} }
func (handler *subscriptionHandler) loadStats() error { func (handler *subscriptionHandler) loadStats() error {
handler.LockStats.Lock()
defer handler.LockStats.Unlock()
file, err := os.Open("./stats.json") file, err := os.Open("./stats.json")
if err != nil { if err != nil {
if os.IsNotExist(err) { if os.IsNotExist(err) {
@ -321,10 +328,25 @@ func (handler *subscriptionHandler) loadStats() error {
return err return err
} }
func (handler *subscriptionHandler) loadSubscriptions() error { func (handler *subscriptionHandler) saveStats() error {
handler.LockStats.Lock() handler.LockStats.Lock()
defer handler.LockStats.Unlock() 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") file, err := os.Open("./subscription.json")
if err != nil { if err != nil {
if os.IsNotExist(err) { if os.IsNotExist(err) {
@ -338,27 +360,6 @@ func (handler *subscriptionHandler) loadSubscriptions() error {
return err return err
} }
func (handler *subscriptionHandler) load() error {
err := handler.loadSubscriptions()
if err != nil {
return err
}
return nil //handler.loadStats()
}
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) saveSubscriptions() error { func (handler *subscriptionHandler) saveSubscriptions() error {
handler.LockSubs.Lock() handler.LockSubs.Lock()
@ -375,6 +376,14 @@ func (handler *subscriptionHandler) saveSubscriptions() error {
return err return err
} }
func (handler *subscriptionHandler) load() error {
err := handler.loadSubscriptions()
if err != nil {
return err
}
return handler.loadStats()
}
func (handler *subscriptionHandler) save() error { func (handler *subscriptionHandler) save() error {
handler.saveSubscriptions() handler.saveSubscriptions()
return handler.saveStats() return handler.saveStats()