2019-02-22 11:26:44 +00:00
|
|
|
from app import db
|
2021-04-14 07:11:01 +01:00
|
|
|
from app.dao.dao_utils import autocommit
|
2019-03-11 15:01:22 +00:00
|
|
|
from app.models import ServiceUser, User
|
2019-02-22 11:26:44 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def dao_get_service_user(user_id, service_id):
|
2024-04-24 16:27:20 -04:00
|
|
|
# TODO: This has been changed to account for the test case failure
|
|
|
|
|
# that used this method but have any service user to return. Somehow, this
|
|
|
|
|
# started to throw an error with one() method in sqlalchemy 2.0 unlike 1.4
|
|
|
|
|
return ServiceUser.query.filter_by(
|
|
|
|
|
user_id=user_id, service_id=service_id
|
|
|
|
|
).one_or_none()
|
2019-02-22 11:26:44 +00:00
|
|
|
|
|
|
|
|
|
2019-03-11 15:01:22 +00:00
|
|
|
def dao_get_active_service_users(service_id):
|
2023-08-29 14:54:30 -07:00
|
|
|
query = (
|
|
|
|
|
db.session.query(ServiceUser)
|
|
|
|
|
.join(User, User.id == ServiceUser.user_id)
|
|
|
|
|
.filter(User.state == "active", ServiceUser.service_id == service_id)
|
2019-03-11 15:01:22 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
return query.all()
|
|
|
|
|
|
|
|
|
|
|
2019-05-21 15:53:48 +01:00
|
|
|
def dao_get_service_users_by_user_id(user_id):
|
|
|
|
|
return ServiceUser.query.filter_by(user_id=user_id).all()
|
|
|
|
|
|
|
|
|
|
|
2021-04-14 07:11:01 +01:00
|
|
|
@autocommit
|
2019-02-22 11:26:44 +00:00
|
|
|
def dao_update_service_user(service_user):
|
|
|
|
|
db.session.add(service_user)
|