package controllers import ( "net/http" "time" oclib "cloud.o-forge.io/core/oc-lib" "cloud.o-forge.io/core/oc-lib/dbs" "cloud.o-forge.io/core/oc-lib/models/booking" beego "github.com/beego/beego/v2/server/web" "github.com/gorilla/websocket" "go.mongodb.org/mongo-driver/bson/primitive" ) // Operations about workspace type BookingController struct { beego.Controller } var BookingExample booking.Booking // @Title Search // @Description search bookings by execution // @Param id path string true "id execution" // @Param is_draft query string false "draft wished" // @Success 200 {workspace} models.workspace // @router /search/execution/:id [get] func (o *BookingController) ExecutionSearch() { /* * This is a sample of how to use the search function * The search function is used to search for data in the database * The search function takes in a filter and a data type * The filter is a struct that contains the search parameters * The data type is an enum that specifies the type of data to search for * The search function returns a list of data that matches the filter * The data is then returned as a json object */ // store and return Id or post with UUID user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request) id := o.Ctx.Input.Param(":id") isDraft := o.Ctx.Input.Query("is_draft") f := dbs.Filters{ Or: map[string][]dbs.Filter{ // filter by name if no filters are provided "execution_id": {{Operator: dbs.EQUAL.String(), Value: id}}, }, } o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.BOOKING), user, peerID, groups, nil).Search(&f, "", isDraft == "true") o.ServeJSON() } // @Title Search // @Description search bookings // @Param start_date path string true "the word search you want to get" // @Param end_date path string true "the word search you want to get" // @Param is_draft query string false "draft wished" // @Success 200 {workspace} models.workspace // @router /search/:start_date/:end_date [get] func (o *BookingController) Search() { /* * This is a sample of how to use the search function * The search function is used to search for data in the database * The search function takes in a filter and a data type * The filter is a struct that contains the search parameters * The data type is an enum that specifies the type of data to search for * The search function returns a list of data that matches the filter * The data is then returned as a json object */ // store and return Id or post with UUID user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request) start_date, _ := time.Parse("2006-01-02", o.Ctx.Input.Param(":start_date")) end_date, _ := time.Parse("2006-01-02", o.Ctx.Input.Param(":end_date")) isDraft := o.Ctx.Input.Query("is_draft") sd := primitive.NewDateTimeFromTime(start_date) ed := primitive.NewDateTimeFromTime(end_date) f := dbs.Filters{ And: map[string][]dbs.Filter{ "execution_date": {{Operator: "gte", Value: sd}, {Operator: "lte", Value: ed}}, }, } o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.BOOKING), user, peerID, groups, nil).Search(&f, "", isDraft == "true") o.ServeJSON() } // @Title GetAll // @Description find booking by id // @Param is_draft query string false "draft wished" // @Success 200 {booking} models.booking // @router / [get] func (o *BookingController) GetAll() { user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request) isDraft := o.Ctx.Input.Query("is_draft") o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.BOOKING), user, peerID, groups, nil).LoadAll(isDraft == "true") o.ServeJSON() } // @Title Get // @Description find booking by id // @Param id path string true "the id you want to get" // @Success 200 {booking} models.booking // @router /:id [get] func (o *BookingController) Get() { user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request) id := o.Ctx.Input.Param(":id") o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.BOOKING), user, peerID, groups, nil).LoadOne(id) o.ServeJSON() } var upgrader = websocket.Upgrader{ CheckOrigin: func(r *http.Request) bool { return true }, // allow all origins }