feat!(backend): move /auth/export to /users/@me/export
This commit is contained in:
parent
17f6ac4d23
commit
f087e9a29f
5 changed files with 14 additions and 9 deletions
74
backend/routes/user/export.go
Normal file
74
backend/routes/user/export.go
Normal file
|
@ -0,0 +1,74 @@
|
|||
package user
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
"codeberg.org/u1f320/pronouns.cc/backend/db"
|
||||
"codeberg.org/u1f320/pronouns.cc/backend/log"
|
||||
"codeberg.org/u1f320/pronouns.cc/backend/server"
|
||||
"github.com/go-chi/render"
|
||||
)
|
||||
|
||||
func (s *Server) startExport(w http.ResponseWriter, r *http.Request) error {
|
||||
ctx := r.Context()
|
||||
claims, _ := server.ClaimsFromContext(ctx)
|
||||
|
||||
hasExport, err := s.DB.HasRecentExport(ctx, claims.UserID)
|
||||
if err != nil {
|
||||
log.Errorf("checking if user has recent export: %v", err)
|
||||
return server.APIError{Code: server.ErrInternalServerError}
|
||||
}
|
||||
if hasExport {
|
||||
return server.APIError{Code: server.ErrRecentExport}
|
||||
}
|
||||
|
||||
req, err := http.NewRequestWithContext(ctx, "GET", s.ExporterPath+"/start/"+claims.UserID.String(), nil)
|
||||
if err != nil {
|
||||
log.Errorf("creating start export request: %v", err)
|
||||
return server.APIError{Code: server.ErrInternalServerError}
|
||||
}
|
||||
|
||||
resp, err := http.DefaultClient.Do(req)
|
||||
if err != nil {
|
||||
log.Errorf("executing start export request: %v", err)
|
||||
return server.APIError{Code: server.ErrInternalServerError}
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
if resp.StatusCode != http.StatusAccepted {
|
||||
log.Errorf("got non-%v code: %v", http.StatusAccepted, resp.StatusCode)
|
||||
return server.APIError{
|
||||
Code: server.ErrInternalServerError,
|
||||
}
|
||||
}
|
||||
|
||||
render.JSON(w, r, map[string]any{"started": true})
|
||||
return nil
|
||||
}
|
||||
|
||||
type dataExportResponse struct {
|
||||
Path string `json:"path"`
|
||||
CreatedAt time.Time `json:"created_at"`
|
||||
}
|
||||
|
||||
func (s *Server) getExport(w http.ResponseWriter, r *http.Request) error {
|
||||
ctx := r.Context()
|
||||
claims, _ := server.ClaimsFromContext(ctx)
|
||||
|
||||
de, err := s.DB.UserExport(ctx, claims.UserID)
|
||||
if err != nil {
|
||||
if err == db.ErrNoExport {
|
||||
return server.APIError{Code: server.ErrNotFound}
|
||||
}
|
||||
|
||||
log.Errorf("getting export for user %v: %v", claims.UserID, err)
|
||||
return err
|
||||
}
|
||||
|
||||
render.JSON(w, r, dataExportResponse{
|
||||
Path: de.Path(),
|
||||
CreatedAt: de.CreatedAt,
|
||||
})
|
||||
return nil
|
||||
}
|
|
@ -1,16 +1,23 @@
|
|||
package user
|
||||
|
||||
import (
|
||||
"os"
|
||||
|
||||
"codeberg.org/u1f320/pronouns.cc/backend/server"
|
||||
"github.com/go-chi/chi/v5"
|
||||
)
|
||||
|
||||
type Server struct {
|
||||
*server.Server
|
||||
|
||||
ExporterPath string
|
||||
}
|
||||
|
||||
func Mount(srv *server.Server, r chi.Router) {
|
||||
s := &Server{srv}
|
||||
s := &Server{
|
||||
Server: srv,
|
||||
ExporterPath: "http://127.0.0.1:" + os.Getenv("EXPORTER_PORT"),
|
||||
}
|
||||
|
||||
r.Route("/users", func(r chi.Router) {
|
||||
r.Get("/{userRef}", server.WrapHandler(s.getUser))
|
||||
|
@ -19,6 +26,9 @@ func Mount(srv *server.Server, r chi.Router) {
|
|||
r.Get("/@me", server.WrapHandler(s.getMeUser))
|
||||
r.Patch("/@me", server.WrapHandler(s.patchUser))
|
||||
r.Delete("/@me", server.WrapHandler(s.deleteUser))
|
||||
|
||||
r.Get("/export/start", server.WrapHandler(s.startExport))
|
||||
r.Get("/export", server.WrapHandler(s.getExport))
|
||||
})
|
||||
})
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue