in src/frontend/handlers.go [451:497]
func (fe *frontendServer) chatBotHandler(w http.ResponseWriter, r *http.Request) {
log := r.Context().Value(ctxKeyLog{}).(logrus.FieldLogger)
type Response struct {
Message string `json:"message"`
}
type LLMResponse struct {
Content string `json:"content"`
Details map[string]any `json:"details"`
}
var response LLMResponse
url := "http://" + fe.shoppingAssistantSvcAddr
req, err := http.NewRequest(http.MethodPost, url, r.Body)
if err != nil {
renderHTTPError(log, r, w, errors.Wrap(err, "failed to create request"), http.StatusInternalServerError)
return
}
req.Header.Set("Content-Type", "application/json")
req.Header.Set("Accept", "application/json")
res, err := http.DefaultClient.Do(req)
if err != nil {
renderHTTPError(log, r, w, errors.Wrap(err, "failed to send request"), http.StatusInternalServerError)
return
}
body, err := io.ReadAll(res.Body)
if err != nil {
renderHTTPError(log, r, w, errors.Wrap(err, "failed to read response"), http.StatusInternalServerError)
return
}
fmt.Printf("%+v\n", body)
fmt.Printf("%+v\n", res)
err = json.Unmarshal(body, &response)
if err != nil {
renderHTTPError(log, r, w, errors.Wrap(err, "failed to unmarshal body"), http.StatusInternalServerError)
return
}
// respond with the same message
json.NewEncoder(w).Encode(Response{Message: response.Content})
w.WriteHeader(http.StatusOK)
}