mirror of
https://github.com/containers/podman.git
synced 2025-07-15 03:02:52 +08:00

Implement `podman-remote cp` and break out the logic from the previously added `pkg/copy` into it's basic building blocks and move them up into the `ContainerEngine` interface and `cmd/podman`. The `--pause` and `--extract` flags are now deprecated and turned into nops. Note that this commit is vendoring a non-release version of Buildah to pull in updates to the copier package. Signed-off-by: Valentin Rothberg <rothberg@redhat.com>
170 lines
4.8 KiB
Go
170 lines
4.8 KiB
Go
package server
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/containers/podman/v2/pkg/api/handlers/compat"
|
|
"github.com/gorilla/mux"
|
|
)
|
|
|
|
func (s *APIServer) registerAchiveHandlers(r *mux.Router) error {
|
|
// swagger:operation PUT /containers/{name}/archive compat putArchive
|
|
// ---
|
|
// summary: Put files into a container
|
|
// description: Put a tar archive of files into a container
|
|
// tags:
|
|
// - containers (compat)
|
|
// produces:
|
|
// - application/json
|
|
// parameters:
|
|
// - in: path
|
|
// name: name
|
|
// type: string
|
|
// description: container name or id
|
|
// required: true
|
|
// - in: query
|
|
// name: path
|
|
// type: string
|
|
// description: Path to a directory in the container to extract
|
|
// required: true
|
|
// - in: query
|
|
// name: noOverwriteDirNonDir
|
|
// type: string
|
|
// description: if unpacking the given content would cause an existing directory to be replaced with a non-directory and vice versa (1 or true)
|
|
// - in: query
|
|
// name: copyUIDGID
|
|
// type: string
|
|
// description: copy UID/GID maps to the dest file or di (1 or true)
|
|
// - in: body
|
|
// name: request
|
|
// description: tarfile of files to copy into the container
|
|
// schema:
|
|
// type: string
|
|
// responses:
|
|
// 200:
|
|
// description: no error
|
|
// 400:
|
|
// $ref: "#/responses/BadParamError"
|
|
// 403:
|
|
// description: the container rootfs is read-only
|
|
// 404:
|
|
// $ref: "#/responses/NoSuchContainer"
|
|
// 500:
|
|
// $ref: "#/responses/InternalError"
|
|
|
|
// swagger:operation GET /containers/{name}/archive compat getArchive
|
|
// ---
|
|
// summary: Get files from a container
|
|
// description: Get a tar archive of files from a container
|
|
// tags:
|
|
// - containers (compat)
|
|
// produces:
|
|
// - application/json
|
|
// parameters:
|
|
// - in: path
|
|
// name: name
|
|
// type: string
|
|
// description: container name or id
|
|
// required: true
|
|
// - in: query
|
|
// name: path
|
|
// type: string
|
|
// description: Path to a directory in the container to extract
|
|
// required: true
|
|
// responses:
|
|
// 200:
|
|
// description: no error
|
|
// schema:
|
|
// type: string
|
|
// format: binary
|
|
// 400:
|
|
// $ref: "#/responses/BadParamError"
|
|
// 404:
|
|
// $ref: "#/responses/NoSuchContainer"
|
|
// 500:
|
|
// $ref: "#/responses/InternalError"
|
|
r.HandleFunc(VersionedPath("/containers/{name}/archive"), s.APIHandler(compat.Archive)).Methods(http.MethodGet, http.MethodPut, http.MethodHead)
|
|
// Added non version path to URI to support docker non versioned paths
|
|
r.HandleFunc("/containers/{name}/archive", s.APIHandler(compat.Archive)).Methods(http.MethodGet, http.MethodPut, http.MethodHead)
|
|
|
|
/*
|
|
Libpod
|
|
*/
|
|
|
|
// swagger:operation POST /libpod/containers/{name}/archive libpod libpodPutArchive
|
|
// ---
|
|
// summary: Copy files into a container
|
|
// description: Copy a tar archive of files into a container
|
|
// tags:
|
|
// - containers
|
|
// produces:
|
|
// - application/json
|
|
// parameters:
|
|
// - in: path
|
|
// name: name
|
|
// type: string
|
|
// description: container name or id
|
|
// required: true
|
|
// - in: query
|
|
// name: path
|
|
// type: string
|
|
// description: Path to a directory in the container to extract
|
|
// required: true
|
|
// - in: query
|
|
// name: pause
|
|
// type: boolean
|
|
// description: pause the container while copying (defaults to true)
|
|
// default: true
|
|
// - in: body
|
|
// name: request
|
|
// description: tarfile of files to copy into the container
|
|
// schema:
|
|
// type: string
|
|
// responses:
|
|
// 200:
|
|
// description: no error
|
|
// 400:
|
|
// $ref: "#/responses/BadParamError"
|
|
// 403:
|
|
// description: the container rootfs is read-only
|
|
// 404:
|
|
// $ref: "#/responses/NoSuchContainer"
|
|
// 500:
|
|
// $ref: "#/responses/InternalError"
|
|
|
|
// swagger:operation GET /libpod/containers/{name}/archive libpod libpodGetArchive
|
|
// ---
|
|
// summary: Copy files from a container
|
|
// description: Copy a tar archive of files from a container
|
|
// tags:
|
|
// - containers (compat)
|
|
// produces:
|
|
// - application/json
|
|
// parameters:
|
|
// - in: path
|
|
// name: name
|
|
// type: string
|
|
// description: container name or id
|
|
// required: true
|
|
// - in: query
|
|
// name: path
|
|
// type: string
|
|
// description: Path to a directory in the container to extract
|
|
// required: true
|
|
// responses:
|
|
// 200:
|
|
// description: no error
|
|
// schema:
|
|
// type: string
|
|
// format: binary
|
|
// 400:
|
|
// $ref: "#/responses/BadParamError"
|
|
// 404:
|
|
// $ref: "#/responses/NoSuchContainer"
|
|
// 500:
|
|
// $ref: "#/responses/InternalError"
|
|
r.HandleFunc(VersionedPath("/libpod/containers/{name}/archive"), s.APIHandler(compat.Archive)).Methods(http.MethodGet, http.MethodPut, http.MethodHead)
|
|
|
|
return nil
|
|
}
|