hookhandler

package
v0.9.9 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 31, 2022 License: MIT Imports: 5 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type APICardinality

type APICardinality int
const (
	APICardinalityOne  APICardinality = 1
	APICardinalityMany APICardinality = 2
)

type Cargo

type Cargo struct {
	Payload interface{}
}

Cargo is payload between hookpoints

type Data

type Data struct {
	// Ms is the slice of IModels
	Ms []models.IModel
	// DB is the DB handle
	DB *gorm.DB
	// Who is operating this CRUPD right now
	Who models.UserIDFetchable
	// TypeString
	TypeString string
	// Cargo between Before and After hookpoints (not used in AfterRead since there is before read hookpoint.)
	Cargo *Cargo
	// Role of this user in relation to this data, only available during read
	Roles []models.UserRole
	// URL parameters
	URLParams map[urlparam.Param]interface{}
}

Data is the data send to batch model hookpoints

type EndPointInfo

type EndPointInfo struct {
	Op          RESTOp
	Cardinality APICardinality
}

Endpoint information

type IAfter

type IAfter interface {
	After(data *Data, info *EndPointInfo) *webrender.RetError
}

IAfter supports method to be called after data is after all CRUPD operations

type IAfterTransact

type IAfterTransact interface {
	AfterTransact(data *Data, info *EndPointInfo)
}

IAfterTransact is the method to be called after data is after the entire database transaction is done. No error is returned because database transaction is already committed.

type IBefore

type IBefore interface {
	Before(data *Data, info *EndPointInfo) *webrender.RetError
}

IBefore supports method to be called before data is fetched for all CRUPD operations

type IBeforeApply

type IBeforeApply interface {
	BeforeApply(data *Data, info *EndPointInfo) *webrender.RetError
}

IBeforeApply before patching operation occurred. Only called for Patch. This comes before patch is applied. Before "Before"

type IHasRenderer

type IHasRenderer interface {
	Render(c *gin.Context, data *Data, op *EndPointInfo) bool
}

IHasRenderer is for formatting IModel with a custom function basically do your own custom output If return false, use the default JSON output For batch renderer, register a Render(r UserRole, who models.UserIDFetchable, modelObjs []IModel) bool

type IHookhandler

type IHookhandler interface {
	// Init data for this REST operation
	Init(data *InitData, args ...interface{})
}

type InitData added in v0.9.3

type InitData struct {
	Who models.UserIDFetchable
	// TypeString
	TypeString string
	// Role of this user in relation to this data, only available during read
	Roles []models.UserRole
	// URL parameters
	URLParams map[urlparam.Param]interface{}
	// Info is endpoint information
	Info *EndPointInfo
}

type RESTOp

type RESTOp int

Method designates the type of operations for BeforeCRUPD and AfterCRUPD hookpoints

const (
	RESTOpOther RESTOp = iota // should not be used
	RESTOpRead
	RESTOpCreate
	RESTOpUpdate
	RESTOpPatch
	RESTOpDelete
)

func HTTPMethodToRESTOp

func HTTPMethodToRESTOp(method string) RESTOp

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL