hook

package
v0.0.2 Latest Latest
Warning

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

Go to latest
Published: Nov 9, 2022 License: Apache-2.0 Imports: 3 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func FixedError

func FixedError(err error) pets.Hook

FixedError is a hook returning a fixed error.

func If

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

If executes the given hook under condition.

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

func On

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

On executes the given hook only for the given operation.

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

func Reject

func Reject(op pets.Op) pets.Hook

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

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

func Unless

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

Unless skips the given hook only for the given operation.

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

Types

type CategoryFunc

type CategoryFunc func(context.Context, *pets.CategoryMutation) (pets.Value, error)

The CategoryFunc type is an adapter to allow the use of ordinary function as Category mutator.

func (CategoryFunc) Mutate

func (f CategoryFunc) Mutate(ctx context.Context, m pets.Mutation) (pets.Value, error)

Mutate calls f(ctx, m).

type Chain

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

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

NewChain creates a new chain of hooks.

func (Chain) Append

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

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

func (Chain) Extend

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

func (c Chain) Hook() pets.Hook

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

type Condition

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

Condition is a hook condition function.

func And

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

And groups conditions with the AND operator.

func HasAddedFields

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

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

func HasClearedFields

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

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

func HasFields

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

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

func HasOp

func HasOp(op pets.Op) Condition

HasOp is a condition testing mutation operation.

func Not

func Not(cond Condition) Condition

Not negates a given condition.

func Or

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

Or groups conditions with the OR operator.

type PetFunc

type PetFunc func(context.Context, *pets.PetMutation) (pets.Value, error)

The PetFunc type is an adapter to allow the use of ordinary function as Pet mutator.

func (PetFunc) Mutate

func (f PetFunc) Mutate(ctx context.Context, m pets.Mutation) (pets.Value, error)

Mutate calls f(ctx, m).

type UserFunc

type UserFunc func(context.Context, *pets.UserMutation) (pets.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 pets.Mutation) (pets.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