//Broadcaster of new data for realtime notification //Redis queue can be used as realtime source notificateur func processFetchEvens() { session, db := mongo.GetDatabase() timenow := time.Now() var currentDateString = timenow.Format(time.RFC3339) //"2015-03-21T23:59:59Z" didCalls := mongo.GetDidCalls(currentDateString, db) peerInCalls := mongo.GetPeerInCalls(currentDateString, db) peerOutCalls := mongo.GetPeerOutCalls(currentDateString, db) peerInCallsDisp := mongo.GetPeerDispositionByDay(currentDateString, "in", "", db) peerOutCallsDisp := mongo.GetPeerDispositionByDay(currentDateString, "out", "", db) results := bson.M{ "didCalls": didCalls, "peerInCalls": peerInCalls, "peerOutCalls": peerOutCalls, "peerInCallsDisp": peerInCallsDisp, "peerOutCallsDisp": peerOutCallsDisp, } data, err := json.Marshal(results) if err == nil { MyBroker.Messages <- fmt.Sprintf("%s", data) } if session != nil { session.Close() } revel.TRACE.Printf("Broadcast message [%s] to %d clients", data, len(MyBroker.Clients)) }
func (c Daily) PeerGetOutDispositionByDayAndPeer(day string, peer string, tmp int) revel.Result { revel.TRACE.Printf("[Daily Peer] Get outcalls disposition by day [%s] and peer [%s].\r\n", day, peer) results := mongo.GetPeerDispositionByDay(day, "out", peer, c.MongoDatabase) return c.RenderJson(results) }
func (c Daily) PeerGetInDispositionByDay(day string, tmp int) revel.Result { revel.TRACE.Printf("[Daily Peer] Get incalls disposition by day [%s].\r\n", day) results := mongo.GetPeerDispositionByDay(day, "in", "", c.MongoDatabase) return c.RenderJson(results) }