2024-08-06 11:09:38 +02:00
|
|
|
package controllers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
oclib "cloud.o-forge.io/core/oc-lib"
|
|
|
|
dbs "cloud.o-forge.io/core/oc-lib/dbs"
|
|
|
|
beego "github.com/beego/beego/v2/server/web"
|
|
|
|
"go.mongodb.org/mongo-driver/bson/primitive"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Operations about workflow
|
|
|
|
type WorkflowExecutionController struct {
|
|
|
|
beego.Controller
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Title Search
|
|
|
|
// @Description search workspace
|
|
|
|
// @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"
|
2025-01-17 17:21:52 +01:00
|
|
|
// @Param is_draft query string false "draft wished"
|
2024-08-06 11:09:38 +02:00
|
|
|
// @Success 200 {workspace} models.workspace
|
|
|
|
// @router /search/:start_date/:end_date [get]
|
|
|
|
func (o *WorkflowExecutionController) Search() {
|
2024-08-30 10:58:29 +02:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*/
|
2025-01-17 17:21:52 +01:00
|
|
|
user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request)
|
2024-08-06 11:09:38 +02:00
|
|
|
// store and return Id or post with UUID
|
|
|
|
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"))
|
|
|
|
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}},
|
|
|
|
},
|
|
|
|
}
|
2025-01-17 17:21:52 +01:00
|
|
|
isDraft := o.Ctx.Input.Query("is_draft")
|
|
|
|
o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.WORKFLOW_EXECUTION), user, peerID, groups, nil).Search(&f, "", isDraft == "true")
|
2024-08-06 11:09:38 +02:00
|
|
|
o.ServeJSON()
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Title GetAll
|
|
|
|
// @Description find workflow by workflowid
|
2025-01-17 17:21:52 +01:00
|
|
|
// @Param is_draft query string false "draft wished"
|
2024-08-06 11:09:38 +02:00
|
|
|
// @Success 200 {workflow} models.workflow
|
|
|
|
// @router / [get]
|
|
|
|
func (o *WorkflowExecutionController) GetAll() {
|
2025-01-17 17:21:52 +01:00
|
|
|
user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request)
|
|
|
|
isDraft := o.Ctx.Input.Query("is_draft")
|
|
|
|
o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.WORKFLOW_EXECUTION), user, peerID, groups, nil).LoadAll(isDraft == "true")
|
2024-08-06 11:09:38 +02:00
|
|
|
o.ServeJSON()
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Title Get
|
|
|
|
// @Description find workflow by workflowid
|
|
|
|
// @Param id path string true "the workflowid you want to get"
|
|
|
|
// @Success 200 {workflow} models.workflow
|
|
|
|
// @router /:id [get]
|
|
|
|
func (o *WorkflowExecutionController) Get() {
|
2025-01-17 17:21:52 +01:00
|
|
|
user, peerID, groups := oclib.ExtractTokenInfo(*o.Ctx.Request)
|
2024-08-06 11:09:38 +02:00
|
|
|
id := o.Ctx.Input.Param(":id")
|
2025-01-17 17:21:52 +01:00
|
|
|
o.Data["json"] = oclib.NewRequest(oclib.LibDataEnum(oclib.WORKFLOW_EXECUTION), user, peerID, groups, nil).LoadOne(id)
|
2024-08-06 11:09:38 +02:00
|
|
|
o.ServeJSON()
|
|
|
|
}
|