request_builder.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. package gateway
  2. import (
  3. "git.sxidc.com/go-framework/baize/framework/core/api"
  4. "git.sxidc.com/go-tools/utils/http_client"
  5. "github.com/pkg/errors"
  6. )
  7. // ResponseSuccessCallback 网关API成功响应回调
  8. type ResponseSuccessCallback func(c *api.Context, historyRequests []Request, resultMap map[string]any)
  9. // ResponseErrorCallback 网关API错误响应回调
  10. type ResponseErrorCallback func(c *api.Context, historyRequests []Request, resultMap map[string]any, err error)
  11. // BeforeRequestCallback 请求发送前的回调
  12. type BeforeRequestCallback func(c *api.Context, historyRequests []Request, resultMap map[string]any) error
  13. // RequestResponseCallback 请求响应回调
  14. type RequestResponseCallback func(c *api.Context, historyRequests []Request, resultMap map[string]any, response *http_client.Response) error
  15. type RequestOption func(options *RequestOptions)
  16. type RequestOptions struct {
  17. beforeRequestCallback BeforeRequestCallback
  18. requestResponseCallback RequestResponseCallback
  19. }
  20. // WithBeforeRequestCallback 设置请求发送前的回调请求选项
  21. func WithBeforeRequestCallback(callback BeforeRequestCallback) RequestOption {
  22. return func(options *RequestOptions) {
  23. options.beforeRequestCallback = callback
  24. }
  25. }
  26. // WithRequestResponseCallback 设置请求响应回调请求选项
  27. func WithRequestResponseCallback(callback RequestResponseCallback) RequestOption {
  28. return func(options *RequestOptions) {
  29. options.requestResponseCallback = callback
  30. }
  31. }
  32. // RequestBuilder 请求构建器
  33. type RequestBuilder struct {
  34. c *api.Context
  35. historyRequests []Request
  36. resultMap map[string]any
  37. httpRequest *http_client.Request
  38. params *requestBuilderParams
  39. }
  40. func newRequestBuilder(c *api.Context, httpRequest *http_client.Request) *RequestBuilder {
  41. return &RequestBuilder{
  42. c: c,
  43. historyRequests: make([]Request, 0),
  44. resultMap: make(map[string]any),
  45. httpRequest: httpRequest,
  46. params: newRequestBuilderParams(),
  47. }
  48. }
  49. // Context 获取上下文
  50. // 参数: 无
  51. // 返回值:
  52. // - 上下文
  53. func (builder *RequestBuilder) Context() *api.Context {
  54. return builder.c
  55. }
  56. // HistoryRequests 获取历史请求(包含响应)
  57. // 参数: 无
  58. // 返回值:
  59. // - 历史请求
  60. func (builder *RequestBuilder) HistoryRequests() []Request {
  61. return builder.historyRequests
  62. }
  63. // Post 定义POST请求
  64. // 参数:
  65. // - request: PostRequest
  66. // - opts: 请求选项
  67. // 返回值:
  68. // - RequestBuilder
  69. func (builder *RequestBuilder) Post(request *PostRequest, opts ...RequestOption) *RequestBuilder {
  70. return builder.request(request, opts...)
  71. }
  72. // Delete 定义Delete请求
  73. // 参数:
  74. // - request: DeleteRequest
  75. // - opts: 请求选项
  76. // 返回值:
  77. // - RequestBuilder
  78. func (builder *RequestBuilder) Delete(request *DeleteRequest, opts ...RequestOption) *RequestBuilder {
  79. return builder.request(request, opts...)
  80. }
  81. // Put 定义Put请求
  82. // 参数:
  83. // - request: PutRequest
  84. // - opts: 请求选项
  85. // 返回值:
  86. // - RequestBuilder
  87. func (builder *RequestBuilder) Put(request *PutRequest, opts ...RequestOption) *RequestBuilder {
  88. return builder.request(request, opts...)
  89. }
  90. // Get 定义Get请求
  91. // 参数:
  92. // - request: GetRequest
  93. // - opts: 请求选项
  94. // 返回值:
  95. // - RequestBuilder
  96. func (builder *RequestBuilder) Get(request *GetRequest, opts ...RequestOption) *RequestBuilder {
  97. return builder.request(request, opts...)
  98. }
  99. // ResponseSuccessCallback 设置网关API成功响应回调
  100. // 参数:
  101. // - responseSuccessCallback: 网关API成功响应回调,默认回调会将最后一个请求的响应作为网关API的响应返回
  102. // 返回值:
  103. // - RequestBuilder
  104. func (builder *RequestBuilder) ResponseSuccessCallback(responseSuccessCallback ResponseSuccessCallback) *RequestBuilder {
  105. builder.params.responseSuccessCallback = responseSuccessCallback
  106. return builder
  107. }
  108. // ResponseErrorCallback 设置网关API错误响应回调
  109. // 参数:
  110. // - responseErrorCallback: 网关API错误响应回调,默认回调会按照是否存在错误返回MsgResponse
  111. // 返回值:
  112. // - RequestBuilder
  113. func (builder *RequestBuilder) ResponseErrorCallback(responseErrorCallback ResponseErrorCallback) *RequestBuilder {
  114. builder.params.responseErrorCallback = responseErrorCallback
  115. return builder
  116. }
  117. // Request 发送构造的请求链
  118. // 参数: 无
  119. // 返回值: 无
  120. func (builder *RequestBuilder) Request() {
  121. httpRequest := builder.httpRequest
  122. for _, requestItem := range builder.params.requestItems {
  123. if requestItem.options.beforeRequestCallback != nil {
  124. err := requestItem.options.beforeRequestCallback(builder.c, builder.historyRequests, builder.resultMap)
  125. if err != nil {
  126. builder.params.responseErrorCallback(builder.c, builder.historyRequests, builder.resultMap, errors.New(err.Error()))
  127. return
  128. }
  129. }
  130. requestWithResponse, err := requestItem.builderRequest.Request(builder.c, httpRequest)
  131. if err != nil {
  132. builder.params.responseErrorCallback(builder.c, builder.historyRequests, builder.resultMap, errors.New(err.Error()))
  133. return
  134. }
  135. builder.historyRequests = append(builder.historyRequests, requestWithResponse)
  136. if requestItem.options.requestResponseCallback != nil {
  137. err := requestItem.options.requestResponseCallback(builder.c, builder.historyRequests, builder.resultMap, requestWithResponse.Response())
  138. if err != nil {
  139. builder.params.responseErrorCallback(builder.c, builder.historyRequests, builder.resultMap, errors.New(err.Error()))
  140. return
  141. }
  142. }
  143. }
  144. builder.params.responseSuccessCallback(builder.c, builder.historyRequests, builder.resultMap)
  145. }
  146. // ResponseError 利用网关API错误响应回调发送网关API响应
  147. // 参数:
  148. // - 错误
  149. // 返回值: 无
  150. func (builder *RequestBuilder) ResponseError(err error) {
  151. builder.params.responseErrorCallback(builder.c, builder.historyRequests, builder.resultMap, err)
  152. }
  153. // ResponseSuccess 利用网关API成功响应回调发送网关API响应
  154. // 参数: 无
  155. // 返回值: 无
  156. func (builder *RequestBuilder) ResponseSuccess() {
  157. builder.params.responseSuccessCallback(builder.c, builder.historyRequests, builder.resultMap)
  158. }
  159. func (builder *RequestBuilder) request(builderRequest Request, opts ...RequestOption) *RequestBuilder {
  160. options := new(RequestOptions)
  161. for _, opt := range opts {
  162. opt(options)
  163. }
  164. builder.params.requestItems = append(builder.params.requestItems, newBuilderRequestItem(builderRequest, options))
  165. return builder
  166. }