forked from mirrors/homebox
6529549289
* implement custom http handler interface * implement trace_id * normalize http method spacing for consistent logs * fix failing test * fix linter errors * cleanup old dead code * more route cleanup * cleanup some inconsistent errors * update and generate code * make taskfile more consistent * update task calls * run tidy * drop `@` tag for version * use relative paths * tidy * fix auto-setting variables * update build paths * add contributing guide * tidy
27 lines
879 B
Go
27 lines
879 B
Go
package v1
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/go-chi/chi/v5"
|
|
"github.com/google/uuid"
|
|
"github.com/hay-kot/homebox/backend/internal/sys/validate"
|
|
)
|
|
|
|
// routeID extracts the ID from the request URL. If the ID is not in a valid
|
|
// format, an error is returned. If a error is returned, it can be directly returned
|
|
// from the handler. the validate.ErrInvalidID error is known by the error middleware
|
|
// and will be handled accordingly.
|
|
//
|
|
// Example: /api/v1/ac614db5-d8b8-4659-9b14-6e913a6eb18a -> uuid.UUID{ac614db5-d8b8-4659-9b14-6e913a6eb18a}
|
|
func (ctrl *V1Controller) routeID(r *http.Request) (uuid.UUID, error) {
|
|
return ctrl.routeUUID(r, "id")
|
|
}
|
|
|
|
func (ctrl *V1Controller) routeUUID(r *http.Request, key string) (uuid.UUID, error) {
|
|
ID, err := uuid.Parse(chi.URLParam(r, key))
|
|
if err != nil {
|
|
return uuid.Nil, validate.NewInvalidRouteKeyError(key)
|
|
}
|
|
return ID, nil
|
|
}
|