0

我正在使用 goswagger 生成我的 restAPI 代码,并且作为生成的用于编写响应的代码的一部分,我应该返回 middleware.Responder。我希望可以选择直接使用 API 客户端编写响应,因为我正在使用 gorx 反应式扩展,因为它在异步模式下运行时无法返回值。

Code Example:

//Handle which is generated by goswagger
api.TodosFindTodosHandler = todos.FindTodosHandlerFunc(func(params todos.FindTodosParams) middleware.Responder {
        return getToListHandler(api)

    })


//goRx code which iterate over all items and handle it using observer model
  func getToListHandler(api *operations.TodoListAPI) middleware.Responder {
    watcher := observer.Observer{
        NextHandler: func(item interface{}) {
            ms, ok := item.(*models.Item)
            if ok {
                 //How can write the response here i tried this but didnt work
                result := middleware.ResponderFunc(func(rw 
                http.ResponseWriter, p runtime.Producer) {
                rw.Write([]byte("hello"))
                rw.WriteHeader(200)
            })
             //message just to use the result value to skip error
            fmt.Println("result value of method '%v'", x)
                })

            }
        },
        // Register a handler for any emitted error.
        ErrHandler: func(err error) {
             //How can write the response here
        },

        // Register a handler when a stream is completed.
        DoneHandler: func() {
         //How can write the response here
        },
    }
    it, _ := iterable.New(getAllTGoListMode())
    source := observable.From(it)
    sub := source.Subscribe(watcher)
    <-sub
    return middleware.NotImplemented("DONE....")
  } 

作为我的代码的一部分,我想直接将响应编写为 NextHandler、NextHandler、DoneHandler 的一部分

谢谢

托尼。

4

1 回答 1

0

middleware.Responder 是一个简单的单一方法接口,可让您完全访问响应和该响应内容类型的序列化程序。

你可以看看这个例子:https ://github.com/go-swagger/go-swagger/blob/master/examples/stream-server/restapi/configure_countdown.go#L43-L47

它流式传输一个计数器,但它是相同的用例。

于 2019-06-30T23:57:33.620 回答