Rainbond/pkg/api/controller/event.go
2017-12-07 09:56:08 +08:00

57 lines
1.4 KiB
Go

package controller
import (
"io/ioutil"
"net/http"
"github.com/Sirupsen/logrus"
"github.com/bitly/go-simplejson"
"github.com/goodrain/rainbond/pkg/db"
dbmodel "github.com/goodrain/rainbond/pkg/db/model"
httputil "github.com/goodrain/rainbond/pkg/util/http"
)
//Event GetLogs
func (e *TenantStruct) Event(w http.ResponseWriter, r *http.Request) {
// swagger:operation GET /v2/tenants/{tenant_name}/event v2 get events
//
// 获取指定event_ids详细信息
//
// get events
//
// ---
// produces:
// - application/json
// - application/xml
//
// responses:
// default:
// schema:
// "$ref": "#/responses/commandResponse"
// description: 统一返回格式
b, _ := ioutil.ReadAll(r.Body)
defer r.Body.Close()
j, err := simplejson.NewJson(b)
if err != nil {
logrus.Errorf("error decode json,details %s", err.Error())
httputil.ReturnError(r, w, 400, "bad request")
return
}
eventIDS, err := j.Get("event_ids").StringArray()
if err != nil {
logrus.Errorf("error get event_id in json,details %s", err.Error())
httputil.ReturnError(r, w, 400, "bad request")
return
}
result := []*dbmodel.ServiceEvent{}
for _, v := range eventIDS {
serviceEvent, err := db.GetManager().ServiceEventDao().GetEventByEventID(v)
if err != nil {
logrus.Warnf("can't find event by given id %s ,details %s", v, err.Error())
continue
}
result = append(result, serviceEvent)
}
httputil.ReturnSuccess(r, w, result)
}