2016-12-19 17:45:46 +00:00
|
|
|
from datetime import datetime
|
|
|
|
|
|
2016-05-10 09:04:22 +01:00
|
|
|
from sqlalchemy import asc
|
|
|
|
|
from app.dao.dao_utils import transactional
|
2016-12-19 16:49:56 +00:00
|
|
|
from app.models import ProviderDetails, ProviderDetailsHistory
|
2016-05-10 09:04:22 +01:00
|
|
|
from app import db
|
|
|
|
|
|
2016-05-10 09:13:02 +01:00
|
|
|
|
2016-05-10 09:04:22 +01:00
|
|
|
def get_provider_details():
|
2016-05-10 15:18:41 +01:00
|
|
|
return ProviderDetails.query.order_by(asc(ProviderDetails.priority), asc(ProviderDetails.notification_type)).all()
|
2016-05-10 09:04:22 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_provider_details_by_id(provider_details_id):
|
|
|
|
|
return ProviderDetails.query.get(provider_details_id)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_provider_details_by_notification_type(notification_type):
|
|
|
|
|
return ProviderDetails.query.filter_by(
|
|
|
|
|
notification_type=notification_type
|
|
|
|
|
).order_by(asc(ProviderDetails.priority)).all()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@transactional
|
|
|
|
|
def dao_update_provider_details(provider_details):
|
2016-12-19 16:49:56 +00:00
|
|
|
provider_details.version += 1
|
2016-12-19 17:45:46 +00:00
|
|
|
provider_details.updated_at = datetime.utcnow()
|
2016-12-19 16:49:56 +00:00
|
|
|
history = ProviderDetailsHistory.from_original(provider_details)
|
2016-05-10 09:04:22 +01:00
|
|
|
db.session.add(provider_details)
|
2016-12-19 16:49:56 +00:00
|
|
|
db.session.add(history)
|