hook

package
v0.2.7 Latest Latest
Warning

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

Go to latest
Published: Jul 16, 2020 License: Apache-2.0 Imports: 3 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func If added in v0.2.6

func If(hk entv1.Hook, cond Condition) entv1.Hook

If executes the given hook under condition.

Hook.If(ComputeAverage, And(HasFields(...), HasAddedFields(...)))

func On

func On(hk entv1.Hook, op entv1.Op) entv1.Hook

On executes the given hook only for the given operation.

hook.On(Log, entv1.Delete|entv1.Create)

func Reject

func Reject(op entv1.Op) entv1.Hook

Reject returns a hook that rejects all operations that match op.

func (T) Hooks() []entv1.Hook {
	return []entv1.Hook{
		Reject(entv1.Delete|entv1.Update),
	}
}

func Unless added in v0.2.4

func Unless(hk entv1.Hook, op entv1.Op) entv1.Hook

Unless skips the given hook only for the given operation.

hook.Unless(Log, entv1.Update|entv1.UpdateOne)

Types

type CarFunc

type CarFunc func(context.Context, *entv1.CarMutation) (entv1.Value, error)

The CarFunc type is an adapter to allow the use of ordinary function as Car mutator.

func (CarFunc) Mutate

func (f CarFunc) Mutate(ctx context.Context, m entv1.Mutation) (entv1.Value, error)

Mutate calls f(ctx, m).

type Chain added in v0.1.5

type Chain struct {
	// contains filtered or unexported fields
}

Chain acts as a list of hooks and is effectively immutable. Once created, it will always hold the same set of hooks in the same order.

func NewChain added in v0.1.5

func NewChain(hooks ...entv1.Hook) Chain

NewChain creates a new chain of hooks.

func (Chain) Append added in v0.1.5

func (c Chain) Append(hooks ...entv1.Hook) Chain

Append extends a chain, adding the specified hook as the last ones in the mutation flow.

func (Chain) Extend added in v0.1.5

func (c Chain) Extend(chain Chain) Chain

Extend extends a chain, adding the specified chain as the last ones in the mutation flow.

func (Chain) Hook added in v0.1.5

func (c Chain) Hook() entv1.Hook

Hook chains the list of hooks and returns the final hook.

type Condition added in v0.2.6

type Condition func(context.Context, entv1.Mutation) bool

Condition is a hook condition function.

func And added in v0.2.6

func And(first, second Condition, rest ...Condition) Condition

And groups conditions with the AND operator.

func HasAddedFields added in v0.2.6

func HasAddedFields(field string, fields ...string) Condition

HasAddedFields is a condition validating `.AddedField` on fields.

func HasClearedFields added in v0.2.6

func HasClearedFields(field string, fields ...string) Condition

HasClearedFields is a condition validating `.FieldCleared` on fields.

func HasFields added in v0.2.6

func HasFields(field string, fields ...string) Condition

HasFields is a condition validating `.Field` on fields.

func HasOp added in v0.2.6

func HasOp(op entv1.Op) Condition

HasOp is a condition testing mutation operation.

func Not added in v0.2.6

func Not(cond Condition) Condition

Not negates a given condition.

func Or added in v0.2.6

func Or(first, second Condition, rest ...Condition) Condition

Or groups conditions with the OR operator.

type UserFunc

type UserFunc func(context.Context, *entv1.UserMutation) (entv1.Value, error)

The UserFunc type is an adapter to allow the use of ordinary function as User mutator.

func (UserFunc) Mutate

func (f UserFunc) Mutate(ctx context.Context, m entv1.Mutation) (entv1.Value, error)

Mutate calls f(ctx, m).

Jump to

Keyboard shortcuts

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