Source code for libcloud.container.drivers.joyent

# 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
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# 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 DockerConnection, DockerContainerDriver

[docs]class JoyentContainerDriver(DockerContainerDriver): """ Joyent Triton container driver class. >>> from libcloud.container.providers import get_driver >>> driver = get_driver('joyent') >>> conn = driver(host='', port=2376, key_file='key.pem', cert_file='cert.pem') """ type = Provider.JOYENT name = "Joyent Triton" website = "" 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().__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- # # 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 = True else: = secure = host self.connection.port = port