blob: 9f42ba343098c0c154b3e5d0c0e63a00853c00c0 [file] [log] [blame]
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from libcloud.container.providers import Provider
from libcloud.container.drivers.docker import DockerContainerDriver, DockerConnection
class JoyentContainerDriver(DockerContainerDriver):
"""
Joyent Triton container driver class.
>>> from libcloud.container.providers import get_driver
>>> driver = get_driver('joyent')
>>> conn = driver(host='https://us-east-1.docker.joyent.com',
port=2376, key_file='key.pem', cert_file='cert.pem')
"""
type = Provider.JOYENT
name = "Joyent Triton"
website = "http://joyent.com"
connectionCls = DockerConnection
supports_clusters = False
def __init__(
self,
key=None,
secret=None,
secure=False,
host="localhost",
port=2376,
key_file=None,
cert_file=None,
):
super(JoyentContainerDriver, self).__init__(
key=key,
secret=secret,
secure=secure,
host=host,
port=port,
key_file=key_file,
cert_file=cert_file,
)
if host.startswith("https://"):
secure = True
# strip the prefix
prefixes = ["http://", "https://"]
for prefix in prefixes:
if host.startswith(prefix):
host = host.strip(prefix)
if key_file or cert_file:
# docker tls authentication-
# https://docs.docker.com/articles/https/
# We pass two files, a key_file with the
# private key and cert_file with the certificate
# libcloud will handle them through LibcloudHTTPSConnection
if not (key_file and cert_file):
raise Exception(
"Needs both private key file and "
"certificate file for tls authentication"
)
self.connection.key_file = key_file
self.connection.cert_file = cert_file
self.connection.secure = True
else:
self.connection.secure = secure
self.connection.host = host
self.connection.port = port