package app import ( "github.com/veypi/OneBD/rest" M "oa/models" "oa/cfg" "strings" "github.com/google/uuid" ) func useAppUser(r rest.Router) { r.Patch("/:app_user_id", appUserPatch) r.Post("/", appUserPost) r.Put("/:app_user_id", appUserPut) r.Delete("/:app_user_id", appUserDelete) r.Get("/:app_user_id", appUserGet) r.Get("/", appUserList) } func appUserPatch(x *rest.X) (any, error) { opts := &M.AppUserPatch{} err := x.Parse(opts) if err != nil { return nil, err } data := &M.AppUser{} err = cfg.DB().Where("id = ?", opts.ID).First(data).Error if err != nil { return nil, err } optsMap := make(map[string]interface{}) if opts.AppID != nil { optsMap["app_id"] = opts.AppID } if opts.UserID != nil { optsMap["user_id"] = opts.UserID } if opts.Status != nil { optsMap["status"] = opts.Status } err = cfg.DB().Model(data).Updates(optsMap).Error return data, err } func appUserPost(x *rest.X) (any, error) { opts := &M.AppUserPost{} err := x.Parse(opts) if err != nil { return nil, err } data := &M.AppUser{} data.ID = strings.ReplaceAll(uuid.New().String(), "-", "") data.AppID = opts.AppID data.UserID = opts.UserID data.Status = opts.Status err = cfg.DB().Create(data).Error return data, err } func appUserPut(x *rest.X) (any, error) { opts := &M.AppUserPut{} err := x.Parse(opts) if err != nil { return nil, err } data := &M.AppUser{} err = cfg.DB().Where("id = ?", opts.ID).First(data).Error if err != nil { return nil, err } optsMap := map[string]interface{}{ "id": opts.ID, "status": opts.Status, } err = cfg.DB().Model(data).Updates(optsMap).Error return data, err } func appUserDelete(x *rest.X) (any, error) { opts := &M.AppUserDelete{} err := x.Parse(opts) if err != nil { return nil, err } data := &M.AppUser{} err = cfg.DB().Where("id = ?", opts.ID).Delete(data).Error return data, err } func appUserGet(x *rest.X) (any, error) { opts := &M.AppUserGet{} err := x.Parse(opts) if err != nil { return nil, err } data := &M.AppUser{} err = cfg.DB().Where("id = ?", opts.ID).First(data).Error return data, err } func appUserList(x *rest.X) (any, error) { opts := &M.AppUserList{} err := x.Parse(opts) if err != nil { return nil, err } data := make([]*M.AppUser, 0, 10) query := cfg.DB() if opts.AppID != nil { query = query.Where("app_id LIKE ?", opts.AppID) } if opts.UserID != nil { query = query.Where("user_id LIKE ?", opts.UserID) } if opts.Status != nil { query = query.Where("status LIKE ?", opts.Status) } err = query.Find(&data).Error return data, err }