blob: 26d00acf4142f1352f8291225a7922490b74e85a [file] [log] [blame]
#!/usr/bin/env python
# encoding: utf-8
#
# 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.
#
"""This module provides core classes.
"""
from flask_sqlalchemy import SQLAlchemy
DB = SQLAlchemy()
class Ec2stackError(Exception):
def __init__(self, code, error, message):
self.code = code
self.error = error
self.message = message
class Service(object):
__model__ = None
def _isinstance(self, model, raise_error=True):
"""
Checks if the given model is an instance of the service.
@param model: Model to be checked.
@param raise_error: ValueError if model isn't the correct type.
@return: Bool @raise ValueError: stating not of correct type.
"""
valid_type = isinstance(model, self.__model__)
if not valid_type and raise_error:
raise ValueError('%s is not of type %s' % (model, self.__model__))
return valid_type
def save(self, model):
"""
Saves the given Model.
@param model: The model to be saved.
@return: The saved model.
"""
self._isinstance(model)
DB.session.add(model)
DB.session.commit()
return model
def get(self, primarykey):
"""
Get the model via primarykey.
@param primarykey: primarykey of the model you want.
@return: Found model.
"""
return self.__model__.query.get(primarykey)
def create(self, **kwargs):
"""
Creates a new object.
@param kwargs: Parameters for the model.
@return: Created model.
"""
return self.save(self.__model__(**kwargs))
def delete(self, model):
"""
Deletes the given model.
@param model: Model to be deleted.
"""
self._isinstance(model)
DB.session.delete(model)
DB.session.commit()