mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-17 02:32:32 -05:00
34 lines
867 B
Python
34 lines
867 B
Python
from sqlalchemy import select
|
|
|
|
from app import db
|
|
from app.dao.dao_utils import autocommit
|
|
from app.models import ServiceUser, User
|
|
|
|
|
|
def dao_get_service_user(user_id, service_id):
|
|
stmt = select(ServiceUser).filter_by(user_id=user_id, service_id=service_id)
|
|
return db.session.execute(stmt).scalars().one_or_none()
|
|
|
|
|
|
def dao_get_active_service_users(service_id):
|
|
|
|
stmt = (
|
|
select(ServiceUser)
|
|
.join(User, User.id == ServiceUser.user_id)
|
|
.filter(User.state == "active", ServiceUser.service_id == service_id)
|
|
)
|
|
return db.session.execute(stmt).scalars().all()
|
|
|
|
|
|
def dao_get_service_users_by_user_id(user_id):
|
|
return (
|
|
db.session.execute(select(ServiceUser).filter_by(user_id=user_id))
|
|
.scalars()
|
|
.all()
|
|
)
|
|
|
|
|
|
@autocommit
|
|
def dao_update_service_user(service_user):
|
|
db.session.add(service_user)
|