github.com/AngusLu/go-swagger@v0.28.0/docs/use/server.md (about) 1 # Use the generated server 2 3 The generated server serves the API but the default implementation returns 501 Not implemented for everything. Let's 4 look into using the generated code. 5 6 Go swagger primarily deals with HTTP and originally only supports the stdlib `net/http` interface. A typical HTTP 7 request expects a response. This is reflected in go-swagger where a handler is typically defined as a function of 8 input parameters to a responder. 9 10 ```go 11 type ListTravelsHandler interface { 12 Handle(ListTravelsParams) middleware.Responder 13 } 14 ``` 15 16 The signature of this handler is one of 2 possible variations. When a handler doesn't use authentication then a handler 17 interface consists out of input parameters and a responder. 18 19 ```go 20 type AddOneAuthenticatedHandler interface { 21 Handle(AddOneParams, interface{}) middleware.Responder 22 } 23 ``` 24 25 When a handler does use authentication then the second argument to the handler function represents the security 26 principal for your application. You can specify the type name for this principal at generation time by specifying the 27 -P or --principal flag. 28 29 ``` 30 swagger generate server -P models.User 31 swagger generate client -P models.User 32 ``` 33 34 See the full list of available options [for server](../generate/server.md) and [for client](../generate/client.md). 35 36 When you would execute the generate step with that parameter for the security principal then the 37 AddOneAuthenticatedHandler would look a bit like this: 38 39 ```go 40 type AddOneAuthenticatedHandler interface { 41 Handle(AddOneParams, *models.User) middleware.Responder 42 } 43 ``` 44 45 ## Implement handlers 46 47 A handler is an interface/contract that defines a statically typed representation of the input and output parameters of 48 an operation on your API. 49 The tool generates handlers that are stubbed with a NotImplemented response when you first generate the server. 50 51 ### The `not implemented` handler 52 53 The not implemented handler is actually a not implemented responder, it returns a responder that will always respond 54 with status code 501 and a message that lets people know it's not the fault of the client that things don't work. 55 56 ```go 57 middleware.NotImplemented("operation todos.AddOne has not yet been implemented") 58 ``` 59 60 ### Your own code 61 62 Each HTTP request expects a response of some sort, this response might have no data but it's a response none the less. 63 64 Every incoming request is described as a bunch of input parameters which have been validated prior to calling the 65 handler. So whenever your code is executed, the input parameters are guaranteed to be valid according to what the 66 swagger specification prescribes. 67 68 All the input parameters have been validated, and the request has been authenticated should it have triggered 69 authentication. 70 71 You probably want to return something a bit more useful to the users of your API than a not implemented response. 72 73 A possible implementation of the `ListTravelsHandler` interface might look like this: 74 75 ```go 76 type PublicListTravelsOK struct { 77 Body []models.Travel 78 } 79 func (m *PublicListTravelsOK) WriteResponse(rw http.ResponseWriter, producer httpkit.Producer){ 80 // generated code here 81 } 82 83 type PublicListTravelsError struct { 84 Body models.Error 85 } 86 func (m *PublicListTravelsOK) WriteResponse(rw http.ResponseWriter, producer httpkit.Producer){ 87 // generated code here 88 } 89 90 type PublicListTravelsHandler struct { 91 db interface { 92 FetchTravels(*PublicListTravelsParams) ([]models.Travel, error) 93 } 94 } 95 96 func (m *PublicListTravelsHandler) Handle(params ListTravelsParams) middleware.Responder { 97 travels, err := m.db.FetchTravels(¶ms) 98 if err != nil { 99 return &PublicListTravelsError{Body: models.Error{Message: err.Error()}} 100 } 101 return &PublicListTravelsOK{Body: travels} 102 } 103 ``` 104 105 In the example above we have a handler implementation with a hypothetical database fetch interface. When the handle 106 method is executed there are 2 possible responses for the provided parameters. There can either be an error in which 107 case the PublicListTravelsError will be returned, otherwise the PublicListTravelsOK will be returned. 108 109 The code generator has written the remaining code to render that response with the headers etc. 110