simple.go 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. package entity
  2. import (
  3. "git.sxidc.com/go-framework/baize/api"
  4. "git.sxidc.com/go-framework/baize/binding"
  5. "git.sxidc.com/go-framework/baize/binding/request"
  6. "git.sxidc.com/go-framework/baize/binding/response"
  7. "git.sxidc.com/go-framework/baize/domain"
  8. )
  9. // Simple 实体CRUD的Bind参数
  10. // I 为查询相关接口返回的Info类型
  11. type Simple[I any] struct {
  12. // 使用的领域实体,注意是Entity类型
  13. Entity domain.Entity
  14. // 表名
  15. TableName string
  16. // 选择要使用的数据库Executor
  17. // DBExecutorOperations operations 数据库操作
  18. // DBExecutorDataService data_service 数据服务
  19. DBExecutorType string
  20. // URL领域相对路径,如/class,后面会自动补充
  21. DomainPath string
  22. // 创建使用的请求参数
  23. CreateJsonBody request.Params
  24. // 删除使用的请求参数,注意是WithID类型
  25. DeleteQueryParams request.WithID
  26. // 更新使用的请求参数,注意是WithID类型
  27. UpdateJsonBody request.WithID
  28. // 查询使用的请求参数,注意是Query类型
  29. QueryParams request.Query
  30. // 根据ID查询使用的请求参数,注意是WithID类型
  31. GetByIDQueryParams request.WithID
  32. options *Options[I]
  33. }
  34. func (simple *Simple[I]) bind(binder *binding.Binder) {
  35. dbExecutor := binder.ChooseDBExecutor(simple.DBExecutorType)
  36. options := simple.options
  37. // 创建
  38. if !options.createNeedTx {
  39. binding.PostBind(binder, &binding.SimpleBindItem[string]{
  40. Path: simple.DomainPath + "/create",
  41. ResponseFunc: response.SendIDResponse[string],
  42. RequestParams: simple.CreateJsonBody,
  43. Objects: []domain.Object{simple.Entity},
  44. ServiceFunc: Create(simple.TableName, dbExecutor, options.createCallbacks),
  45. }, options.createMiddlewares...)
  46. } else {
  47. binding.PostBind(binder, &binding.SimpleBindItem[string]{
  48. Path: simple.DomainPath + "/create",
  49. ResponseFunc: response.SendIDResponse[string],
  50. RequestParams: simple.CreateJsonBody,
  51. Objects: []domain.Object{simple.Entity},
  52. ServiceFunc: CreateTx(simple.TableName, dbExecutor, options.createCallbacks),
  53. }, options.createMiddlewares...)
  54. }
  55. // 删除
  56. if !options.deleteNeedTx {
  57. binding.DeleteBind(binder, &binding.SimpleBindItem[any]{
  58. Path: simple.DomainPath + "/:id/delete",
  59. ResponseFunc: response.SendMsgResponse,
  60. RequestParams: simple.DeleteQueryParams,
  61. Objects: []domain.Object{simple.Entity},
  62. ServiceFunc: Delete(simple.TableName, dbExecutor, options.deleteCallbacks),
  63. }, options.deleteMiddlewares...)
  64. } else {
  65. binding.DeleteBind(binder, &binding.SimpleBindItem[any]{
  66. Path: simple.DomainPath + "/:id/delete",
  67. ResponseFunc: response.SendMsgResponse,
  68. RequestParams: simple.DeleteQueryParams,
  69. Objects: []domain.Object{simple.Entity},
  70. ServiceFunc: DeleteTx(simple.TableName, dbExecutor, options.deleteCallbacks),
  71. }, options.deleteMiddlewares...)
  72. }
  73. // 修改
  74. if !options.updateNeedTx {
  75. binding.PutBind(binder, &binding.SimpleBindItem[any]{
  76. Path: simple.DomainPath + "/update",
  77. ResponseFunc: response.SendMsgResponse,
  78. RequestParams: simple.UpdateJsonBody,
  79. Objects: []domain.Object{simple.Entity},
  80. ServiceFunc: Update(simple.TableName, dbExecutor, options.updateCallbacks),
  81. }, options.updateMiddlewares...)
  82. } else {
  83. binding.PutBind(binder, &binding.SimpleBindItem[any]{
  84. Path: simple.DomainPath + "/update",
  85. ResponseFunc: response.SendMsgResponse,
  86. RequestParams: simple.UpdateJsonBody,
  87. Objects: []domain.Object{simple.Entity},
  88. ServiceFunc: UpdateTx(simple.TableName, dbExecutor, options.updateCallbacks),
  89. }, options.updateMiddlewares...)
  90. }
  91. // 查询
  92. binding.GetBind(binder, &binding.SimpleBindItem[response.InfosData[I]]{
  93. Path: simple.DomainPath + "/query",
  94. ResponseFunc: response.SendInfosResponse[I],
  95. RequestParams: simple.QueryParams,
  96. Objects: []domain.Object{simple.Entity},
  97. ServiceFunc: Query[I](simple.TableName, dbExecutor, options.queryCallbacks, options.queryConditionFieldCallback),
  98. }, options.queryMiddlewares...)
  99. // 通过ID获取
  100. binding.GetBind(binder, &binding.SimpleBindItem[I]{
  101. Path: simple.DomainPath + "/get",
  102. ResponseFunc: response.SendInfoResponse[I],
  103. RequestParams: simple.GetByIDQueryParams,
  104. Objects: []domain.Object{simple.Entity},
  105. ServiceFunc: GetByID[I](simple.TableName, dbExecutor, options.getByIDCallbacks),
  106. }, options.getByIDMiddlewares...)
  107. }
  108. func BindSimple[I any](binder *binding.Binder, simple *Simple[I], opts ...Option[I]) {
  109. options := new(Options[I])
  110. for _, opt := range opts {
  111. opt(options)
  112. }
  113. simple.options = options
  114. simple.bind(binder)
  115. }
  116. type Option[I any] func(options *Options[I])
  117. type Options[I any] struct {
  118. // 创建是否使用事务
  119. createNeedTx bool
  120. // 创建回调
  121. createCallbacks *Callbacks[string]
  122. // 创建中间件
  123. createMiddlewares []api.Handler
  124. // 删除是否使用事务
  125. deleteNeedTx bool
  126. // 删除回调
  127. deleteCallbacks *Callbacks[any]
  128. // 删除中间件
  129. deleteMiddlewares []api.Handler
  130. // 更新是否使用事务
  131. updateNeedTx bool
  132. // 更新回调
  133. updateCallbacks *Callbacks[any]
  134. // 更新中间件
  135. updateMiddlewares []api.Handler
  136. // 查询条件构造回调
  137. queryConditionFieldCallback ConditionFieldCallback
  138. // 查询回调
  139. queryCallbacks *Callbacks[response.InfosData[I]]
  140. // 查询中间件
  141. queryMiddlewares []api.Handler
  142. // 根据ID查询回调
  143. getByIDCallbacks *Callbacks[I]
  144. // 根据ID查询中间件
  145. getByIDMiddlewares []api.Handler
  146. }
  147. func WithCreateTx[I any]() Option[I] {
  148. return func(options *Options[I]) {
  149. options.createNeedTx = true
  150. }
  151. }
  152. func WithCreateCallbacks[I any](callbacks *Callbacks[string]) Option[I] {
  153. return func(options *Options[I]) {
  154. options.createCallbacks = callbacks
  155. }
  156. }
  157. func WithCreateMiddlewares[I any](middlewares []api.Handler) Option[I] {
  158. return func(options *Options[I]) {
  159. options.createMiddlewares = middlewares
  160. }
  161. }
  162. func WithDeleteTx[I any]() Option[I] {
  163. return func(options *Options[I]) {
  164. options.deleteNeedTx = true
  165. }
  166. }
  167. func WithDeleteCallbacks[I any](callbacks *Callbacks[any]) Option[I] {
  168. return func(options *Options[I]) {
  169. options.deleteCallbacks = callbacks
  170. }
  171. }
  172. func WithDeleteMiddlewares[I any](middlewares []api.Handler) Option[I] {
  173. return func(options *Options[I]) {
  174. options.deleteMiddlewares = middlewares
  175. }
  176. }
  177. func WithUpdateTx[I any]() Option[I] {
  178. return func(options *Options[I]) {
  179. options.updateNeedTx = true
  180. }
  181. }
  182. func WithUpdateCallbacks[I any](callbacks *Callbacks[any]) Option[I] {
  183. return func(options *Options[I]) {
  184. options.updateCallbacks = callbacks
  185. }
  186. }
  187. func WithUpdateMiddlewares[I any](middlewares []api.Handler) Option[I] {
  188. return func(options *Options[I]) {
  189. options.updateMiddlewares = middlewares
  190. }
  191. }
  192. func WithQueryConditionFieldCallback[I any](callback ConditionFieldCallback) Option[I] {
  193. return func(options *Options[I]) {
  194. options.queryConditionFieldCallback = callback
  195. }
  196. }
  197. func WithQueryCallbacks[I any](callbacks *Callbacks[response.InfosData[I]]) Option[I] {
  198. return func(options *Options[I]) {
  199. options.queryCallbacks = callbacks
  200. }
  201. }
  202. func WithQueryMiddlewares[I any](middlewares []api.Handler) Option[I] {
  203. return func(options *Options[I]) {
  204. options.queryMiddlewares = middlewares
  205. }
  206. }
  207. func WithGetByIDCallbacks[I any](callbacks *Callbacks[I]) Option[I] {
  208. return func(options *Options[I]) {
  209. options.getByIDCallbacks = callbacks
  210. }
  211. }
  212. func WithGetByIDMiddlewares[I any](middlewares []api.Handler) Option[I] {
  213. return func(options *Options[I]) {
  214. options.getByIDMiddlewares = middlewares
  215. }
  216. }