blob: 39df0194d2a24a4663ed6c73e1e03e3467c10fd5 [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