// Code generated by ent, DO NOT EDIT. package intercept import ( "context" "fmt" "wechat-api/ent" "wechat-api/ent/batchmsg" "wechat-api/ent/contact" "wechat-api/ent/label" "wechat-api/ent/labelrelationship" "wechat-api/ent/message" "wechat-api/ent/messagerecords" "wechat-api/ent/msg" "wechat-api/ent/predicate" "wechat-api/ent/server" "wechat-api/ent/sopnode" "wechat-api/ent/sopstage" "wechat-api/ent/soptask" "wechat-api/ent/wx" "entgo.io/ent/dialect/sql" ) // The Query interface represents an operation that queries a graph. // By using this interface, users can write generic code that manipulates // query builders of different types. type Query interface { // Type returns the string representation of the query type. Type() string // Limit the number of records to be returned by this query. Limit(int) // Offset to start from. Offset(int) // Unique configures the query builder to filter duplicate records. Unique(bool) // Order specifies how the records should be ordered. Order(...func(*sql.Selector)) // WhereP appends storage-level predicates to the query builder. Using this method, users // can use type-assertion to append predicates that do not depend on any generated package. WhereP(...func(*sql.Selector)) } // The Func type is an adapter that allows ordinary functions to be used as interceptors. // Unlike traversal functions, interceptors are skipped during graph traversals. Note that the // implementation of Func is different from the one defined in entgo.io/ent.InterceptFunc. type Func func(context.Context, Query) error // Intercept calls f(ctx, q) and then applied the next Querier. func (f Func) Intercept(next ent.Querier) ent.Querier { return ent.QuerierFunc(func(ctx context.Context, q ent.Query) (ent.Value, error) { query, err := NewQuery(q) if err != nil { return nil, err } if err := f(ctx, query); err != nil { return nil, err } return next.Query(ctx, q) }) } // The TraverseFunc type is an adapter to allow the use of ordinary function as Traverser. // If f is a function with the appropriate signature, TraverseFunc(f) is a Traverser that calls f. type TraverseFunc func(context.Context, Query) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseFunc) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseFunc) Traverse(ctx context.Context, q ent.Query) error { query, err := NewQuery(q) if err != nil { return err } return f(ctx, query) } // The BatchMsgFunc type is an adapter to allow the use of ordinary function as a Querier. type BatchMsgFunc func(context.Context, *ent.BatchMsgQuery) (ent.Value, error) // Query calls f(ctx, q). func (f BatchMsgFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.BatchMsgQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.BatchMsgQuery", q) } // The TraverseBatchMsg type is an adapter to allow the use of ordinary function as Traverser. type TraverseBatchMsg func(context.Context, *ent.BatchMsgQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseBatchMsg) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseBatchMsg) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.BatchMsgQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.BatchMsgQuery", q) } // The ContactFunc type is an adapter to allow the use of ordinary function as a Querier. type ContactFunc func(context.Context, *ent.ContactQuery) (ent.Value, error) // Query calls f(ctx, q). func (f ContactFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.ContactQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.ContactQuery", q) } // The TraverseContact type is an adapter to allow the use of ordinary function as Traverser. type TraverseContact func(context.Context, *ent.ContactQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseContact) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseContact) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.ContactQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.ContactQuery", q) } // The LabelFunc type is an adapter to allow the use of ordinary function as a Querier. type LabelFunc func(context.Context, *ent.LabelQuery) (ent.Value, error) // Query calls f(ctx, q). func (f LabelFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.LabelQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.LabelQuery", q) } // The TraverseLabel type is an adapter to allow the use of ordinary function as Traverser. type TraverseLabel func(context.Context, *ent.LabelQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseLabel) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseLabel) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.LabelQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.LabelQuery", q) } // The LabelRelationshipFunc type is an adapter to allow the use of ordinary function as a Querier. type LabelRelationshipFunc func(context.Context, *ent.LabelRelationshipQuery) (ent.Value, error) // Query calls f(ctx, q). func (f LabelRelationshipFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.LabelRelationshipQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.LabelRelationshipQuery", q) } // The TraverseLabelRelationship type is an adapter to allow the use of ordinary function as Traverser. type TraverseLabelRelationship func(context.Context, *ent.LabelRelationshipQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseLabelRelationship) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseLabelRelationship) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.LabelRelationshipQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.LabelRelationshipQuery", q) } // The MessageFunc type is an adapter to allow the use of ordinary function as a Querier. type MessageFunc func(context.Context, *ent.MessageQuery) (ent.Value, error) // Query calls f(ctx, q). func (f MessageFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.MessageQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.MessageQuery", q) } // The TraverseMessage type is an adapter to allow the use of ordinary function as Traverser. type TraverseMessage func(context.Context, *ent.MessageQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseMessage) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseMessage) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.MessageQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.MessageQuery", q) } // The MessageRecordsFunc type is an adapter to allow the use of ordinary function as a Querier. type MessageRecordsFunc func(context.Context, *ent.MessageRecordsQuery) (ent.Value, error) // Query calls f(ctx, q). func (f MessageRecordsFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.MessageRecordsQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.MessageRecordsQuery", q) } // The TraverseMessageRecords type is an adapter to allow the use of ordinary function as Traverser. type TraverseMessageRecords func(context.Context, *ent.MessageRecordsQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseMessageRecords) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseMessageRecords) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.MessageRecordsQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.MessageRecordsQuery", q) } // The MsgFunc type is an adapter to allow the use of ordinary function as a Querier. type MsgFunc func(context.Context, *ent.MsgQuery) (ent.Value, error) // Query calls f(ctx, q). func (f MsgFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.MsgQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.MsgQuery", q) } // The TraverseMsg type is an adapter to allow the use of ordinary function as Traverser. type TraverseMsg func(context.Context, *ent.MsgQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseMsg) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseMsg) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.MsgQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.MsgQuery", q) } // The ServerFunc type is an adapter to allow the use of ordinary function as a Querier. type ServerFunc func(context.Context, *ent.ServerQuery) (ent.Value, error) // Query calls f(ctx, q). func (f ServerFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.ServerQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.ServerQuery", q) } // The TraverseServer type is an adapter to allow the use of ordinary function as Traverser. type TraverseServer func(context.Context, *ent.ServerQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseServer) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseServer) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.ServerQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.ServerQuery", q) } // The SopNodeFunc type is an adapter to allow the use of ordinary function as a Querier. type SopNodeFunc func(context.Context, *ent.SopNodeQuery) (ent.Value, error) // Query calls f(ctx, q). func (f SopNodeFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.SopNodeQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.SopNodeQuery", q) } // The TraverseSopNode type is an adapter to allow the use of ordinary function as Traverser. type TraverseSopNode func(context.Context, *ent.SopNodeQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseSopNode) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseSopNode) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.SopNodeQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.SopNodeQuery", q) } // The SopStageFunc type is an adapter to allow the use of ordinary function as a Querier. type SopStageFunc func(context.Context, *ent.SopStageQuery) (ent.Value, error) // Query calls f(ctx, q). func (f SopStageFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.SopStageQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.SopStageQuery", q) } // The TraverseSopStage type is an adapter to allow the use of ordinary function as Traverser. type TraverseSopStage func(context.Context, *ent.SopStageQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseSopStage) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseSopStage) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.SopStageQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.SopStageQuery", q) } // The SopTaskFunc type is an adapter to allow the use of ordinary function as a Querier. type SopTaskFunc func(context.Context, *ent.SopTaskQuery) (ent.Value, error) // Query calls f(ctx, q). func (f SopTaskFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.SopTaskQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.SopTaskQuery", q) } // The TraverseSopTask type is an adapter to allow the use of ordinary function as Traverser. type TraverseSopTask func(context.Context, *ent.SopTaskQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseSopTask) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseSopTask) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.SopTaskQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.SopTaskQuery", q) } // The WxFunc type is an adapter to allow the use of ordinary function as a Querier. type WxFunc func(context.Context, *ent.WxQuery) (ent.Value, error) // Query calls f(ctx, q). func (f WxFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) { if q, ok := q.(*ent.WxQuery); ok { return f(ctx, q) } return nil, fmt.Errorf("unexpected query type %T. expect *ent.WxQuery", q) } // The TraverseWx type is an adapter to allow the use of ordinary function as Traverser. type TraverseWx func(context.Context, *ent.WxQuery) error // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline. func (f TraverseWx) Intercept(next ent.Querier) ent.Querier { return next } // Traverse calls f(ctx, q). func (f TraverseWx) Traverse(ctx context.Context, q ent.Query) error { if q, ok := q.(*ent.WxQuery); ok { return f(ctx, q) } return fmt.Errorf("unexpected query type %T. expect *ent.WxQuery", q) } // NewQuery returns the generic Query interface for the given typed query. func NewQuery(q ent.Query) (Query, error) { switch q := q.(type) { case *ent.BatchMsgQuery: return &query[*ent.BatchMsgQuery, predicate.BatchMsg, batchmsg.OrderOption]{typ: ent.TypeBatchMsg, tq: q}, nil case *ent.ContactQuery: return &query[*ent.ContactQuery, predicate.Contact, contact.OrderOption]{typ: ent.TypeContact, tq: q}, nil case *ent.LabelQuery: return &query[*ent.LabelQuery, predicate.Label, label.OrderOption]{typ: ent.TypeLabel, tq: q}, nil case *ent.LabelRelationshipQuery: return &query[*ent.LabelRelationshipQuery, predicate.LabelRelationship, labelrelationship.OrderOption]{typ: ent.TypeLabelRelationship, tq: q}, nil case *ent.MessageQuery: return &query[*ent.MessageQuery, predicate.Message, message.OrderOption]{typ: ent.TypeMessage, tq: q}, nil case *ent.MessageRecordsQuery: return &query[*ent.MessageRecordsQuery, predicate.MessageRecords, messagerecords.OrderOption]{typ: ent.TypeMessageRecords, tq: q}, nil case *ent.MsgQuery: return &query[*ent.MsgQuery, predicate.Msg, msg.OrderOption]{typ: ent.TypeMsg, tq: q}, nil case *ent.ServerQuery: return &query[*ent.ServerQuery, predicate.Server, server.OrderOption]{typ: ent.TypeServer, tq: q}, nil case *ent.SopNodeQuery: return &query[*ent.SopNodeQuery, predicate.SopNode, sopnode.OrderOption]{typ: ent.TypeSopNode, tq: q}, nil case *ent.SopStageQuery: return &query[*ent.SopStageQuery, predicate.SopStage, sopstage.OrderOption]{typ: ent.TypeSopStage, tq: q}, nil case *ent.SopTaskQuery: return &query[*ent.SopTaskQuery, predicate.SopTask, soptask.OrderOption]{typ: ent.TypeSopTask, tq: q}, nil case *ent.WxQuery: return &query[*ent.WxQuery, predicate.Wx, wx.OrderOption]{typ: ent.TypeWx, tq: q}, nil default: return nil, fmt.Errorf("unknown query type %T", q) } } type query[T any, P ~func(*sql.Selector), R ~func(*sql.Selector)] struct { typ string tq interface { Limit(int) T Offset(int) T Unique(bool) T Order(...R) T Where(...P) T } } func (q query[T, P, R]) Type() string { return q.typ } func (q query[T, P, R]) Limit(limit int) { q.tq.Limit(limit) } func (q query[T, P, R]) Offset(offset int) { q.tq.Offset(offset) } func (q query[T, P, R]) Unique(unique bool) { q.tq.Unique(unique) } func (q query[T, P, R]) Order(orders ...func(*sql.Selector)) { rs := make([]R, len(orders)) for i := range orders { rs[i] = orders[i] } q.tq.Order(rs...) } func (q query[T, P, R]) WhereP(ps ...func(*sql.Selector)) { p := make([]P, len(ps)) for i := range ps { p[i] = ps[i] } q.tq.Where(p...) }