api_utils.go 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. package httpd
  2. import (
  3. "context"
  4. "errors"
  5. "net/http"
  6. "os"
  7. "strconv"
  8. "github.com/go-chi/render"
  9. "github.com/drakkan/sftpgo/common"
  10. "github.com/drakkan/sftpgo/dataprovider"
  11. )
  12. func sendAPIResponse(w http.ResponseWriter, r *http.Request, err error, message string, code int) {
  13. var errorString string
  14. if err != nil {
  15. errorString = err.Error()
  16. }
  17. resp := apiResponse{
  18. Error: errorString,
  19. Message: message,
  20. }
  21. ctx := context.WithValue(r.Context(), render.StatusCtxKey, code)
  22. render.JSON(w, r.WithContext(ctx), resp)
  23. }
  24. func getRespStatus(err error) int {
  25. if _, ok := err.(*dataprovider.ValidationError); ok {
  26. return http.StatusBadRequest
  27. }
  28. if _, ok := err.(*dataprovider.MethodDisabledError); ok {
  29. return http.StatusForbidden
  30. }
  31. if _, ok := err.(*dataprovider.RecordNotFoundError); ok {
  32. return http.StatusNotFound
  33. }
  34. if os.IsNotExist(err) {
  35. return http.StatusBadRequest
  36. }
  37. return http.StatusInternalServerError
  38. }
  39. func handleCloseConnection(w http.ResponseWriter, r *http.Request) {
  40. connectionID := getURLParam(r, "connectionID")
  41. if connectionID == "" {
  42. sendAPIResponse(w, r, nil, "connectionID is mandatory", http.StatusBadRequest)
  43. return
  44. }
  45. if common.Connections.Close(connectionID) {
  46. sendAPIResponse(w, r, nil, "Connection closed", http.StatusOK)
  47. } else {
  48. sendAPIResponse(w, r, nil, "Not Found", http.StatusNotFound)
  49. }
  50. }
  51. func getSearchFilters(w http.ResponseWriter, r *http.Request) (int, int, string, error) {
  52. var err error
  53. limit := 100
  54. offset := 0
  55. order := dataprovider.OrderASC
  56. if _, ok := r.URL.Query()["limit"]; ok {
  57. limit, err = strconv.Atoi(r.URL.Query().Get("limit"))
  58. if err != nil {
  59. err = errors.New("invalid limit")
  60. sendAPIResponse(w, r, err, "", http.StatusBadRequest)
  61. return limit, offset, order, err
  62. }
  63. if limit > 500 {
  64. limit = 500
  65. }
  66. }
  67. if _, ok := r.URL.Query()["offset"]; ok {
  68. offset, err = strconv.Atoi(r.URL.Query().Get("offset"))
  69. if err != nil {
  70. err = errors.New("invalid offset")
  71. sendAPIResponse(w, r, err, "", http.StatusBadRequest)
  72. return limit, offset, order, err
  73. }
  74. }
  75. if _, ok := r.URL.Query()["order"]; ok {
  76. order = r.URL.Query().Get("order")
  77. if order != dataprovider.OrderASC && order != dataprovider.OrderDESC {
  78. err = errors.New("invalid order")
  79. sendAPIResponse(w, r, err, "", http.StatusBadRequest)
  80. return limit, offset, order, err
  81. }
  82. }
  83. return limit, offset, order, err
  84. }