mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-01 07:35:34 -05:00
Merge pull request #2617 from alphagov/notification-count-for-job
Return count of notifications in the database for a job
This commit is contained in:
@@ -178,6 +178,11 @@ def get_notifications_for_job(service_id, job_id, filter_dict=None, page=1, page
|
||||
)
|
||||
|
||||
|
||||
@statsd(namespace="dao")
|
||||
def dao_get_notification_count_for_job_id(*, job_id):
|
||||
return Notification.query.filter_by(job_id=job_id).count()
|
||||
|
||||
|
||||
@statsd(namespace="dao")
|
||||
def get_notification_with_personalisation(service_id, notification_id, key_type):
|
||||
filter_dict = {'service_id': service_id, 'id': notification_id}
|
||||
|
||||
@@ -20,7 +20,7 @@ from app.dao.jobs_dao import (
|
||||
from app.dao.fact_notification_status_dao import fetch_notification_statuses_for_job
|
||||
from app.dao.services_dao import dao_fetch_service_by_id
|
||||
from app.dao.templates_dao import dao_get_template_by_id
|
||||
from app.dao.notifications_dao import get_notifications_for_job
|
||||
from app.dao.notifications_dao import dao_get_notification_count_for_job_id, get_notifications_for_job
|
||||
from app.schemas import (
|
||||
job_schema,
|
||||
unarchived_template_schema,
|
||||
@@ -108,6 +108,15 @@ def get_all_notifications_for_service_job(service_id, job_id):
|
||||
), 200
|
||||
|
||||
|
||||
@job_blueprint.route('/<job_id>/notification_count', methods=['GET'])
|
||||
def get_notification_count_for_job_id(service_id, job_id):
|
||||
dao_get_job_by_service_id_and_job_id(service_id, job_id)
|
||||
count = dao_get_notification_count_for_job_id(job_id=job_id)
|
||||
return jsonify(
|
||||
count=count
|
||||
), 200
|
||||
|
||||
|
||||
@job_blueprint.route('', methods=['GET'])
|
||||
def get_jobs_by_service(service_id):
|
||||
if request.args.get('limit_days'):
|
||||
|
||||
Reference in New Issue
Block a user