ExtractWorkspaceBuildParam grabs workspace build from the "workspacebuild" URL parameter.
(db database.Store)
| 24 | |
| 25 | // ExtractWorkspaceBuildParam grabs workspace build from the "workspacebuild" URL parameter. |
| 26 | func ExtractWorkspaceBuildParam(db database.Store) func(http.Handler) http.Handler { |
| 27 | return func(next http.Handler) http.Handler { |
| 28 | return http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) { |
| 29 | ctx := r.Context() |
| 30 | workspaceBuildID, parsed := ParseUUIDParam(rw, r, "workspacebuild") |
| 31 | if !parsed { |
| 32 | return |
| 33 | } |
| 34 | workspaceBuild, err := db.GetWorkspaceBuildByID(ctx, workspaceBuildID) |
| 35 | if httpapi.Is404Error(err) { |
| 36 | httpapi.ResourceNotFound(rw) |
| 37 | return |
| 38 | } |
| 39 | if err != nil { |
| 40 | httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{ |
| 41 | Message: "Internal error fetching workspace build.", |
| 42 | Detail: err.Error(), |
| 43 | }) |
| 44 | return |
| 45 | } |
| 46 | |
| 47 | ctx = context.WithValue(ctx, workspaceBuildParamContextKey{}, workspaceBuild) |
| 48 | // This injects the "workspace" parameter, because it's expected the consumer |
| 49 | // will want to use the Workspace middleware to ensure the caller owns the workspace. |
| 50 | chi.RouteContext(ctx).URLParams.Add("workspace", workspaceBuild.WorkspaceID.String()) |
| 51 | next.ServeHTTP(rw, r.WithContext(ctx)) |
| 52 | }) |
| 53 | } |
| 54 | } |