Files
deb-python-fuelclient/fuelclient/__init__.py
Bulat Gaifullin 757bdd3b48 Plugin sync added to new CLI
CLI examples:
fuel2 plugins sync
fuel2 plugins sync 1 2

cmd line entry points are sorted in alphabetical order

DocImpact
Closes-Bug: #1472982

Change-Id: I894b05ff1cfa36e1be63fa9d5476c5e534baf773
2015-09-29 18:19:32 +03:00

65 lines
2.1 KiB
Python

# Copyright 2014 Mirantis, Inc.
#
# Licensed 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.
# DO NOT PUT ANY IMPORTS HERE BECAUSE THIS FILE IS USED
# DURING THE INSTALLATION.
try:
import pkg_resources
try:
__version__ = pkg_resources.get_distribution(
"python-fuelclient").version
except pkg_resources.DistributionNotFound:
__version__ = ""
except ImportError:
__version__ = ""
def get_client(resource, version='v1'):
"""Gets an API client for a resource
python-fuelclient provides access to Fuel's API
through a set of per-resource facades. In order to
get a proper facade it's necessary to specify the name
of the API resource and the version of Fuel's API.
:param resource: Name of the resource to get a facade for.
:type resource: str
Valid values are environment, node and task
:param version: Version of the Fuel's API
:type version: str,
Available: v1. Default: v1.
:return: Facade to the specified resource that wraps
calls to the specified version of the API.
"""
from fuelclient import v1
version_map = {
'v1': {
'environment': v1.environment,
'fuel-version': v1.fuelversion,
'network-group': v1.network_group,
'node': v1.node,
'plugins': v1.plugins,
'task': v1.task,
}
}
try:
return version_map[version][resource].get_client()
except KeyError:
msg = 'Cannot load API client for "{r}" in the API version "{v}".'
raise ValueError(msg.format(r=resource, v=version))