Micro-service for file storage and processing written in Go
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

91 lines
2.0 KiB

  1. package controllers
  2. import (
  3. "bytes"
  4. "encoding/json"
  5. "github.com/geplauder/lithium/pipelines"
  6. "github.com/geplauder/lithium/storage"
  7. "github.com/sirupsen/logrus"
  8. "io"
  9. "net/http"
  10. )
  11. func UploadHandler(w http.ResponseWriter, r *http.Request, pipes []pipelines.IPipeline, storageProvider storage.IStorageProvider) {
  12. // open file handler
  13. formFile, handler, err := r.FormFile("file")
  14. if err != nil {
  15. writeError(w, http.StatusUnprocessableEntity, err.Error())
  16. return
  17. }
  18. defer formFile.Close()
  19. // check pipelines form param
  20. formPipeline := r.FormValue("pipeline")
  21. if formPipeline == "" {
  22. writeError(w, http.StatusUnprocessableEntity, "pipeline parameter missing")
  23. return
  24. }
  25. var execPipe pipelines.IPipeline
  26. for _, pipe := range pipes {
  27. if formPipeline == pipe.GetSlug() {
  28. execPipe = pipe
  29. break
  30. }
  31. }
  32. if execPipe == nil {
  33. writeError(w, http.StatusUnprocessableEntity, "pipeline not found")
  34. return
  35. }
  36. bucket := r.FormValue("bucket")
  37. if bucket == "" {
  38. writeError(w, http.StatusUnprocessableEntity, "bucket parameter missing")
  39. return
  40. }
  41. // open file
  42. file, err := handler.Open()
  43. if err != nil {
  44. writeError(w, http.StatusInternalServerError, "error reading uploaded file")
  45. return
  46. }
  47. defer file.Close()
  48. // read file to buffer
  49. buf := bytes.NewBuffer(nil)
  50. _, err = io.Copy(buf, file)
  51. if err != nil {
  52. writeError(w, http.StatusInternalServerError, "error reading file from buffer")
  53. return
  54. }
  55. // store uploaded file
  56. _, err = storageProvider.StoreRaw(bucket, "source.jpg", buf.Bytes())
  57. if err != nil {
  58. return
  59. }
  60. // execute pipeline
  61. output, err := execPipe.Run("source.jpg", bucket, storageProvider)
  62. if err != nil {
  63. writeError(w, http.StatusInternalServerError, "error executing pipeline")
  64. return
  65. }
  66. w.Header().Set("Content-Type", "application/json")
  67. err = json.NewEncoder(w).Encode(struct {
  68. Message string `json:"message"`
  69. OutputFiles []string `json:"output_files"`
  70. }{"ok", []string{output}})
  71. if err != nil {
  72. w.WriteHeader(http.StatusInternalServerError)
  73. }
  74. logrus.Info("Pipeline routes registered successfully")
  75. }