Rename dao method to be more consistent.

Fix sort.
Add one to job_row_number, rows start at 0 which would confus the user.
This commit is contained in:
Rebecca Law
2019-12-18 11:31:33 +00:00
parent aabaa4a971
commit b853c4cdf1
4 changed files with 24 additions and 14 deletions

View File

@@ -5,7 +5,14 @@ from sqlalchemy.dialects.postgresql import insert
from app import db
from app.dao.dao_utils import transactional
from app.models import Notification, NotificationHistory, ReturnedLetter, Job, User, Template
from app.models import (
Job,
Notification,
NotificationHistory,
ReturnedLetter,
Template,
User,
)
def _get_notification_ids_for_references(references):
@@ -43,7 +50,7 @@ def insert_or_update_returned_letters(references):
db.session.connection().execute(stmt)
def get_returned_letter_summary(service_id):
def fetch_returned_letter_summary(service_id):
return db.session.query(
func.count(ReturnedLetter.notification_id).label('returned_letter_count'),
ReturnedLetter.reported_at
@@ -70,7 +77,7 @@ def fetch_returned_letters(service_id, report_date):
table.created_by_id,
User.name.label('user_name'),
Job.original_file_name,
table.job_row_number
(table.job_row_number + 1).label('job_row_number') # row numbers start at 0
).outerjoin(
User, table.created_by_id == User.id
).outerjoin(
@@ -84,7 +91,5 @@ def fetch_returned_letters(service_id, report_date):
desc(ReturnedLetter.reported_at), desc(table.created_at)
)
results = results + query.all()
results = sorted(results[:4], reverse=True)
results = sorted(results, key=lambda i: i.created_at, reverse=True)
return results

View File

@@ -30,7 +30,10 @@ from app.dao.fact_notification_status_dao import (
)
from app.dao.inbound_numbers_dao import dao_allocate_number_for_service
from app.dao.organisation_dao import dao_get_organisation_by_service_id
from app.dao.returned_letters_dao import get_returned_letter_summary, fetch_returned_letters
from app.dao.returned_letters_dao import (
fetch_returned_letter_summary,
fetch_returned_letters
)
from app.dao.service_data_retention_dao import (
fetch_service_data_retention,
fetch_service_data_retention_by_id,
@@ -945,7 +948,7 @@ def check_if_reply_to_address_already_in_use(service_id, email_address):
@service_blueprint.route('/<uuid:service_id>/returned-letter-summary', methods=['GET'])
def returned_letter_summary(service_id):
results = get_returned_letter_summary(service_id)
results = fetch_returned_letter_summary(service_id)
json_results = [{'returned_letter_count': x.returned_letter_count,
'reported_at': x.reported_at.strftime(DATE_FORMAT)