intercept.go 50 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289
  1. // Code generated by ent, DO NOT EDIT.
  2. package intercept
  3. import (
  4. "context"
  5. "fmt"
  6. "wechat-api/ent"
  7. "wechat-api/ent/agent"
  8. "wechat-api/ent/agentbase"
  9. "wechat-api/ent/aliyunavatar"
  10. "wechat-api/ent/allocagent"
  11. "wechat-api/ent/batchmsg"
  12. "wechat-api/ent/category"
  13. "wechat-api/ent/chatrecords"
  14. "wechat-api/ent/chatsession"
  15. "wechat-api/ent/contact"
  16. "wechat-api/ent/creditbalance"
  17. "wechat-api/ent/creditusage"
  18. "wechat-api/ent/employee"
  19. "wechat-api/ent/employeeconfig"
  20. "wechat-api/ent/label"
  21. "wechat-api/ent/labelrelationship"
  22. "wechat-api/ent/labeltagging"
  23. "wechat-api/ent/message"
  24. "wechat-api/ent/messagerecords"
  25. "wechat-api/ent/msg"
  26. "wechat-api/ent/payrecharge"
  27. "wechat-api/ent/predicate"
  28. "wechat-api/ent/server"
  29. "wechat-api/ent/sopnode"
  30. "wechat-api/ent/sopstage"
  31. "wechat-api/ent/soptask"
  32. "wechat-api/ent/token"
  33. "wechat-api/ent/tutorial"
  34. "wechat-api/ent/usagedetail"
  35. "wechat-api/ent/usagestatisticday"
  36. "wechat-api/ent/usagestatistichour"
  37. "wechat-api/ent/usagestatisticmonth"
  38. "wechat-api/ent/usagetotal"
  39. "wechat-api/ent/whatsapp"
  40. "wechat-api/ent/workexperience"
  41. "wechat-api/ent/wpchatroom"
  42. "wechat-api/ent/wpchatroommember"
  43. "wechat-api/ent/wx"
  44. "wechat-api/ent/wxcard"
  45. "wechat-api/ent/wxcarduser"
  46. "wechat-api/ent/wxcardvisit"
  47. "entgo.io/ent/dialect/sql"
  48. )
  49. // The Query interface represents an operation that queries a graph.
  50. // By using this interface, users can write generic code that manipulates
  51. // query builders of different types.
  52. type Query interface {
  53. // Type returns the string representation of the query type.
  54. Type() string
  55. // Limit the number of records to be returned by this query.
  56. Limit(int)
  57. // Offset to start from.
  58. Offset(int)
  59. // Unique configures the query builder to filter duplicate records.
  60. Unique(bool)
  61. // Order specifies how the records should be ordered.
  62. Order(...func(*sql.Selector))
  63. // WhereP appends storage-level predicates to the query builder. Using this method, users
  64. // can use type-assertion to append predicates that do not depend on any generated package.
  65. WhereP(...func(*sql.Selector))
  66. }
  67. // The Func type is an adapter that allows ordinary functions to be used as interceptors.
  68. // Unlike traversal functions, interceptors are skipped during graph traversals. Note that the
  69. // implementation of Func is different from the one defined in entgo.io/ent.InterceptFunc.
  70. type Func func(context.Context, Query) error
  71. // Intercept calls f(ctx, q) and then applied the next Querier.
  72. func (f Func) Intercept(next ent.Querier) ent.Querier {
  73. return ent.QuerierFunc(func(ctx context.Context, q ent.Query) (ent.Value, error) {
  74. query, err := NewQuery(q)
  75. if err != nil {
  76. return nil, err
  77. }
  78. if err := f(ctx, query); err != nil {
  79. return nil, err
  80. }
  81. return next.Query(ctx, q)
  82. })
  83. }
  84. // The TraverseFunc type is an adapter to allow the use of ordinary function as Traverser.
  85. // If f is a function with the appropriate signature, TraverseFunc(f) is a Traverser that calls f.
  86. type TraverseFunc func(context.Context, Query) error
  87. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  88. func (f TraverseFunc) Intercept(next ent.Querier) ent.Querier {
  89. return next
  90. }
  91. // Traverse calls f(ctx, q).
  92. func (f TraverseFunc) Traverse(ctx context.Context, q ent.Query) error {
  93. query, err := NewQuery(q)
  94. if err != nil {
  95. return err
  96. }
  97. return f(ctx, query)
  98. }
  99. // The AgentFunc type is an adapter to allow the use of ordinary function as a Querier.
  100. type AgentFunc func(context.Context, *ent.AgentQuery) (ent.Value, error)
  101. // Query calls f(ctx, q).
  102. func (f AgentFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  103. if q, ok := q.(*ent.AgentQuery); ok {
  104. return f(ctx, q)
  105. }
  106. return nil, fmt.Errorf("unexpected query type %T. expect *ent.AgentQuery", q)
  107. }
  108. // The TraverseAgent type is an adapter to allow the use of ordinary function as Traverser.
  109. type TraverseAgent func(context.Context, *ent.AgentQuery) error
  110. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  111. func (f TraverseAgent) Intercept(next ent.Querier) ent.Querier {
  112. return next
  113. }
  114. // Traverse calls f(ctx, q).
  115. func (f TraverseAgent) Traverse(ctx context.Context, q ent.Query) error {
  116. if q, ok := q.(*ent.AgentQuery); ok {
  117. return f(ctx, q)
  118. }
  119. return fmt.Errorf("unexpected query type %T. expect *ent.AgentQuery", q)
  120. }
  121. // The AgentBaseFunc type is an adapter to allow the use of ordinary function as a Querier.
  122. type AgentBaseFunc func(context.Context, *ent.AgentBaseQuery) (ent.Value, error)
  123. // Query calls f(ctx, q).
  124. func (f AgentBaseFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  125. if q, ok := q.(*ent.AgentBaseQuery); ok {
  126. return f(ctx, q)
  127. }
  128. return nil, fmt.Errorf("unexpected query type %T. expect *ent.AgentBaseQuery", q)
  129. }
  130. // The TraverseAgentBase type is an adapter to allow the use of ordinary function as Traverser.
  131. type TraverseAgentBase func(context.Context, *ent.AgentBaseQuery) error
  132. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  133. func (f TraverseAgentBase) Intercept(next ent.Querier) ent.Querier {
  134. return next
  135. }
  136. // Traverse calls f(ctx, q).
  137. func (f TraverseAgentBase) Traverse(ctx context.Context, q ent.Query) error {
  138. if q, ok := q.(*ent.AgentBaseQuery); ok {
  139. return f(ctx, q)
  140. }
  141. return fmt.Errorf("unexpected query type %T. expect *ent.AgentBaseQuery", q)
  142. }
  143. // The AliyunAvatarFunc type is an adapter to allow the use of ordinary function as a Querier.
  144. type AliyunAvatarFunc func(context.Context, *ent.AliyunAvatarQuery) (ent.Value, error)
  145. // Query calls f(ctx, q).
  146. func (f AliyunAvatarFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  147. if q, ok := q.(*ent.AliyunAvatarQuery); ok {
  148. return f(ctx, q)
  149. }
  150. return nil, fmt.Errorf("unexpected query type %T. expect *ent.AliyunAvatarQuery", q)
  151. }
  152. // The TraverseAliyunAvatar type is an adapter to allow the use of ordinary function as Traverser.
  153. type TraverseAliyunAvatar func(context.Context, *ent.AliyunAvatarQuery) error
  154. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  155. func (f TraverseAliyunAvatar) Intercept(next ent.Querier) ent.Querier {
  156. return next
  157. }
  158. // Traverse calls f(ctx, q).
  159. func (f TraverseAliyunAvatar) Traverse(ctx context.Context, q ent.Query) error {
  160. if q, ok := q.(*ent.AliyunAvatarQuery); ok {
  161. return f(ctx, q)
  162. }
  163. return fmt.Errorf("unexpected query type %T. expect *ent.AliyunAvatarQuery", q)
  164. }
  165. // The AllocAgentFunc type is an adapter to allow the use of ordinary function as a Querier.
  166. type AllocAgentFunc func(context.Context, *ent.AllocAgentQuery) (ent.Value, error)
  167. // Query calls f(ctx, q).
  168. func (f AllocAgentFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  169. if q, ok := q.(*ent.AllocAgentQuery); ok {
  170. return f(ctx, q)
  171. }
  172. return nil, fmt.Errorf("unexpected query type %T. expect *ent.AllocAgentQuery", q)
  173. }
  174. // The TraverseAllocAgent type is an adapter to allow the use of ordinary function as Traverser.
  175. type TraverseAllocAgent func(context.Context, *ent.AllocAgentQuery) error
  176. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  177. func (f TraverseAllocAgent) Intercept(next ent.Querier) ent.Querier {
  178. return next
  179. }
  180. // Traverse calls f(ctx, q).
  181. func (f TraverseAllocAgent) Traverse(ctx context.Context, q ent.Query) error {
  182. if q, ok := q.(*ent.AllocAgentQuery); ok {
  183. return f(ctx, q)
  184. }
  185. return fmt.Errorf("unexpected query type %T. expect *ent.AllocAgentQuery", q)
  186. }
  187. // The BatchMsgFunc type is an adapter to allow the use of ordinary function as a Querier.
  188. type BatchMsgFunc func(context.Context, *ent.BatchMsgQuery) (ent.Value, error)
  189. // Query calls f(ctx, q).
  190. func (f BatchMsgFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  191. if q, ok := q.(*ent.BatchMsgQuery); ok {
  192. return f(ctx, q)
  193. }
  194. return nil, fmt.Errorf("unexpected query type %T. expect *ent.BatchMsgQuery", q)
  195. }
  196. // The TraverseBatchMsg type is an adapter to allow the use of ordinary function as Traverser.
  197. type TraverseBatchMsg func(context.Context, *ent.BatchMsgQuery) error
  198. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  199. func (f TraverseBatchMsg) Intercept(next ent.Querier) ent.Querier {
  200. return next
  201. }
  202. // Traverse calls f(ctx, q).
  203. func (f TraverseBatchMsg) Traverse(ctx context.Context, q ent.Query) error {
  204. if q, ok := q.(*ent.BatchMsgQuery); ok {
  205. return f(ctx, q)
  206. }
  207. return fmt.Errorf("unexpected query type %T. expect *ent.BatchMsgQuery", q)
  208. }
  209. // The CategoryFunc type is an adapter to allow the use of ordinary function as a Querier.
  210. type CategoryFunc func(context.Context, *ent.CategoryQuery) (ent.Value, error)
  211. // Query calls f(ctx, q).
  212. func (f CategoryFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  213. if q, ok := q.(*ent.CategoryQuery); ok {
  214. return f(ctx, q)
  215. }
  216. return nil, fmt.Errorf("unexpected query type %T. expect *ent.CategoryQuery", q)
  217. }
  218. // The TraverseCategory type is an adapter to allow the use of ordinary function as Traverser.
  219. type TraverseCategory func(context.Context, *ent.CategoryQuery) error
  220. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  221. func (f TraverseCategory) Intercept(next ent.Querier) ent.Querier {
  222. return next
  223. }
  224. // Traverse calls f(ctx, q).
  225. func (f TraverseCategory) Traverse(ctx context.Context, q ent.Query) error {
  226. if q, ok := q.(*ent.CategoryQuery); ok {
  227. return f(ctx, q)
  228. }
  229. return fmt.Errorf("unexpected query type %T. expect *ent.CategoryQuery", q)
  230. }
  231. // The ChatRecordsFunc type is an adapter to allow the use of ordinary function as a Querier.
  232. type ChatRecordsFunc func(context.Context, *ent.ChatRecordsQuery) (ent.Value, error)
  233. // Query calls f(ctx, q).
  234. func (f ChatRecordsFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  235. if q, ok := q.(*ent.ChatRecordsQuery); ok {
  236. return f(ctx, q)
  237. }
  238. return nil, fmt.Errorf("unexpected query type %T. expect *ent.ChatRecordsQuery", q)
  239. }
  240. // The TraverseChatRecords type is an adapter to allow the use of ordinary function as Traverser.
  241. type TraverseChatRecords func(context.Context, *ent.ChatRecordsQuery) error
  242. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  243. func (f TraverseChatRecords) Intercept(next ent.Querier) ent.Querier {
  244. return next
  245. }
  246. // Traverse calls f(ctx, q).
  247. func (f TraverseChatRecords) Traverse(ctx context.Context, q ent.Query) error {
  248. if q, ok := q.(*ent.ChatRecordsQuery); ok {
  249. return f(ctx, q)
  250. }
  251. return fmt.Errorf("unexpected query type %T. expect *ent.ChatRecordsQuery", q)
  252. }
  253. // The ChatSessionFunc type is an adapter to allow the use of ordinary function as a Querier.
  254. type ChatSessionFunc func(context.Context, *ent.ChatSessionQuery) (ent.Value, error)
  255. // Query calls f(ctx, q).
  256. func (f ChatSessionFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  257. if q, ok := q.(*ent.ChatSessionQuery); ok {
  258. return f(ctx, q)
  259. }
  260. return nil, fmt.Errorf("unexpected query type %T. expect *ent.ChatSessionQuery", q)
  261. }
  262. // The TraverseChatSession type is an adapter to allow the use of ordinary function as Traverser.
  263. type TraverseChatSession func(context.Context, *ent.ChatSessionQuery) error
  264. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  265. func (f TraverseChatSession) Intercept(next ent.Querier) ent.Querier {
  266. return next
  267. }
  268. // Traverse calls f(ctx, q).
  269. func (f TraverseChatSession) Traverse(ctx context.Context, q ent.Query) error {
  270. if q, ok := q.(*ent.ChatSessionQuery); ok {
  271. return f(ctx, q)
  272. }
  273. return fmt.Errorf("unexpected query type %T. expect *ent.ChatSessionQuery", q)
  274. }
  275. // The ContactFunc type is an adapter to allow the use of ordinary function as a Querier.
  276. type ContactFunc func(context.Context, *ent.ContactQuery) (ent.Value, error)
  277. // Query calls f(ctx, q).
  278. func (f ContactFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  279. if q, ok := q.(*ent.ContactQuery); ok {
  280. return f(ctx, q)
  281. }
  282. return nil, fmt.Errorf("unexpected query type %T. expect *ent.ContactQuery", q)
  283. }
  284. // The TraverseContact type is an adapter to allow the use of ordinary function as Traverser.
  285. type TraverseContact func(context.Context, *ent.ContactQuery) error
  286. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  287. func (f TraverseContact) Intercept(next ent.Querier) ent.Querier {
  288. return next
  289. }
  290. // Traverse calls f(ctx, q).
  291. func (f TraverseContact) Traverse(ctx context.Context, q ent.Query) error {
  292. if q, ok := q.(*ent.ContactQuery); ok {
  293. return f(ctx, q)
  294. }
  295. return fmt.Errorf("unexpected query type %T. expect *ent.ContactQuery", q)
  296. }
  297. // The CreditBalanceFunc type is an adapter to allow the use of ordinary function as a Querier.
  298. type CreditBalanceFunc func(context.Context, *ent.CreditBalanceQuery) (ent.Value, error)
  299. // Query calls f(ctx, q).
  300. func (f CreditBalanceFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  301. if q, ok := q.(*ent.CreditBalanceQuery); ok {
  302. return f(ctx, q)
  303. }
  304. return nil, fmt.Errorf("unexpected query type %T. expect *ent.CreditBalanceQuery", q)
  305. }
  306. // The TraverseCreditBalance type is an adapter to allow the use of ordinary function as Traverser.
  307. type TraverseCreditBalance func(context.Context, *ent.CreditBalanceQuery) error
  308. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  309. func (f TraverseCreditBalance) Intercept(next ent.Querier) ent.Querier {
  310. return next
  311. }
  312. // Traverse calls f(ctx, q).
  313. func (f TraverseCreditBalance) Traverse(ctx context.Context, q ent.Query) error {
  314. if q, ok := q.(*ent.CreditBalanceQuery); ok {
  315. return f(ctx, q)
  316. }
  317. return fmt.Errorf("unexpected query type %T. expect *ent.CreditBalanceQuery", q)
  318. }
  319. // The CreditUsageFunc type is an adapter to allow the use of ordinary function as a Querier.
  320. type CreditUsageFunc func(context.Context, *ent.CreditUsageQuery) (ent.Value, error)
  321. // Query calls f(ctx, q).
  322. func (f CreditUsageFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  323. if q, ok := q.(*ent.CreditUsageQuery); ok {
  324. return f(ctx, q)
  325. }
  326. return nil, fmt.Errorf("unexpected query type %T. expect *ent.CreditUsageQuery", q)
  327. }
  328. // The TraverseCreditUsage type is an adapter to allow the use of ordinary function as Traverser.
  329. type TraverseCreditUsage func(context.Context, *ent.CreditUsageQuery) error
  330. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  331. func (f TraverseCreditUsage) Intercept(next ent.Querier) ent.Querier {
  332. return next
  333. }
  334. // Traverse calls f(ctx, q).
  335. func (f TraverseCreditUsage) Traverse(ctx context.Context, q ent.Query) error {
  336. if q, ok := q.(*ent.CreditUsageQuery); ok {
  337. return f(ctx, q)
  338. }
  339. return fmt.Errorf("unexpected query type %T. expect *ent.CreditUsageQuery", q)
  340. }
  341. // The EmployeeFunc type is an adapter to allow the use of ordinary function as a Querier.
  342. type EmployeeFunc func(context.Context, *ent.EmployeeQuery) (ent.Value, error)
  343. // Query calls f(ctx, q).
  344. func (f EmployeeFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  345. if q, ok := q.(*ent.EmployeeQuery); ok {
  346. return f(ctx, q)
  347. }
  348. return nil, fmt.Errorf("unexpected query type %T. expect *ent.EmployeeQuery", q)
  349. }
  350. // The TraverseEmployee type is an adapter to allow the use of ordinary function as Traverser.
  351. type TraverseEmployee func(context.Context, *ent.EmployeeQuery) error
  352. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  353. func (f TraverseEmployee) Intercept(next ent.Querier) ent.Querier {
  354. return next
  355. }
  356. // Traverse calls f(ctx, q).
  357. func (f TraverseEmployee) Traverse(ctx context.Context, q ent.Query) error {
  358. if q, ok := q.(*ent.EmployeeQuery); ok {
  359. return f(ctx, q)
  360. }
  361. return fmt.Errorf("unexpected query type %T. expect *ent.EmployeeQuery", q)
  362. }
  363. // The EmployeeConfigFunc type is an adapter to allow the use of ordinary function as a Querier.
  364. type EmployeeConfigFunc func(context.Context, *ent.EmployeeConfigQuery) (ent.Value, error)
  365. // Query calls f(ctx, q).
  366. func (f EmployeeConfigFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  367. if q, ok := q.(*ent.EmployeeConfigQuery); ok {
  368. return f(ctx, q)
  369. }
  370. return nil, fmt.Errorf("unexpected query type %T. expect *ent.EmployeeConfigQuery", q)
  371. }
  372. // The TraverseEmployeeConfig type is an adapter to allow the use of ordinary function as Traverser.
  373. type TraverseEmployeeConfig func(context.Context, *ent.EmployeeConfigQuery) error
  374. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  375. func (f TraverseEmployeeConfig) Intercept(next ent.Querier) ent.Querier {
  376. return next
  377. }
  378. // Traverse calls f(ctx, q).
  379. func (f TraverseEmployeeConfig) Traverse(ctx context.Context, q ent.Query) error {
  380. if q, ok := q.(*ent.EmployeeConfigQuery); ok {
  381. return f(ctx, q)
  382. }
  383. return fmt.Errorf("unexpected query type %T. expect *ent.EmployeeConfigQuery", q)
  384. }
  385. // The LabelFunc type is an adapter to allow the use of ordinary function as a Querier.
  386. type LabelFunc func(context.Context, *ent.LabelQuery) (ent.Value, error)
  387. // Query calls f(ctx, q).
  388. func (f LabelFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  389. if q, ok := q.(*ent.LabelQuery); ok {
  390. return f(ctx, q)
  391. }
  392. return nil, fmt.Errorf("unexpected query type %T. expect *ent.LabelQuery", q)
  393. }
  394. // The TraverseLabel type is an adapter to allow the use of ordinary function as Traverser.
  395. type TraverseLabel func(context.Context, *ent.LabelQuery) error
  396. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  397. func (f TraverseLabel) Intercept(next ent.Querier) ent.Querier {
  398. return next
  399. }
  400. // Traverse calls f(ctx, q).
  401. func (f TraverseLabel) Traverse(ctx context.Context, q ent.Query) error {
  402. if q, ok := q.(*ent.LabelQuery); ok {
  403. return f(ctx, q)
  404. }
  405. return fmt.Errorf("unexpected query type %T. expect *ent.LabelQuery", q)
  406. }
  407. // The LabelRelationshipFunc type is an adapter to allow the use of ordinary function as a Querier.
  408. type LabelRelationshipFunc func(context.Context, *ent.LabelRelationshipQuery) (ent.Value, error)
  409. // Query calls f(ctx, q).
  410. func (f LabelRelationshipFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  411. if q, ok := q.(*ent.LabelRelationshipQuery); ok {
  412. return f(ctx, q)
  413. }
  414. return nil, fmt.Errorf("unexpected query type %T. expect *ent.LabelRelationshipQuery", q)
  415. }
  416. // The TraverseLabelRelationship type is an adapter to allow the use of ordinary function as Traverser.
  417. type TraverseLabelRelationship func(context.Context, *ent.LabelRelationshipQuery) error
  418. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  419. func (f TraverseLabelRelationship) Intercept(next ent.Querier) ent.Querier {
  420. return next
  421. }
  422. // Traverse calls f(ctx, q).
  423. func (f TraverseLabelRelationship) Traverse(ctx context.Context, q ent.Query) error {
  424. if q, ok := q.(*ent.LabelRelationshipQuery); ok {
  425. return f(ctx, q)
  426. }
  427. return fmt.Errorf("unexpected query type %T. expect *ent.LabelRelationshipQuery", q)
  428. }
  429. // The LabelTaggingFunc type is an adapter to allow the use of ordinary function as a Querier.
  430. type LabelTaggingFunc func(context.Context, *ent.LabelTaggingQuery) (ent.Value, error)
  431. // Query calls f(ctx, q).
  432. func (f LabelTaggingFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  433. if q, ok := q.(*ent.LabelTaggingQuery); ok {
  434. return f(ctx, q)
  435. }
  436. return nil, fmt.Errorf("unexpected query type %T. expect *ent.LabelTaggingQuery", q)
  437. }
  438. // The TraverseLabelTagging type is an adapter to allow the use of ordinary function as Traverser.
  439. type TraverseLabelTagging func(context.Context, *ent.LabelTaggingQuery) error
  440. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  441. func (f TraverseLabelTagging) Intercept(next ent.Querier) ent.Querier {
  442. return next
  443. }
  444. // Traverse calls f(ctx, q).
  445. func (f TraverseLabelTagging) Traverse(ctx context.Context, q ent.Query) error {
  446. if q, ok := q.(*ent.LabelTaggingQuery); ok {
  447. return f(ctx, q)
  448. }
  449. return fmt.Errorf("unexpected query type %T. expect *ent.LabelTaggingQuery", q)
  450. }
  451. // The MessageFunc type is an adapter to allow the use of ordinary function as a Querier.
  452. type MessageFunc func(context.Context, *ent.MessageQuery) (ent.Value, error)
  453. // Query calls f(ctx, q).
  454. func (f MessageFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  455. if q, ok := q.(*ent.MessageQuery); ok {
  456. return f(ctx, q)
  457. }
  458. return nil, fmt.Errorf("unexpected query type %T. expect *ent.MessageQuery", q)
  459. }
  460. // The TraverseMessage type is an adapter to allow the use of ordinary function as Traverser.
  461. type TraverseMessage func(context.Context, *ent.MessageQuery) error
  462. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  463. func (f TraverseMessage) Intercept(next ent.Querier) ent.Querier {
  464. return next
  465. }
  466. // Traverse calls f(ctx, q).
  467. func (f TraverseMessage) Traverse(ctx context.Context, q ent.Query) error {
  468. if q, ok := q.(*ent.MessageQuery); ok {
  469. return f(ctx, q)
  470. }
  471. return fmt.Errorf("unexpected query type %T. expect *ent.MessageQuery", q)
  472. }
  473. // The MessageRecordsFunc type is an adapter to allow the use of ordinary function as a Querier.
  474. type MessageRecordsFunc func(context.Context, *ent.MessageRecordsQuery) (ent.Value, error)
  475. // Query calls f(ctx, q).
  476. func (f MessageRecordsFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  477. if q, ok := q.(*ent.MessageRecordsQuery); ok {
  478. return f(ctx, q)
  479. }
  480. return nil, fmt.Errorf("unexpected query type %T. expect *ent.MessageRecordsQuery", q)
  481. }
  482. // The TraverseMessageRecords type is an adapter to allow the use of ordinary function as Traverser.
  483. type TraverseMessageRecords func(context.Context, *ent.MessageRecordsQuery) error
  484. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  485. func (f TraverseMessageRecords) Intercept(next ent.Querier) ent.Querier {
  486. return next
  487. }
  488. // Traverse calls f(ctx, q).
  489. func (f TraverseMessageRecords) Traverse(ctx context.Context, q ent.Query) error {
  490. if q, ok := q.(*ent.MessageRecordsQuery); ok {
  491. return f(ctx, q)
  492. }
  493. return fmt.Errorf("unexpected query type %T. expect *ent.MessageRecordsQuery", q)
  494. }
  495. // The MsgFunc type is an adapter to allow the use of ordinary function as a Querier.
  496. type MsgFunc func(context.Context, *ent.MsgQuery) (ent.Value, error)
  497. // Query calls f(ctx, q).
  498. func (f MsgFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  499. if q, ok := q.(*ent.MsgQuery); ok {
  500. return f(ctx, q)
  501. }
  502. return nil, fmt.Errorf("unexpected query type %T. expect *ent.MsgQuery", q)
  503. }
  504. // The TraverseMsg type is an adapter to allow the use of ordinary function as Traverser.
  505. type TraverseMsg func(context.Context, *ent.MsgQuery) error
  506. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  507. func (f TraverseMsg) Intercept(next ent.Querier) ent.Querier {
  508. return next
  509. }
  510. // Traverse calls f(ctx, q).
  511. func (f TraverseMsg) Traverse(ctx context.Context, q ent.Query) error {
  512. if q, ok := q.(*ent.MsgQuery); ok {
  513. return f(ctx, q)
  514. }
  515. return fmt.Errorf("unexpected query type %T. expect *ent.MsgQuery", q)
  516. }
  517. // The PayRechargeFunc type is an adapter to allow the use of ordinary function as a Querier.
  518. type PayRechargeFunc func(context.Context, *ent.PayRechargeQuery) (ent.Value, error)
  519. // Query calls f(ctx, q).
  520. func (f PayRechargeFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  521. if q, ok := q.(*ent.PayRechargeQuery); ok {
  522. return f(ctx, q)
  523. }
  524. return nil, fmt.Errorf("unexpected query type %T. expect *ent.PayRechargeQuery", q)
  525. }
  526. // The TraversePayRecharge type is an adapter to allow the use of ordinary function as Traverser.
  527. type TraversePayRecharge func(context.Context, *ent.PayRechargeQuery) error
  528. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  529. func (f TraversePayRecharge) Intercept(next ent.Querier) ent.Querier {
  530. return next
  531. }
  532. // Traverse calls f(ctx, q).
  533. func (f TraversePayRecharge) Traverse(ctx context.Context, q ent.Query) error {
  534. if q, ok := q.(*ent.PayRechargeQuery); ok {
  535. return f(ctx, q)
  536. }
  537. return fmt.Errorf("unexpected query type %T. expect *ent.PayRechargeQuery", q)
  538. }
  539. // The ServerFunc type is an adapter to allow the use of ordinary function as a Querier.
  540. type ServerFunc func(context.Context, *ent.ServerQuery) (ent.Value, error)
  541. // Query calls f(ctx, q).
  542. func (f ServerFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  543. if q, ok := q.(*ent.ServerQuery); ok {
  544. return f(ctx, q)
  545. }
  546. return nil, fmt.Errorf("unexpected query type %T. expect *ent.ServerQuery", q)
  547. }
  548. // The TraverseServer type is an adapter to allow the use of ordinary function as Traverser.
  549. type TraverseServer func(context.Context, *ent.ServerQuery) error
  550. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  551. func (f TraverseServer) Intercept(next ent.Querier) ent.Querier {
  552. return next
  553. }
  554. // Traverse calls f(ctx, q).
  555. func (f TraverseServer) Traverse(ctx context.Context, q ent.Query) error {
  556. if q, ok := q.(*ent.ServerQuery); ok {
  557. return f(ctx, q)
  558. }
  559. return fmt.Errorf("unexpected query type %T. expect *ent.ServerQuery", q)
  560. }
  561. // The SopNodeFunc type is an adapter to allow the use of ordinary function as a Querier.
  562. type SopNodeFunc func(context.Context, *ent.SopNodeQuery) (ent.Value, error)
  563. // Query calls f(ctx, q).
  564. func (f SopNodeFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  565. if q, ok := q.(*ent.SopNodeQuery); ok {
  566. return f(ctx, q)
  567. }
  568. return nil, fmt.Errorf("unexpected query type %T. expect *ent.SopNodeQuery", q)
  569. }
  570. // The TraverseSopNode type is an adapter to allow the use of ordinary function as Traverser.
  571. type TraverseSopNode func(context.Context, *ent.SopNodeQuery) error
  572. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  573. func (f TraverseSopNode) Intercept(next ent.Querier) ent.Querier {
  574. return next
  575. }
  576. // Traverse calls f(ctx, q).
  577. func (f TraverseSopNode) Traverse(ctx context.Context, q ent.Query) error {
  578. if q, ok := q.(*ent.SopNodeQuery); ok {
  579. return f(ctx, q)
  580. }
  581. return fmt.Errorf("unexpected query type %T. expect *ent.SopNodeQuery", q)
  582. }
  583. // The SopStageFunc type is an adapter to allow the use of ordinary function as a Querier.
  584. type SopStageFunc func(context.Context, *ent.SopStageQuery) (ent.Value, error)
  585. // Query calls f(ctx, q).
  586. func (f SopStageFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  587. if q, ok := q.(*ent.SopStageQuery); ok {
  588. return f(ctx, q)
  589. }
  590. return nil, fmt.Errorf("unexpected query type %T. expect *ent.SopStageQuery", q)
  591. }
  592. // The TraverseSopStage type is an adapter to allow the use of ordinary function as Traverser.
  593. type TraverseSopStage func(context.Context, *ent.SopStageQuery) error
  594. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  595. func (f TraverseSopStage) Intercept(next ent.Querier) ent.Querier {
  596. return next
  597. }
  598. // Traverse calls f(ctx, q).
  599. func (f TraverseSopStage) Traverse(ctx context.Context, q ent.Query) error {
  600. if q, ok := q.(*ent.SopStageQuery); ok {
  601. return f(ctx, q)
  602. }
  603. return fmt.Errorf("unexpected query type %T. expect *ent.SopStageQuery", q)
  604. }
  605. // The SopTaskFunc type is an adapter to allow the use of ordinary function as a Querier.
  606. type SopTaskFunc func(context.Context, *ent.SopTaskQuery) (ent.Value, error)
  607. // Query calls f(ctx, q).
  608. func (f SopTaskFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  609. if q, ok := q.(*ent.SopTaskQuery); ok {
  610. return f(ctx, q)
  611. }
  612. return nil, fmt.Errorf("unexpected query type %T. expect *ent.SopTaskQuery", q)
  613. }
  614. // The TraverseSopTask type is an adapter to allow the use of ordinary function as Traverser.
  615. type TraverseSopTask func(context.Context, *ent.SopTaskQuery) error
  616. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  617. func (f TraverseSopTask) Intercept(next ent.Querier) ent.Querier {
  618. return next
  619. }
  620. // Traverse calls f(ctx, q).
  621. func (f TraverseSopTask) Traverse(ctx context.Context, q ent.Query) error {
  622. if q, ok := q.(*ent.SopTaskQuery); ok {
  623. return f(ctx, q)
  624. }
  625. return fmt.Errorf("unexpected query type %T. expect *ent.SopTaskQuery", q)
  626. }
  627. // The TokenFunc type is an adapter to allow the use of ordinary function as a Querier.
  628. type TokenFunc func(context.Context, *ent.TokenQuery) (ent.Value, error)
  629. // Query calls f(ctx, q).
  630. func (f TokenFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  631. if q, ok := q.(*ent.TokenQuery); ok {
  632. return f(ctx, q)
  633. }
  634. return nil, fmt.Errorf("unexpected query type %T. expect *ent.TokenQuery", q)
  635. }
  636. // The TraverseToken type is an adapter to allow the use of ordinary function as Traverser.
  637. type TraverseToken func(context.Context, *ent.TokenQuery) error
  638. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  639. func (f TraverseToken) Intercept(next ent.Querier) ent.Querier {
  640. return next
  641. }
  642. // Traverse calls f(ctx, q).
  643. func (f TraverseToken) Traverse(ctx context.Context, q ent.Query) error {
  644. if q, ok := q.(*ent.TokenQuery); ok {
  645. return f(ctx, q)
  646. }
  647. return fmt.Errorf("unexpected query type %T. expect *ent.TokenQuery", q)
  648. }
  649. // The TutorialFunc type is an adapter to allow the use of ordinary function as a Querier.
  650. type TutorialFunc func(context.Context, *ent.TutorialQuery) (ent.Value, error)
  651. // Query calls f(ctx, q).
  652. func (f TutorialFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  653. if q, ok := q.(*ent.TutorialQuery); ok {
  654. return f(ctx, q)
  655. }
  656. return nil, fmt.Errorf("unexpected query type %T. expect *ent.TutorialQuery", q)
  657. }
  658. // The TraverseTutorial type is an adapter to allow the use of ordinary function as Traverser.
  659. type TraverseTutorial func(context.Context, *ent.TutorialQuery) error
  660. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  661. func (f TraverseTutorial) Intercept(next ent.Querier) ent.Querier {
  662. return next
  663. }
  664. // Traverse calls f(ctx, q).
  665. func (f TraverseTutorial) Traverse(ctx context.Context, q ent.Query) error {
  666. if q, ok := q.(*ent.TutorialQuery); ok {
  667. return f(ctx, q)
  668. }
  669. return fmt.Errorf("unexpected query type %T. expect *ent.TutorialQuery", q)
  670. }
  671. // The UsageDetailFunc type is an adapter to allow the use of ordinary function as a Querier.
  672. type UsageDetailFunc func(context.Context, *ent.UsageDetailQuery) (ent.Value, error)
  673. // Query calls f(ctx, q).
  674. func (f UsageDetailFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  675. if q, ok := q.(*ent.UsageDetailQuery); ok {
  676. return f(ctx, q)
  677. }
  678. return nil, fmt.Errorf("unexpected query type %T. expect *ent.UsageDetailQuery", q)
  679. }
  680. // The TraverseUsageDetail type is an adapter to allow the use of ordinary function as Traverser.
  681. type TraverseUsageDetail func(context.Context, *ent.UsageDetailQuery) error
  682. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  683. func (f TraverseUsageDetail) Intercept(next ent.Querier) ent.Querier {
  684. return next
  685. }
  686. // Traverse calls f(ctx, q).
  687. func (f TraverseUsageDetail) Traverse(ctx context.Context, q ent.Query) error {
  688. if q, ok := q.(*ent.UsageDetailQuery); ok {
  689. return f(ctx, q)
  690. }
  691. return fmt.Errorf("unexpected query type %T. expect *ent.UsageDetailQuery", q)
  692. }
  693. // The UsageStatisticDayFunc type is an adapter to allow the use of ordinary function as a Querier.
  694. type UsageStatisticDayFunc func(context.Context, *ent.UsageStatisticDayQuery) (ent.Value, error)
  695. // Query calls f(ctx, q).
  696. func (f UsageStatisticDayFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  697. if q, ok := q.(*ent.UsageStatisticDayQuery); ok {
  698. return f(ctx, q)
  699. }
  700. return nil, fmt.Errorf("unexpected query type %T. expect *ent.UsageStatisticDayQuery", q)
  701. }
  702. // The TraverseUsageStatisticDay type is an adapter to allow the use of ordinary function as Traverser.
  703. type TraverseUsageStatisticDay func(context.Context, *ent.UsageStatisticDayQuery) error
  704. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  705. func (f TraverseUsageStatisticDay) Intercept(next ent.Querier) ent.Querier {
  706. return next
  707. }
  708. // Traverse calls f(ctx, q).
  709. func (f TraverseUsageStatisticDay) Traverse(ctx context.Context, q ent.Query) error {
  710. if q, ok := q.(*ent.UsageStatisticDayQuery); ok {
  711. return f(ctx, q)
  712. }
  713. return fmt.Errorf("unexpected query type %T. expect *ent.UsageStatisticDayQuery", q)
  714. }
  715. // The UsageStatisticHourFunc type is an adapter to allow the use of ordinary function as a Querier.
  716. type UsageStatisticHourFunc func(context.Context, *ent.UsageStatisticHourQuery) (ent.Value, error)
  717. // Query calls f(ctx, q).
  718. func (f UsageStatisticHourFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  719. if q, ok := q.(*ent.UsageStatisticHourQuery); ok {
  720. return f(ctx, q)
  721. }
  722. return nil, fmt.Errorf("unexpected query type %T. expect *ent.UsageStatisticHourQuery", q)
  723. }
  724. // The TraverseUsageStatisticHour type is an adapter to allow the use of ordinary function as Traverser.
  725. type TraverseUsageStatisticHour func(context.Context, *ent.UsageStatisticHourQuery) error
  726. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  727. func (f TraverseUsageStatisticHour) Intercept(next ent.Querier) ent.Querier {
  728. return next
  729. }
  730. // Traverse calls f(ctx, q).
  731. func (f TraverseUsageStatisticHour) Traverse(ctx context.Context, q ent.Query) error {
  732. if q, ok := q.(*ent.UsageStatisticHourQuery); ok {
  733. return f(ctx, q)
  734. }
  735. return fmt.Errorf("unexpected query type %T. expect *ent.UsageStatisticHourQuery", q)
  736. }
  737. // The UsageStatisticMonthFunc type is an adapter to allow the use of ordinary function as a Querier.
  738. type UsageStatisticMonthFunc func(context.Context, *ent.UsageStatisticMonthQuery) (ent.Value, error)
  739. // Query calls f(ctx, q).
  740. func (f UsageStatisticMonthFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  741. if q, ok := q.(*ent.UsageStatisticMonthQuery); ok {
  742. return f(ctx, q)
  743. }
  744. return nil, fmt.Errorf("unexpected query type %T. expect *ent.UsageStatisticMonthQuery", q)
  745. }
  746. // The TraverseUsageStatisticMonth type is an adapter to allow the use of ordinary function as Traverser.
  747. type TraverseUsageStatisticMonth func(context.Context, *ent.UsageStatisticMonthQuery) error
  748. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  749. func (f TraverseUsageStatisticMonth) Intercept(next ent.Querier) ent.Querier {
  750. return next
  751. }
  752. // Traverse calls f(ctx, q).
  753. func (f TraverseUsageStatisticMonth) Traverse(ctx context.Context, q ent.Query) error {
  754. if q, ok := q.(*ent.UsageStatisticMonthQuery); ok {
  755. return f(ctx, q)
  756. }
  757. return fmt.Errorf("unexpected query type %T. expect *ent.UsageStatisticMonthQuery", q)
  758. }
  759. // The UsageTotalFunc type is an adapter to allow the use of ordinary function as a Querier.
  760. type UsageTotalFunc func(context.Context, *ent.UsageTotalQuery) (ent.Value, error)
  761. // Query calls f(ctx, q).
  762. func (f UsageTotalFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  763. if q, ok := q.(*ent.UsageTotalQuery); ok {
  764. return f(ctx, q)
  765. }
  766. return nil, fmt.Errorf("unexpected query type %T. expect *ent.UsageTotalQuery", q)
  767. }
  768. // The TraverseUsageTotal type is an adapter to allow the use of ordinary function as Traverser.
  769. type TraverseUsageTotal func(context.Context, *ent.UsageTotalQuery) error
  770. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  771. func (f TraverseUsageTotal) Intercept(next ent.Querier) ent.Querier {
  772. return next
  773. }
  774. // Traverse calls f(ctx, q).
  775. func (f TraverseUsageTotal) Traverse(ctx context.Context, q ent.Query) error {
  776. if q, ok := q.(*ent.UsageTotalQuery); ok {
  777. return f(ctx, q)
  778. }
  779. return fmt.Errorf("unexpected query type %T. expect *ent.UsageTotalQuery", q)
  780. }
  781. // The WhatsappFunc type is an adapter to allow the use of ordinary function as a Querier.
  782. type WhatsappFunc func(context.Context, *ent.WhatsappQuery) (ent.Value, error)
  783. // Query calls f(ctx, q).
  784. func (f WhatsappFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  785. if q, ok := q.(*ent.WhatsappQuery); ok {
  786. return f(ctx, q)
  787. }
  788. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WhatsappQuery", q)
  789. }
  790. // The TraverseWhatsapp type is an adapter to allow the use of ordinary function as Traverser.
  791. type TraverseWhatsapp func(context.Context, *ent.WhatsappQuery) error
  792. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  793. func (f TraverseWhatsapp) Intercept(next ent.Querier) ent.Querier {
  794. return next
  795. }
  796. // Traverse calls f(ctx, q).
  797. func (f TraverseWhatsapp) Traverse(ctx context.Context, q ent.Query) error {
  798. if q, ok := q.(*ent.WhatsappQuery); ok {
  799. return f(ctx, q)
  800. }
  801. return fmt.Errorf("unexpected query type %T. expect *ent.WhatsappQuery", q)
  802. }
  803. // The WorkExperienceFunc type is an adapter to allow the use of ordinary function as a Querier.
  804. type WorkExperienceFunc func(context.Context, *ent.WorkExperienceQuery) (ent.Value, error)
  805. // Query calls f(ctx, q).
  806. func (f WorkExperienceFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  807. if q, ok := q.(*ent.WorkExperienceQuery); ok {
  808. return f(ctx, q)
  809. }
  810. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WorkExperienceQuery", q)
  811. }
  812. // The TraverseWorkExperience type is an adapter to allow the use of ordinary function as Traverser.
  813. type TraverseWorkExperience func(context.Context, *ent.WorkExperienceQuery) error
  814. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  815. func (f TraverseWorkExperience) Intercept(next ent.Querier) ent.Querier {
  816. return next
  817. }
  818. // Traverse calls f(ctx, q).
  819. func (f TraverseWorkExperience) Traverse(ctx context.Context, q ent.Query) error {
  820. if q, ok := q.(*ent.WorkExperienceQuery); ok {
  821. return f(ctx, q)
  822. }
  823. return fmt.Errorf("unexpected query type %T. expect *ent.WorkExperienceQuery", q)
  824. }
  825. // The WpChatroomFunc type is an adapter to allow the use of ordinary function as a Querier.
  826. type WpChatroomFunc func(context.Context, *ent.WpChatroomQuery) (ent.Value, error)
  827. // Query calls f(ctx, q).
  828. func (f WpChatroomFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  829. if q, ok := q.(*ent.WpChatroomQuery); ok {
  830. return f(ctx, q)
  831. }
  832. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WpChatroomQuery", q)
  833. }
  834. // The TraverseWpChatroom type is an adapter to allow the use of ordinary function as Traverser.
  835. type TraverseWpChatroom func(context.Context, *ent.WpChatroomQuery) error
  836. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  837. func (f TraverseWpChatroom) Intercept(next ent.Querier) ent.Querier {
  838. return next
  839. }
  840. // Traverse calls f(ctx, q).
  841. func (f TraverseWpChatroom) Traverse(ctx context.Context, q ent.Query) error {
  842. if q, ok := q.(*ent.WpChatroomQuery); ok {
  843. return f(ctx, q)
  844. }
  845. return fmt.Errorf("unexpected query type %T. expect *ent.WpChatroomQuery", q)
  846. }
  847. // The WpChatroomMemberFunc type is an adapter to allow the use of ordinary function as a Querier.
  848. type WpChatroomMemberFunc func(context.Context, *ent.WpChatroomMemberQuery) (ent.Value, error)
  849. // Query calls f(ctx, q).
  850. func (f WpChatroomMemberFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  851. if q, ok := q.(*ent.WpChatroomMemberQuery); ok {
  852. return f(ctx, q)
  853. }
  854. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WpChatroomMemberQuery", q)
  855. }
  856. // The TraverseWpChatroomMember type is an adapter to allow the use of ordinary function as Traverser.
  857. type TraverseWpChatroomMember func(context.Context, *ent.WpChatroomMemberQuery) error
  858. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  859. func (f TraverseWpChatroomMember) Intercept(next ent.Querier) ent.Querier {
  860. return next
  861. }
  862. // Traverse calls f(ctx, q).
  863. func (f TraverseWpChatroomMember) Traverse(ctx context.Context, q ent.Query) error {
  864. if q, ok := q.(*ent.WpChatroomMemberQuery); ok {
  865. return f(ctx, q)
  866. }
  867. return fmt.Errorf("unexpected query type %T. expect *ent.WpChatroomMemberQuery", q)
  868. }
  869. // The WxFunc type is an adapter to allow the use of ordinary function as a Querier.
  870. type WxFunc func(context.Context, *ent.WxQuery) (ent.Value, error)
  871. // Query calls f(ctx, q).
  872. func (f WxFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  873. if q, ok := q.(*ent.WxQuery); ok {
  874. return f(ctx, q)
  875. }
  876. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WxQuery", q)
  877. }
  878. // The TraverseWx type is an adapter to allow the use of ordinary function as Traverser.
  879. type TraverseWx func(context.Context, *ent.WxQuery) error
  880. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  881. func (f TraverseWx) Intercept(next ent.Querier) ent.Querier {
  882. return next
  883. }
  884. // Traverse calls f(ctx, q).
  885. func (f TraverseWx) Traverse(ctx context.Context, q ent.Query) error {
  886. if q, ok := q.(*ent.WxQuery); ok {
  887. return f(ctx, q)
  888. }
  889. return fmt.Errorf("unexpected query type %T. expect *ent.WxQuery", q)
  890. }
  891. // The WxCardFunc type is an adapter to allow the use of ordinary function as a Querier.
  892. type WxCardFunc func(context.Context, *ent.WxCardQuery) (ent.Value, error)
  893. // Query calls f(ctx, q).
  894. func (f WxCardFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  895. if q, ok := q.(*ent.WxCardQuery); ok {
  896. return f(ctx, q)
  897. }
  898. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WxCardQuery", q)
  899. }
  900. // The TraverseWxCard type is an adapter to allow the use of ordinary function as Traverser.
  901. type TraverseWxCard func(context.Context, *ent.WxCardQuery) error
  902. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  903. func (f TraverseWxCard) Intercept(next ent.Querier) ent.Querier {
  904. return next
  905. }
  906. // Traverse calls f(ctx, q).
  907. func (f TraverseWxCard) Traverse(ctx context.Context, q ent.Query) error {
  908. if q, ok := q.(*ent.WxCardQuery); ok {
  909. return f(ctx, q)
  910. }
  911. return fmt.Errorf("unexpected query type %T. expect *ent.WxCardQuery", q)
  912. }
  913. // The WxCardUserFunc type is an adapter to allow the use of ordinary function as a Querier.
  914. type WxCardUserFunc func(context.Context, *ent.WxCardUserQuery) (ent.Value, error)
  915. // Query calls f(ctx, q).
  916. func (f WxCardUserFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  917. if q, ok := q.(*ent.WxCardUserQuery); ok {
  918. return f(ctx, q)
  919. }
  920. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WxCardUserQuery", q)
  921. }
  922. // The TraverseWxCardUser type is an adapter to allow the use of ordinary function as Traverser.
  923. type TraverseWxCardUser func(context.Context, *ent.WxCardUserQuery) error
  924. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  925. func (f TraverseWxCardUser) Intercept(next ent.Querier) ent.Querier {
  926. return next
  927. }
  928. // Traverse calls f(ctx, q).
  929. func (f TraverseWxCardUser) Traverse(ctx context.Context, q ent.Query) error {
  930. if q, ok := q.(*ent.WxCardUserQuery); ok {
  931. return f(ctx, q)
  932. }
  933. return fmt.Errorf("unexpected query type %T. expect *ent.WxCardUserQuery", q)
  934. }
  935. // The WxCardVisitFunc type is an adapter to allow the use of ordinary function as a Querier.
  936. type WxCardVisitFunc func(context.Context, *ent.WxCardVisitQuery) (ent.Value, error)
  937. // Query calls f(ctx, q).
  938. func (f WxCardVisitFunc) Query(ctx context.Context, q ent.Query) (ent.Value, error) {
  939. if q, ok := q.(*ent.WxCardVisitQuery); ok {
  940. return f(ctx, q)
  941. }
  942. return nil, fmt.Errorf("unexpected query type %T. expect *ent.WxCardVisitQuery", q)
  943. }
  944. // The TraverseWxCardVisit type is an adapter to allow the use of ordinary function as Traverser.
  945. type TraverseWxCardVisit func(context.Context, *ent.WxCardVisitQuery) error
  946. // Intercept is a dummy implementation of Intercept that returns the next Querier in the pipeline.
  947. func (f TraverseWxCardVisit) Intercept(next ent.Querier) ent.Querier {
  948. return next
  949. }
  950. // Traverse calls f(ctx, q).
  951. func (f TraverseWxCardVisit) Traverse(ctx context.Context, q ent.Query) error {
  952. if q, ok := q.(*ent.WxCardVisitQuery); ok {
  953. return f(ctx, q)
  954. }
  955. return fmt.Errorf("unexpected query type %T. expect *ent.WxCardVisitQuery", q)
  956. }
  957. // NewQuery returns the generic Query interface for the given typed query.
  958. func NewQuery(q ent.Query) (Query, error) {
  959. switch q := q.(type) {
  960. case *ent.AgentQuery:
  961. return &query[*ent.AgentQuery, predicate.Agent, agent.OrderOption]{typ: ent.TypeAgent, tq: q}, nil
  962. case *ent.AgentBaseQuery:
  963. return &query[*ent.AgentBaseQuery, predicate.AgentBase, agentbase.OrderOption]{typ: ent.TypeAgentBase, tq: q}, nil
  964. case *ent.AliyunAvatarQuery:
  965. return &query[*ent.AliyunAvatarQuery, predicate.AliyunAvatar, aliyunavatar.OrderOption]{typ: ent.TypeAliyunAvatar, tq: q}, nil
  966. case *ent.AllocAgentQuery:
  967. return &query[*ent.AllocAgentQuery, predicate.AllocAgent, allocagent.OrderOption]{typ: ent.TypeAllocAgent, tq: q}, nil
  968. case *ent.BatchMsgQuery:
  969. return &query[*ent.BatchMsgQuery, predicate.BatchMsg, batchmsg.OrderOption]{typ: ent.TypeBatchMsg, tq: q}, nil
  970. case *ent.CategoryQuery:
  971. return &query[*ent.CategoryQuery, predicate.Category, category.OrderOption]{typ: ent.TypeCategory, tq: q}, nil
  972. case *ent.ChatRecordsQuery:
  973. return &query[*ent.ChatRecordsQuery, predicate.ChatRecords, chatrecords.OrderOption]{typ: ent.TypeChatRecords, tq: q}, nil
  974. case *ent.ChatSessionQuery:
  975. return &query[*ent.ChatSessionQuery, predicate.ChatSession, chatsession.OrderOption]{typ: ent.TypeChatSession, tq: q}, nil
  976. case *ent.ContactQuery:
  977. return &query[*ent.ContactQuery, predicate.Contact, contact.OrderOption]{typ: ent.TypeContact, tq: q}, nil
  978. case *ent.CreditBalanceQuery:
  979. return &query[*ent.CreditBalanceQuery, predicate.CreditBalance, creditbalance.OrderOption]{typ: ent.TypeCreditBalance, tq: q}, nil
  980. case *ent.CreditUsageQuery:
  981. return &query[*ent.CreditUsageQuery, predicate.CreditUsage, creditusage.OrderOption]{typ: ent.TypeCreditUsage, tq: q}, nil
  982. case *ent.EmployeeQuery:
  983. return &query[*ent.EmployeeQuery, predicate.Employee, employee.OrderOption]{typ: ent.TypeEmployee, tq: q}, nil
  984. case *ent.EmployeeConfigQuery:
  985. return &query[*ent.EmployeeConfigQuery, predicate.EmployeeConfig, employeeconfig.OrderOption]{typ: ent.TypeEmployeeConfig, tq: q}, nil
  986. case *ent.LabelQuery:
  987. return &query[*ent.LabelQuery, predicate.Label, label.OrderOption]{typ: ent.TypeLabel, tq: q}, nil
  988. case *ent.LabelRelationshipQuery:
  989. return &query[*ent.LabelRelationshipQuery, predicate.LabelRelationship, labelrelationship.OrderOption]{typ: ent.TypeLabelRelationship, tq: q}, nil
  990. case *ent.LabelTaggingQuery:
  991. return &query[*ent.LabelTaggingQuery, predicate.LabelTagging, labeltagging.OrderOption]{typ: ent.TypeLabelTagging, tq: q}, nil
  992. case *ent.MessageQuery:
  993. return &query[*ent.MessageQuery, predicate.Message, message.OrderOption]{typ: ent.TypeMessage, tq: q}, nil
  994. case *ent.MessageRecordsQuery:
  995. return &query[*ent.MessageRecordsQuery, predicate.MessageRecords, messagerecords.OrderOption]{typ: ent.TypeMessageRecords, tq: q}, nil
  996. case *ent.MsgQuery:
  997. return &query[*ent.MsgQuery, predicate.Msg, msg.OrderOption]{typ: ent.TypeMsg, tq: q}, nil
  998. case *ent.PayRechargeQuery:
  999. return &query[*ent.PayRechargeQuery, predicate.PayRecharge, payrecharge.OrderOption]{typ: ent.TypePayRecharge, tq: q}, nil
  1000. case *ent.ServerQuery:
  1001. return &query[*ent.ServerQuery, predicate.Server, server.OrderOption]{typ: ent.TypeServer, tq: q}, nil
  1002. case *ent.SopNodeQuery:
  1003. return &query[*ent.SopNodeQuery, predicate.SopNode, sopnode.OrderOption]{typ: ent.TypeSopNode, tq: q}, nil
  1004. case *ent.SopStageQuery:
  1005. return &query[*ent.SopStageQuery, predicate.SopStage, sopstage.OrderOption]{typ: ent.TypeSopStage, tq: q}, nil
  1006. case *ent.SopTaskQuery:
  1007. return &query[*ent.SopTaskQuery, predicate.SopTask, soptask.OrderOption]{typ: ent.TypeSopTask, tq: q}, nil
  1008. case *ent.TokenQuery:
  1009. return &query[*ent.TokenQuery, predicate.Token, token.OrderOption]{typ: ent.TypeToken, tq: q}, nil
  1010. case *ent.TutorialQuery:
  1011. return &query[*ent.TutorialQuery, predicate.Tutorial, tutorial.OrderOption]{typ: ent.TypeTutorial, tq: q}, nil
  1012. case *ent.UsageDetailQuery:
  1013. return &query[*ent.UsageDetailQuery, predicate.UsageDetail, usagedetail.OrderOption]{typ: ent.TypeUsageDetail, tq: q}, nil
  1014. case *ent.UsageStatisticDayQuery:
  1015. return &query[*ent.UsageStatisticDayQuery, predicate.UsageStatisticDay, usagestatisticday.OrderOption]{typ: ent.TypeUsageStatisticDay, tq: q}, nil
  1016. case *ent.UsageStatisticHourQuery:
  1017. return &query[*ent.UsageStatisticHourQuery, predicate.UsageStatisticHour, usagestatistichour.OrderOption]{typ: ent.TypeUsageStatisticHour, tq: q}, nil
  1018. case *ent.UsageStatisticMonthQuery:
  1019. return &query[*ent.UsageStatisticMonthQuery, predicate.UsageStatisticMonth, usagestatisticmonth.OrderOption]{typ: ent.TypeUsageStatisticMonth, tq: q}, nil
  1020. case *ent.UsageTotalQuery:
  1021. return &query[*ent.UsageTotalQuery, predicate.UsageTotal, usagetotal.OrderOption]{typ: ent.TypeUsageTotal, tq: q}, nil
  1022. case *ent.WhatsappQuery:
  1023. return &query[*ent.WhatsappQuery, predicate.Whatsapp, whatsapp.OrderOption]{typ: ent.TypeWhatsapp, tq: q}, nil
  1024. case *ent.WorkExperienceQuery:
  1025. return &query[*ent.WorkExperienceQuery, predicate.WorkExperience, workexperience.OrderOption]{typ: ent.TypeWorkExperience, tq: q}, nil
  1026. case *ent.WpChatroomQuery:
  1027. return &query[*ent.WpChatroomQuery, predicate.WpChatroom, wpchatroom.OrderOption]{typ: ent.TypeWpChatroom, tq: q}, nil
  1028. case *ent.WpChatroomMemberQuery:
  1029. return &query[*ent.WpChatroomMemberQuery, predicate.WpChatroomMember, wpchatroommember.OrderOption]{typ: ent.TypeWpChatroomMember, tq: q}, nil
  1030. case *ent.WxQuery:
  1031. return &query[*ent.WxQuery, predicate.Wx, wx.OrderOption]{typ: ent.TypeWx, tq: q}, nil
  1032. case *ent.WxCardQuery:
  1033. return &query[*ent.WxCardQuery, predicate.WxCard, wxcard.OrderOption]{typ: ent.TypeWxCard, tq: q}, nil
  1034. case *ent.WxCardUserQuery:
  1035. return &query[*ent.WxCardUserQuery, predicate.WxCardUser, wxcarduser.OrderOption]{typ: ent.TypeWxCardUser, tq: q}, nil
  1036. case *ent.WxCardVisitQuery:
  1037. return &query[*ent.WxCardVisitQuery, predicate.WxCardVisit, wxcardvisit.OrderOption]{typ: ent.TypeWxCardVisit, tq: q}, nil
  1038. default:
  1039. return nil, fmt.Errorf("unknown query type %T", q)
  1040. }
  1041. }
  1042. type query[T any, P ~func(*sql.Selector), R ~func(*sql.Selector)] struct {
  1043. typ string
  1044. tq interface {
  1045. Limit(int) T
  1046. Offset(int) T
  1047. Unique(bool) T
  1048. Order(...R) T
  1049. Where(...P) T
  1050. }
  1051. }
  1052. func (q query[T, P, R]) Type() string {
  1053. return q.typ
  1054. }
  1055. func (q query[T, P, R]) Limit(limit int) {
  1056. q.tq.Limit(limit)
  1057. }
  1058. func (q query[T, P, R]) Offset(offset int) {
  1059. q.tq.Offset(offset)
  1060. }
  1061. func (q query[T, P, R]) Unique(unique bool) {
  1062. q.tq.Unique(unique)
  1063. }
  1064. func (q query[T, P, R]) Order(orders ...func(*sql.Selector)) {
  1065. rs := make([]R, len(orders))
  1066. for i := range orders {
  1067. rs[i] = orders[i]
  1068. }
  1069. q.tq.Order(rs...)
  1070. }
  1071. func (q query[T, P, R]) WhereP(ps ...func(*sql.Selector)) {
  1072. p := make([]P, len(ps))
  1073. for i := range ps {
  1074. p[i] = ps[i]
  1075. }
  1076. q.tq.Where(p...)
  1077. }