mirror of
				https://github.com/containers/podman.git
				synced 2025-10-31 10:00:01 +08:00 
			
		
		
		
	 ee782fcb70
			
		
	
	ee782fcb70
	
	
	
		
			
			Fixes: https://github.com/containers/podman/issues/14208 Signed-off-by: Daniel J Walsh <dwalsh@redhat.com>
		
			
				
	
	
		
			75 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package compat
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 
 | |
| 	"github.com/containers/podman/v4/libpod"
 | |
| 	"github.com/containers/podman/v4/pkg/api/handlers/utils"
 | |
| 	api "github.com/containers/podman/v4/pkg/api/types"
 | |
| 	"github.com/containers/podman/v4/pkg/domain/entities"
 | |
| 	"github.com/containers/podman/v4/pkg/domain/infra/abi"
 | |
| 	"github.com/containers/storage"
 | |
| 	"github.com/gorilla/schema"
 | |
| 	"github.com/pkg/errors"
 | |
| )
 | |
| 
 | |
| func RemoveImage(w http.ResponseWriter, r *http.Request) {
 | |
| 	decoder := r.Context().Value(api.DecoderKey).(*schema.Decoder)
 | |
| 	runtime := r.Context().Value(api.RuntimeKey).(*libpod.Runtime)
 | |
| 
 | |
| 	query := struct {
 | |
| 		Force   bool `schema:"force"`
 | |
| 		NoPrune bool `schema:"noprune"`
 | |
| 	}{
 | |
| 		// This is where you can override the golang default value for one of fields
 | |
| 	}
 | |
| 
 | |
| 	if err := decoder.Decode(&query, r.URL.Query()); err != nil {
 | |
| 		utils.Error(w, http.StatusBadRequest, errors.Wrapf(err, "failed to parse parameters for %s", r.URL.String()))
 | |
| 		return
 | |
| 	}
 | |
| 	if _, found := r.URL.Query()["noprune"]; found {
 | |
| 		if query.NoPrune {
 | |
| 			utils.UnSupportedParameter("noprune")
 | |
| 		}
 | |
| 	}
 | |
| 	name := utils.GetName(r)
 | |
| 	possiblyNormalizedName, err := utils.NormalizeToDockerHub(r, name)
 | |
| 	if err != nil {
 | |
| 		utils.Error(w, http.StatusInternalServerError, errors.Wrap(err, "error normalizing image"))
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	imageEngine := abi.ImageEngine{Libpod: runtime}
 | |
| 
 | |
| 	options := entities.ImageRemoveOptions{
 | |
| 		Force: query.Force,
 | |
| 	}
 | |
| 	report, rmerrors := imageEngine.Remove(r.Context(), []string{possiblyNormalizedName}, options)
 | |
| 	if len(rmerrors) > 0 && rmerrors[0] != nil {
 | |
| 		err := rmerrors[0]
 | |
| 		if errors.Cause(err) == storage.ErrImageUnknown {
 | |
| 			utils.ImageNotFound(w, name, errors.Wrapf(err, "failed to find image %s", name))
 | |
| 			return
 | |
| 		}
 | |
| 		if errors.Cause(err) == storage.ErrImageUsedByContainer {
 | |
| 			utils.Error(w, http.StatusConflict, errors.Wrapf(err, "image %s is in use", name))
 | |
| 			return
 | |
| 		}
 | |
| 		utils.Error(w, http.StatusInternalServerError, err)
 | |
| 		return
 | |
| 	}
 | |
| 	response := make([]map[string]string, 0, len(report.Untagged)+1)
 | |
| 	for _, d := range report.Deleted {
 | |
| 		deleted := make(map[string]string, 1)
 | |
| 		deleted["Deleted"] = d
 | |
| 		response = append(response, deleted)
 | |
| 	}
 | |
| 	for _, u := range report.Untagged {
 | |
| 		untagged := make(map[string]string, 1)
 | |
| 		untagged["Untagged"] = u
 | |
| 		response = append(response, untagged)
 | |
| 	}
 | |
| 	utils.WriteResponse(w, http.StatusOK, response)
 | |
| }
 |