mirror of
https://github.com/containers/podman.git
synced 2025-05-21 00:56:36 +08:00
v2 copy endpoints
add copy endpoint inputs and outputs. these endpoints are not implemented yet, nor are any bindings. this allows us to update this later without having to change our api version. Signed-off-by: Brent Baude <bbaude@redhat.com>
This commit is contained in:
12
pkg/api/handlers/compat/containers_archive.go
Normal file
12
pkg/api/handlers/compat/containers_archive.go
Normal file
@ -0,0 +1,12 @@
|
||||
package compat
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"net/http"
|
||||
|
||||
"github.com/containers/libpod/pkg/api/handlers/utils"
|
||||
)
|
||||
|
||||
func Archive(w http.ResponseWriter, r *http.Request) {
|
||||
utils.Error(w, "not implemented", http.StatusNotImplemented, errors.New("not implemented"))
|
||||
}
|
12
pkg/api/handlers/libpod/copy.go
Normal file
12
pkg/api/handlers/libpod/copy.go
Normal file
@ -0,0 +1,12 @@
|
||||
package libpod
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/containers/libpod/pkg/api/handlers/utils"
|
||||
"github.com/pkg/errors"
|
||||
)
|
||||
|
||||
func Archive(w http.ResponseWriter, r *http.Request) {
|
||||
utils.Error(w, "not implemented", http.StatusNotImplemented, errors.New("not implemented"))
|
||||
}
|
171
pkg/api/server/register_archive.go
Normal file
171
pkg/api/server/register_archive.go
Normal file
@ -0,0 +1,171 @@
|
||||
package server
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/containers/libpod/pkg/api/handlers/compat"
|
||||
"github.com/containers/libpod/pkg/api/handlers/libpod"
|
||||
"github.com/gorilla/mux"
|
||||
)
|
||||
|
||||
func (s *APIServer) registerAchiveHandlers(r *mux.Router) error {
|
||||
// swagger:operation POST /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.MethodPost)
|
||||
// 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.MethodPost)
|
||||
|
||||
/*
|
||||
Libpod
|
||||
*/
|
||||
|
||||
// swagger:operation POST /libpod/containers/{name}/copy 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}/copy 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}/copy"), s.APIHandler(libpod.Archive)).Methods(http.MethodGet, http.MethodPost)
|
||||
r.HandleFunc(VersionedPath("/libpod/containers/{name}/archive"), s.APIHandler(libpod.Archive)).Methods(http.MethodGet, http.MethodPost)
|
||||
|
||||
return nil
|
||||
}
|
@ -102,6 +102,7 @@ func newServer(runtime *libpod.Runtime, duration time.Duration, listener *net.Li
|
||||
|
||||
for _, fn := range []func(*mux.Router) error{
|
||||
server.registerAuthHandlers,
|
||||
server.registerAchiveHandlers,
|
||||
server.registerContainersHandlers,
|
||||
server.registerDistributionHandlers,
|
||||
server.registerEventsHandlers,
|
||||
|
Reference in New Issue
Block a user