simple.go 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. package entity
  2. import (
  3. "git.sxidc.com/go-framework/baize/api"
  4. "git.sxidc.com/go-framework/baize/convenient/binding"
  5. "git.sxidc.com/go-framework/baize/convenient/binding/request"
  6. "git.sxidc.com/go-framework/baize/convenient/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. // URL领域相对路径,如/class,后面会自动补充,如/class/create
  17. DomainPath string
  18. // 创建使用的请求参数
  19. CreateJsonBody request.Params
  20. // 删除使用的请求参数,注意是WithID类型
  21. DeleteQueryParams request.WithID
  22. // 更新使用的请求参数,注意是WithID类型
  23. UpdateJsonBody request.WithID
  24. // 查询使用的请求参数,注意是Query类型
  25. QueryQueryParams request.Query
  26. // 根据ID查询使用的请求参数,注意是WithID类型
  27. GetByIDQueryParams request.WithID
  28. // 可选配置项,通过WithXXX配置
  29. options *Options[I]
  30. }
  31. func (simple *Simple[I]) bind(binder *binding.Binder) {
  32. options := simple.options
  33. // 创建
  34. if !options.disableCreate {
  35. if !options.createNeedTx {
  36. binding.PostBind(binder, &binding.SimpleBindItem[string]{
  37. Path: simple.DomainPath + "/create",
  38. ResponseFunc: response.SendIDResponse[string],
  39. RequestParams: simple.CreateJsonBody,
  40. Objects: []domain.Object{simple.Entity},
  41. ServiceFunc: Create(simple.TableName, options.createCallbacks),
  42. }, options.createMiddlewares...)
  43. } else {
  44. binding.PostBind(binder, &binding.SimpleBindItem[string]{
  45. Path: simple.DomainPath + "/create",
  46. ResponseFunc: response.SendIDResponse[string],
  47. RequestParams: simple.CreateJsonBody,
  48. Objects: []domain.Object{simple.Entity},
  49. ServiceFunc: CreateTx(simple.TableName, options.createCallbacks),
  50. }, options.createMiddlewares...)
  51. }
  52. }
  53. // 删除
  54. if !options.disableDelete {
  55. if !options.deleteNeedTx {
  56. binding.DeleteBind(binder, &binding.SimpleBindItem[any]{
  57. Path: simple.DomainPath + "/:id/delete",
  58. ResponseFunc: response.SendMsgResponse,
  59. RequestParams: simple.DeleteQueryParams,
  60. Objects: []domain.Object{simple.Entity},
  61. ServiceFunc: Delete(simple.TableName, options.deleteCallbacks),
  62. }, options.deleteMiddlewares...)
  63. } else {
  64. binding.DeleteBind(binder, &binding.SimpleBindItem[any]{
  65. Path: simple.DomainPath + "/:id/delete",
  66. ResponseFunc: response.SendMsgResponse,
  67. RequestParams: simple.DeleteQueryParams,
  68. Objects: []domain.Object{simple.Entity},
  69. ServiceFunc: DeleteTx(simple.TableName, options.deleteCallbacks),
  70. }, options.deleteMiddlewares...)
  71. }
  72. }
  73. // 修改
  74. if !options.disableUpdate {
  75. if !options.updateNeedTx {
  76. binding.PutBind(binder, &binding.SimpleBindItem[any]{
  77. Path: simple.DomainPath + "/update",
  78. ResponseFunc: response.SendMsgResponse,
  79. RequestParams: simple.UpdateJsonBody,
  80. Objects: []domain.Object{simple.Entity},
  81. ServiceFunc: Update(simple.TableName, options.updateCallbacks),
  82. }, options.updateMiddlewares...)
  83. } else {
  84. binding.PutBind(binder, &binding.SimpleBindItem[any]{
  85. Path: simple.DomainPath + "/update",
  86. ResponseFunc: response.SendMsgResponse,
  87. RequestParams: simple.UpdateJsonBody,
  88. Objects: []domain.Object{simple.Entity},
  89. ServiceFunc: UpdateTx(simple.TableName, options.updateCallbacks),
  90. }, options.updateMiddlewares...)
  91. }
  92. }
  93. // 查询
  94. if !options.disableQuery {
  95. binding.GetBind(binder, &binding.SimpleBindItem[response.InfosData[I]]{
  96. Path: simple.DomainPath + "/query",
  97. ResponseFunc: response.SendInfosResponse[I],
  98. RequestParams: simple.QueryQueryParams,
  99. Objects: []domain.Object{simple.Entity},
  100. ServiceFunc: Query[I](simple.TableName, options.queryCallbacks, options.queryConditionFieldCallback),
  101. }, options.queryMiddlewares...)
  102. }
  103. // 通过ID获取
  104. if !options.disableQueryByID {
  105. binding.GetBind(binder, &binding.SimpleBindItem[I]{
  106. Path: simple.DomainPath + "/get",
  107. ResponseFunc: response.SendInfoResponse[I],
  108. RequestParams: simple.GetByIDQueryParams,
  109. Objects: []domain.Object{simple.Entity},
  110. ServiceFunc: GetByID[I](simple.TableName, options.getByIDCallbacks),
  111. }, options.getByIDMiddlewares...)
  112. }
  113. }
  114. func BindSimple[I any](binder *binding.Binder, simple *Simple[I], opts ...Option[I]) {
  115. options := new(Options[I])
  116. for _, opt := range opts {
  117. opt(options)
  118. }
  119. simple.options = options
  120. simple.bind(binder)
  121. }
  122. type Option[I any] func(options *Options[I])
  123. type Options[I any] struct {
  124. // 关闭创建
  125. disableCreate bool
  126. // 创建是否使用事务
  127. createNeedTx bool
  128. // 创建回调
  129. createCallbacks *Callbacks[string]
  130. // 创建中间件
  131. createMiddlewares []api.Handler
  132. // 关闭删除
  133. disableDelete bool
  134. // 删除是否使用事务
  135. deleteNeedTx bool
  136. // 删除回调
  137. deleteCallbacks *Callbacks[any]
  138. // 删除中间件
  139. deleteMiddlewares []api.Handler
  140. // 关闭更新
  141. disableUpdate bool
  142. // 更新是否使用事务
  143. updateNeedTx bool
  144. // 更新回调
  145. updateCallbacks *Callbacks[any]
  146. // 更新中间件
  147. updateMiddlewares []api.Handler
  148. // 关闭查询
  149. disableQuery bool
  150. // 查询条件构造回调
  151. queryConditionFieldCallback ConditionFieldCallback
  152. // 查询回调
  153. queryCallbacks *Callbacks[response.InfosData[I]]
  154. // 查询中间件
  155. queryMiddlewares []api.Handler
  156. // 关闭根据ID查询
  157. disableQueryByID bool
  158. // 根据ID查询回调
  159. getByIDCallbacks *Callbacks[I]
  160. // 根据ID查询中间件
  161. getByIDMiddlewares []api.Handler
  162. }
  163. func WithDisableCreate[I any]() Option[I] {
  164. return func(options *Options[I]) {
  165. options.disableCreate = true
  166. }
  167. }
  168. func WithCreateTx[I any]() Option[I] {
  169. return func(options *Options[I]) {
  170. options.createNeedTx = true
  171. }
  172. }
  173. func WithCreateCallbacks[I any](callbacks *Callbacks[string]) Option[I] {
  174. return func(options *Options[I]) {
  175. options.createCallbacks = callbacks
  176. }
  177. }
  178. func WithCreateMiddlewares[I any](middlewares []api.Handler) Option[I] {
  179. return func(options *Options[I]) {
  180. options.createMiddlewares = middlewares
  181. }
  182. }
  183. func WithDisableDelete[I any]() Option[I] {
  184. return func(options *Options[I]) {
  185. options.disableDelete = true
  186. }
  187. }
  188. func WithDeleteTx[I any]() Option[I] {
  189. return func(options *Options[I]) {
  190. options.deleteNeedTx = true
  191. }
  192. }
  193. func WithDeleteCallbacks[I any](callbacks *Callbacks[any]) Option[I] {
  194. return func(options *Options[I]) {
  195. options.deleteCallbacks = callbacks
  196. }
  197. }
  198. func WithDeleteMiddlewares[I any](middlewares []api.Handler) Option[I] {
  199. return func(options *Options[I]) {
  200. options.deleteMiddlewares = middlewares
  201. }
  202. }
  203. func WithDisableUpdate[I any]() Option[I] {
  204. return func(options *Options[I]) {
  205. options.disableUpdate = true
  206. }
  207. }
  208. func WithUpdateTx[I any]() Option[I] {
  209. return func(options *Options[I]) {
  210. options.updateNeedTx = true
  211. }
  212. }
  213. func WithUpdateCallbacks[I any](callbacks *Callbacks[any]) Option[I] {
  214. return func(options *Options[I]) {
  215. options.updateCallbacks = callbacks
  216. }
  217. }
  218. func WithUpdateMiddlewares[I any](middlewares []api.Handler) Option[I] {
  219. return func(options *Options[I]) {
  220. options.updateMiddlewares = middlewares
  221. }
  222. }
  223. func WithDisableQuery[I any]() Option[I] {
  224. return func(options *Options[I]) {
  225. options.disableQuery = true
  226. }
  227. }
  228. func WithQueryConditionFieldCallback[I any](callback ConditionFieldCallback) Option[I] {
  229. return func(options *Options[I]) {
  230. options.queryConditionFieldCallback = callback
  231. }
  232. }
  233. func WithQueryCallbacks[I any](callbacks *Callbacks[response.InfosData[I]]) Option[I] {
  234. return func(options *Options[I]) {
  235. options.queryCallbacks = callbacks
  236. }
  237. }
  238. func WithQueryMiddlewares[I any](middlewares []api.Handler) Option[I] {
  239. return func(options *Options[I]) {
  240. options.queryMiddlewares = middlewares
  241. }
  242. }
  243. func WithDisableQueryByID[I any]() Option[I] {
  244. return func(options *Options[I]) {
  245. options.disableQueryByID = true
  246. }
  247. }
  248. func WithGetByIDCallbacks[I any](callbacks *Callbacks[I]) Option[I] {
  249. return func(options *Options[I]) {
  250. options.getByIDCallbacks = callbacks
  251. }
  252. }
  253. func WithGetByIDMiddlewares[I any](middlewares []api.Handler) Option[I] {
  254. return func(options *Options[I]) {
  255. options.getByIDMiddlewares = middlewares
  256. }
  257. }