123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- package got
- import (
- "text/template"
- . "git.eugeniocarvalho.dev/eugeniucarvalho/apicodegen/common"
- G "github.com/dave/jennifer/jen"
- // "github.com/davecgh/go-spew/spew"
- )
- var (
- patchStmtsTmpl, patchRelationStmtsTmpl *template.Template
- patchStmtsErr error
- )
- func init() {
- patchStmtsTmpl, patchStmtsErr = ParseTemplate(`
- var (
- patchs = &models.{{.entity}}Patchs{Set: &models.{{.entity}}Input{}}
- entity = patchs.Set
- )
- if err = api.ReadJson(ctx, patchs); err != nil {
- return
- }
- entity.SetMode("patch")
- values := ctx.Values()
- values.Set("patchs", patchs)
- entity.LastUpdate = api.NowUnix()
- user := values.Get("$user.ref").(*models.UserReference)
- entity.UpdatedBy = user
- values.Set("entity", entity)
- {{if .entityAlias }}
- values.Set("{{.entityAlias}}", entity)
- values.Set("{{.entityAlias}}.patch", patchs)
- {{end}}
-
- {{if .preconditions}}
- if _, err = executeAction(
- ctx,
- {{.preconditions}},
- ); err != nil {
- return
- }
- {{end}}
- filter := values.Get("$filter").(*api.Filter)
- filter.DB = "{{.dbName}}"
- filter.Collection = "{{.collectionName}}"
- filter.Patchs = patchs.Patch()
- if _, err = models.Api.PatchOne(filter); err != nil {
- err.Details(&errs.Detail{
- Dominio: "",
- Reason: "",
- Location: "middleware.path",
- LocationType: "middleware.operation/{{.entity}}",
- })
- return
- }
- filter.Entity = &models.{{.entity}}{}
- if _, err = models.Api.FindOne(filter); err != nil {
- err.Details(&errs.Detail{
- Dominio: "",
- Reason: "",
- Location: "middleware.findOne",
- LocationType: "middleware.operation/{{.entity}}",
- })
- return
- }
- values.Set("{{.entityAlias}}.after.patch", filter.Entity)
- {{if .hasUpdateRelation}} // Cria uma thread que executa a atualizaca das referências.
- go func() {
- UpdateRelation{{.entity}}(filter)
- }() {{end}}
- {{if .beforeResponse}}
- if resp, err = executeAction(
- ctx,
- {{.beforeResponse}},
- ); err != nil || resp != nil {
- return
- }
- {{end}}
- resp = filter.Entity
- return`)
- if patchStmtsErr != nil {
- panic(patchStmtsErr)
- }
- }
- var (
- GenPatchStmts = &Middleware{
- Id: "implement",
- Type: "method",
- Fn: func(ctx *MiddlewareContext) error {
- var (
- project = ctx.Project
- method = ctx.Method
- dbName = project.GetEntityDB(method.Entity)
- collectionName = project.GetCollection(method.Entity)
- dependenceMethod = BASE_HAS_DEPENDE + method.Entity
- beforeSend = method.Hook("beforeSend")
- beforePersist = method.Hook("beforePersist")
- context = map[string]interface{}{
- "dbName": dbName,
- "collectionName": collectionName,
- "entity": method.Entity,
- "dependenceMethod": dependenceMethod,
- "beforePersist": beforePersist,
- "beforeSend": beforeSend,
- "hasUpdateRelation": SR.Has(method.Entity),
- "preconditions": parseMethodActions(method.Preconditions),
- "beforeResponse": parseMethodActions(method.BeforeResponse),
- "entityAlias": getCustom(method.Custom, "go.entity.alias"),
- }
- )
- if beforePersist {
- generateHookCall(project, method, "beforePersist")
- }
- if beforeSend {
- generateHookCall(project, method, "beforeSend")
- }
- // Nome do metodo que verifica se a entidade tem dependencias
- out, _ := TemplateToString(patchStmtsTmpl, context)
- afterMethod := ctx.Statement.Block(G.Id(out)).Line()
- if body, err := createUpdateRelationMethod(method, context); err == nil {
- afterMethod.Id(body)
- }
- return nil
- },
- }
- )
|