simple.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. package value_object
  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. // 使用的领域实体,注意是ValueObject类型
  13. ValueObject domain.ValueObject
  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. // 查询使用的请求参数,注意是Query类型
  27. QueryParams request.Query
  28. options *Options[I]
  29. }
  30. func (simple *Simple[I]) bind(binder *binding.Binder) {
  31. dbExecutor := binder.ChooseDBExecutor(simple.DBExecutorType)
  32. options := simple.options
  33. // 创建
  34. if !options.createNeedTx {
  35. binding.PostBind(binder, &binding.SimpleBindItem[any]{
  36. Path: simple.DomainPath + "/create",
  37. ResponseFunc: response.SendMsgResponse,
  38. RequestParams: simple.CreateJsonBody,
  39. Objects: []domain.Object{simple.ValueObject},
  40. ServiceFunc: Create(simple.TableName, dbExecutor, options.createCallbacks),
  41. })
  42. } else {
  43. binding.PostBind(binder, &binding.SimpleBindItem[any]{
  44. Path: simple.DomainPath + "/create",
  45. ResponseFunc: response.SendMsgResponse,
  46. RequestParams: simple.CreateJsonBody,
  47. Objects: []domain.Object{simple.ValueObject},
  48. ServiceFunc: CreateTx(simple.TableName, dbExecutor, options.createCallbacks),
  49. })
  50. }
  51. // 删除班级
  52. if !options.deleteNeedTx {
  53. binding.DeleteBind(binder, &binding.SimpleBindItem[any]{
  54. Path: simple.DomainPath + "/:id/delete",
  55. ResponseFunc: response.SendMsgResponse,
  56. RequestParams: simple.DeleteQueryParams,
  57. Objects: []domain.Object{simple.ValueObject},
  58. ServiceFunc: Delete(simple.TableName, dbExecutor, options.deleteCallbacks),
  59. })
  60. } else {
  61. binding.DeleteBind(binder, &binding.SimpleBindItem[any]{
  62. Path: simple.DomainPath + "/:id/delete",
  63. ResponseFunc: response.SendMsgResponse,
  64. RequestParams: simple.DeleteQueryParams,
  65. Objects: []domain.Object{simple.ValueObject},
  66. ServiceFunc: DeleteTx(simple.TableName, dbExecutor, options.deleteCallbacks),
  67. })
  68. }
  69. // 查询班级
  70. binding.GetBind(binder, &binding.SimpleBindItem[response.InfosData[I]]{
  71. Path: simple.DomainPath + "/query",
  72. ResponseFunc: response.SendInfosResponse[I],
  73. RequestParams: simple.QueryParams,
  74. Objects: []domain.Object{simple.ValueObject},
  75. ServiceFunc: Query(simple.TableName, dbExecutor, options.queryCallbacks, options.queryConditionFieldCallback),
  76. })
  77. }
  78. func BindSimple[I any](binder *binding.Binder, crud *Simple[I]) {
  79. crud.bind(binder)
  80. }
  81. type Option[I any] func(options *Options[I])
  82. type Options[I any] struct {
  83. // 创建是否使用事务
  84. createNeedTx bool
  85. // 创建回调
  86. createCallbacks *Callbacks[any]
  87. // 创建中间件
  88. createMiddlewares []api.Handler
  89. // 删除是否使用事务
  90. deleteNeedTx bool
  91. // 删除回调
  92. deleteCallbacks *Callbacks[any]
  93. // 删除中间件
  94. deleteMiddlewares []api.Handler
  95. // 查询条件构造回调
  96. queryConditionFieldCallback ConditionFieldCallback
  97. // 查询回调
  98. queryCallbacks *Callbacks[response.InfosData[I]]
  99. // 查询中间件
  100. queryMiddlewares []api.Handler
  101. }
  102. func WithCreateTx[I any]() Option[I] {
  103. return func(options *Options[I]) {
  104. options.createNeedTx = true
  105. }
  106. }
  107. func WithCreateCallbacks[I any](callbacks *Callbacks[any]) Option[I] {
  108. return func(options *Options[I]) {
  109. options.createCallbacks = callbacks
  110. }
  111. }
  112. func WithCreateMiddlewares[I any](middlewares []api.Handler) Option[I] {
  113. return func(options *Options[I]) {
  114. options.createMiddlewares = middlewares
  115. }
  116. }
  117. func WithDeleteTx[I any]() Option[I] {
  118. return func(options *Options[I]) {
  119. options.deleteNeedTx = true
  120. }
  121. }
  122. func WithDeleteCallbacks[I any](callbacks *Callbacks[any]) Option[I] {
  123. return func(options *Options[I]) {
  124. options.deleteCallbacks = callbacks
  125. }
  126. }
  127. func WithDeleteMiddlewares[I any](middlewares []api.Handler) Option[I] {
  128. return func(options *Options[I]) {
  129. options.deleteMiddlewares = middlewares
  130. }
  131. }
  132. func WithQueryConditionFieldCallback[I any](callback ConditionFieldCallback) Option[I] {
  133. return func(options *Options[I]) {
  134. options.queryConditionFieldCallback = callback
  135. }
  136. }
  137. func WithQueryCallbacks[I any](callbacks *Callbacks[response.InfosData[I]]) Option[I] {
  138. return func(options *Options[I]) {
  139. options.queryCallbacks = callbacks
  140. }
  141. }
  142. func WithQueryMiddlewares[I any](middlewares []api.Handler) Option[I] {
  143. return func(options *Options[I]) {
  144. options.queryMiddlewares = middlewares
  145. }
  146. }