3
0
corteza/system/rest/application.go

163 lines
4.3 KiB
Go

package rest
import (
"context"
"github.com/titpetric/factory/resputil"
"github.com/cortezaproject/corteza-server/pkg/corredor"
"github.com/cortezaproject/corteza-server/pkg/rh"
"github.com/cortezaproject/corteza-server/system/rest/request"
"github.com/cortezaproject/corteza-server/system/service"
"github.com/cortezaproject/corteza-server/system/service/event"
"github.com/cortezaproject/corteza-server/system/types"
"github.com/pkg/errors"
)
var _ = errors.Wrap
type (
Application struct {
application service.ApplicationService
ac applicationAccessController
}
applicationAccessController interface {
CanGrant(context.Context) bool
CanUpdateApplication(context.Context, *types.Application) bool
CanDeleteApplication(context.Context, *types.Application) bool
}
applicationPayload struct {
*types.Application
CanGrant bool `json:"canGrant"`
CanUpdateApplication bool `json:"canUpdateApplication"`
CanDeleteApplication bool `json:"canDeleteApplication"`
}
applicationSetPayload struct {
Filter types.ApplicationFilter `json:"filter"`
Set []*applicationPayload `json:"set"`
}
)
func (Application) New() *Application {
return &Application{
application: service.DefaultApplication,
ac: service.DefaultAccessControl,
}
}
func (ctrl *Application) List(ctx context.Context, r *request.ApplicationList) (interface{}, error) {
f := types.ApplicationFilter{
Name: r.Name,
Query: r.Query,
Deleted: rh.FilterState(r.Deleted),
Sort: rh.NormalizeSortColumns(r.Sort),
PageFilter: rh.Paging(r.Page, r.PerPage),
}
set, filter, err := ctrl.application.With(ctx).Find(f)
return ctrl.makeFilterPayload(ctx, set, filter, err)
}
func (ctrl *Application) Create(ctx context.Context, r *request.ApplicationCreate) (interface{}, error) {
var (
err error
app = &types.Application{
Name: r.Name,
Enabled: r.Enabled,
}
)
if r.Unify != nil {
app.Unify = &types.ApplicationUnify{}
if err := r.Unify.Unmarshal(app.Unify); err != nil {
return nil, err
}
}
app, err = ctrl.application.With(ctx).Create(app)
return ctrl.makePayload(ctx, app, err)
}
func (ctrl *Application) Update(ctx context.Context, r *request.ApplicationUpdate) (interface{}, error) {
var (
err error
app = &types.Application{
ID: r.ApplicationID,
Name: r.Name,
Enabled: r.Enabled,
}
)
if r.Unify != nil {
app.Unify = &types.ApplicationUnify{}
if err := r.Unify.Unmarshal(app.Unify); err != nil {
return nil, err
}
}
app, err = ctrl.application.With(ctx).Update(app)
return ctrl.makePayload(ctx, app, err)
}
func (ctrl *Application) Read(ctx context.Context, r *request.ApplicationRead) (interface{}, error) {
app, err := ctrl.application.With(ctx).FindByID(r.ApplicationID)
return ctrl.makePayload(ctx, app, err)
}
func (ctrl *Application) Delete(ctx context.Context, r *request.ApplicationDelete) (interface{}, error) {
return resputil.OK(), ctrl.application.With(ctx).Delete(r.ApplicationID)
}
func (ctrl *Application) Undelete(ctx context.Context, r *request.ApplicationUndelete) (interface{}, error) {
return resputil.OK(), ctrl.application.With(ctx).Undelete(r.ApplicationID)
}
func (ctrl *Application) FireTrigger(ctx context.Context, r *request.ApplicationFireTrigger) (rsp interface{}, err error) {
var (
application *types.Application
)
if application, err = ctrl.application.With(ctx).FindByID(r.ApplicationID); err != nil {
return
}
return resputil.OK(), corredor.Service().ExecOnManual(ctx, r.Script, event.ApplicationOnManual(application, nil))
}
func (ctrl Application) makePayload(ctx context.Context, m *types.Application, err error) (*applicationPayload, error) {
if err != nil || m == nil {
return nil, err
}
return &applicationPayload{
Application: m,
CanGrant: ctrl.ac.CanGrant(ctx),
CanUpdateApplication: ctrl.ac.CanUpdateApplication(ctx, m),
CanDeleteApplication: ctrl.ac.CanDeleteApplication(ctx, m),
}, nil
}
func (ctrl Application) makeFilterPayload(ctx context.Context, nn types.ApplicationSet, f types.ApplicationFilter, err error) (*applicationSetPayload, error) {
if err != nil {
return nil, err
}
msp := &applicationSetPayload{Filter: f, Set: make([]*applicationPayload, len(nn))}
for i := range nn {
msp.Set[i], _ = ctrl.makePayload(ctx, nn[i], nil)
}
return msp, nil
}