* package structure * some implementation ideas * a lot of working functions * fixed Fuelclient tests * fixed action validation * fixed formatting and pep8 * fixed copyright * fixed unnecessary request during deployment Implements: blueprint fuelclient-refactoring Change-Id: Ice7f96273afb5d96e7970acfc45c61bab620aaed
61 lines
2.0 KiB
Python
61 lines
2.0 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.
|
|
|
|
from fuelclient.cli.error import ArgumentException
|
|
from fuelclient.objects.base import BaseObject
|
|
|
|
|
|
class Release(BaseObject):
|
|
|
|
class_api_path = "releases/"
|
|
instance_api_path = "releases/{0}/"
|
|
|
|
def configure(self, username, password,
|
|
satellite_server_hostname=None, activation_key=None):
|
|
data = {
|
|
"release_id": self.id,
|
|
"username": username,
|
|
"password": password
|
|
}
|
|
satellite_flags = [satellite_server_hostname,
|
|
activation_key]
|
|
|
|
if not any(satellite_flags):
|
|
data.update({
|
|
"license_type": "rhsm",
|
|
"satellite": "",
|
|
"activation_key": ""
|
|
})
|
|
elif all(satellite_flags):
|
|
data.update({
|
|
"license_type": "rhn",
|
|
"satellite": satellite_server_hostname,
|
|
"activation_key": activation_key
|
|
})
|
|
else:
|
|
raise ArgumentException(
|
|
'RedHat satellite settings requires both a'
|
|
' "--satellite-server-hostname" and '
|
|
'a "--activation-key" flags.'
|
|
)
|
|
release_response = self.connection.post_request(
|
|
"redhat/setup/",
|
|
data
|
|
)
|
|
return release_response
|
|
|
|
@classmethod
|
|
def get_all(cls):
|
|
map(cls.init_with_data, cls.get_all_data())
|