using access token in header!

This commit is contained in:
2025-09-15 21:50:15 +01:00
parent 29c56bee1c
commit e28d9e5d16
3 changed files with 40 additions and 4 deletions

View File

@ -249,13 +249,16 @@ func (h *ImageHandler) reprocessImage(w http.ResponseWriter, r *http.Request) {
func (h *ImageHandler) CreateRoutes(r chi.Router) { func (h *ImageHandler) CreateRoutes(r chi.Router) {
h.logger.Info("Mounting image router") h.logger.Info("Mounting image router")
// Protected routes r.Group(func(r chi.Router) {
r.Use(middleware.ProtectedRouteURL)
r.Get("/{id}", h.serveImage)
})
r.Group(func(r chi.Router) { r.Group(func(r chi.Router) {
r.Use(middleware.ProtectedRoute) r.Use(middleware.ProtectedRoute)
r.Use(middleware.SetJson) r.Use(middleware.SetJson)
r.Get("/", h.listImages) r.Get("/", h.listImages)
r.Get("/{id}", h.serveImage)
r.Post("/{name}", middleware.WithLimit(h.logger, h.limitsManager.HasReachedImageLimit, h.uploadImage)) r.Post("/{name}", middleware.WithLimit(h.logger, h.limitsManager.HasReachedImageLimit, h.uploadImage))
r.Delete("/{image-id}", h.deleteImage) r.Delete("/{image-id}", h.deleteImage)
}) })

View File

@ -50,9 +50,27 @@ func GetUserID(ctx context.Context, logger *log.Logger, w http.ResponseWriter) (
return userIdUuid, nil return userIdUuid, nil
} }
func ProtectedRouteURL(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
token := r.URL.Query().Get("token")
userId, err := GetUserIdFromAccess(token)
if err != nil {
w.WriteHeader(http.StatusUnauthorized)
return
}
contextWithUserId := context.WithValue(r.Context(), USER_ID, userId)
newR := r.WithContext(contextWithUserId)
next.ServeHTTP(w, newR)
})
}
func ProtectedRoute(next http.Handler) http.Handler { func ProtectedRoute(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
token := r.Header.Get("Authorization") token := r.Header.Get("Authorization")
if len(token) < len("Bearer ") { if len(token) < len("Bearer ") {
w.WriteHeader(http.StatusUnauthorized) w.WriteHeader(http.StatusUnauthorized)
return return

View File

@ -11,13 +11,19 @@ type ImageComponentProps = {
export const ImageComponent: Component<ImageComponentProps> = (props) => { export const ImageComponent: Component<ImageComponentProps> = (props) => {
const [isOpen, setIsOpen] = createSignal(false); const [isOpen, setIsOpen] = createSignal(false);
// TODO: make sure this is up to date. Put it behind a resource.
const accessToken = localStorage.getItem("access");
if (accessToken == null) {
return <>Ermm... Access token is not set :(</>
}
return ( return (
<> <>
<div class="relative w-full flex justify-center h-[300px]"> <div class="relative w-full flex justify-center h-[300px]">
<A href={`/image/${props.ID}`} class="flex w-full"> <A href={`/image/${props.ID}`} class="flex w-full">
<img <img
class="flex w-full object-cover rounded-xl" class="flex w-full object-cover rounded-xl"
src={`${base}/images/${props.ID}`} src={`${base}/images/${props.ID}?token=${accessToken}`}
/> />
</A> </A>
<button <button
@ -56,16 +62,25 @@ export const ImageComponent: Component<ImageComponentProps> = (props) => {
); );
}; };
// TODO: these two components are basically identical
// merge the fuckers
export const ImageComponentFullHeight: Component<ImageComponentProps> = (props) => { export const ImageComponentFullHeight: Component<ImageComponentProps> = (props) => {
const [isOpen, setIsOpen] = createSignal(false); const [isOpen, setIsOpen] = createSignal(false);
// TODO: make sure this is up to date. Put it behind a resource.
const accessToken = localStorage.getItem("access");
if (accessToken == null) {
return <>Ermm... Access token is not set :(</>
}
return ( return (
<> <>
<div class="relative w-full flex justify-center"> <div class="relative w-full flex justify-center">
<A href={`/image/${props.ID}`} class="flex w-full"> <A href={`/image/${props.ID}`} class="flex w-full">
<img <img
class="flex w-full object-cover rounded-xl" class="flex w-full object-cover rounded-xl"
src={`${base}/images/${props.ID}`} src={`${base}/images/${props.ID}?token=${accessToken}`}
/> />
</A> </A>
<button <button