ec2stack/core.py (27 lines of code) (raw):

#!/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()