summaryrefslogtreecommitdiff
path: root/pkg/bindings/connection.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2020-05-20 20:10:51 +0200
committerGitHub <noreply@github.com>2020-05-20 20:10:51 +0200
commitb0bfa0e6da7d1cb0673328cdcff18329ca18cabf (patch)
tree226b022eb0d7aef35ad65dcaa10c6a2ec9f56e7c /pkg/bindings/connection.go
parent09f8f14b4f7d09946d3d5cfc5460ec9923f7da59 (diff)
parentf9c392f50a631a181bc2aa194b9c46504506d657 (diff)
downloadpodman-b0bfa0e6da7d1cb0673328cdcff18329ca18cabf.tar.gz
podman-b0bfa0e6da7d1cb0673328cdcff18329ca18cabf.tar.bz2
podman-b0bfa0e6da7d1cb0673328cdcff18329ca18cabf.zip
Merge pull request #6271 from jwhonce/wip/version
V2 API Version Support
Diffstat (limited to 'pkg/bindings/connection.go')
-rw-r--r--pkg/bindings/connection.go17
1 files changed, 15 insertions, 2 deletions
diff --git a/pkg/bindings/connection.go b/pkg/bindings/connection.go
index d83c0482c..d21d55beb 100644
--- a/pkg/bindings/connection.go
+++ b/pkg/bindings/connection.go
@@ -15,6 +15,7 @@ import (
"strings"
"time"
+ "github.com/blang/semver"
"github.com/containers/libpod/pkg/api/types"
jsoniter "github.com/json-iterator/go"
"github.com/pkg/errors"
@@ -143,7 +144,7 @@ func tcpClient(_url *url.URL) (Connection, error) {
}
// pingNewConnection pings to make sure the RESTFUL service is up
-// and running. it should only be used where initializing a connection
+// and running. it should only be used when initializing a connection
func pingNewConnection(ctx context.Context) error {
client, err := GetClient(ctx)
if err != nil {
@@ -154,8 +155,20 @@ func pingNewConnection(ctx context.Context) error {
if err != nil {
return err
}
+
if response.StatusCode == http.StatusOK {
- return nil
+ v, err := semver.ParseTolerant(response.Header.Get("Libpod-API-Version"))
+ if err != nil {
+ return err
+ }
+
+ switch APIVersion.Compare(v) {
+ case 1, 0:
+ // Server's job when client version is equal or older
+ return nil
+ case -1:
+ return errors.Errorf("server API version is too old. client %q server %q", APIVersion.String(), v.String())
+ }
}
return errors.Errorf("ping response was %q", response.StatusCode)
}