|
@@ -3,41 +3,18 @@ import logging
|
|
import os
|
|
import os
|
|
import re
|
|
import re
|
|
import yaml
|
|
import yaml
|
|
-import socket
|
|
|
|
|
|
|
|
from ..project import Project
|
|
from ..project import Project
|
|
from .docopt_command import DocoptCommand
|
|
from .docopt_command import DocoptCommand
|
|
from .formatter import Formatter
|
|
from .formatter import Formatter
|
|
-from .utils import cached_property
|
|
|
|
-from .errors import UserError
|
|
|
|
|
|
+from .utils import cached_property, docker_url
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
class Command(DocoptCommand):
|
|
class Command(DocoptCommand):
|
|
@cached_property
|
|
@cached_property
|
|
def client(self):
|
|
def client(self):
|
|
- if os.environ.get('DOCKER_URL'):
|
|
|
|
- return Client(os.environ['DOCKER_URL'])
|
|
|
|
-
|
|
|
|
- socket_path = '/var/run/docker.sock'
|
|
|
|
- tcp_host = '127.0.0.1'
|
|
|
|
- tcp_port = 4243
|
|
|
|
-
|
|
|
|
- if os.path.exists(socket_path):
|
|
|
|
- return Client('unix://%s' % socket_path)
|
|
|
|
-
|
|
|
|
- try:
|
|
|
|
- s = socket.socket()
|
|
|
|
- s.connect((tcp_host, tcp_port))
|
|
|
|
- s.close()
|
|
|
|
- return Client('http://%s:%s' % (tcp_host, tcp_port))
|
|
|
|
- except:
|
|
|
|
- pass
|
|
|
|
-
|
|
|
|
- raise UserError("""
|
|
|
|
- Couldn't find Docker daemon - tried %s and %s:%s.
|
|
|
|
- If it's running elsewhere, specify a url with DOCKER_URL.
|
|
|
|
- """ % (socket_path, tcp_host, tcp_port))
|
|
|
|
|
|
+ return Client(docker_url())
|
|
|
|
|
|
@cached_property
|
|
@cached_property
|
|
def project(self):
|
|
def project(self):
|