summaryrefslogtreecommitdiffstats
path: root/snaps/openstack/openstack_creator.py
diff options
context:
space:
mode:
Diffstat (limited to 'snaps/openstack/openstack_creator.py')
-rw-r--r--snaps/openstack/openstack_creator.py26
1 files changed, 25 insertions, 1 deletions
diff --git a/snaps/openstack/openstack_creator.py b/snaps/openstack/openstack_creator.py
index de2ae91..945a78b 100644
--- a/snaps/openstack/openstack_creator.py
+++ b/snaps/openstack/openstack_creator.py
@@ -13,7 +13,8 @@
# See the License for the specific language governing permissions and
# limitations under the License.
from snaps.domain.creator import CloudObject
-from snaps.openstack.utils import nova_utils, neutron_utils, keystone_utils
+from snaps.openstack.utils import (nova_utils, neutron_utils, keystone_utils,
+ cinder_utils)
__author__ = 'spisarski'
@@ -108,3 +109,26 @@ class OpenStackIdentityObject(OpenStackCloudObject):
def clean(self):
raise NotImplementedError('Do not override abstract method')
+
+
+class OpenStackVolumeObject(OpenStackCloudObject):
+ """
+ Abstract class for all OpenStack compute creators
+ """
+
+ def __init__(self, os_creds):
+ """
+ Constructor
+ :param os_creds: the OpenStack credentials object
+ """
+ super(OpenStackVolumeObject, self).__init__(os_creds)
+ self._cinder = None
+
+ def initialize(self):
+ self._cinder = cinder_utils.cinder_client(self._os_creds)
+
+ def create(self):
+ raise NotImplementedError('Do not override abstract method')
+
+ def clean(self):
+ raise NotImplementedError('Do not override abstract method')