示例#1
0
文件: broker.go 项目: vassilux/revor
//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))
}
示例#2
0
文件: daily.go 项目: vassilux/revor
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)
}
示例#3
0
文件: daily.go 项目: vassilux/revor
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)
}