filter the Notifications result by trial_service_mode

This commit is contained in:
venusbb
2017-09-15 14:40:56 +01:00
parent 5e74a1a9ae
commit 9de7ae11e8
2 changed files with 16 additions and 6 deletions

View File

@@ -358,14 +358,19 @@ def dao_fetch_monthly_historical_stats_for_service(service_id, year):
@statsd(namespace='dao') @statsd(namespace='dao')
def dao_fetch_todays_stats_for_all_services(include_from_test_key=True): def dao_fetch_todays_stats_for_all_services(include_from_test_key=True, trial_mode_services=True):
# service_id = db.session.query(Service.id).filter(Service.restricted == True)
query = db.session.query( query = db.session.query(
Notification.notification_type, Notification.notification_type,
Notification.status, Notification.status,
Notification.service_id, Notification.service_id,
func.count(Notification.id).label('count') func.count(Notification.id).label('count')
).join(Service
).filter( ).filter(
func.date(Notification.created_at) == date.today() func.date(Notification.created_at) == date.today(),
Service.restricted == trial_mode_services
).group_by( ).group_by(
Notification.notification_type, Notification.notification_type,
Notification.status, Notification.status,

View File

@@ -82,6 +82,7 @@ def get_services():
detailed = request.args.get('detailed') == 'True' detailed = request.args.get('detailed') == 'True'
user_id = request.args.get('user_id', None) user_id = request.args.get('user_id', None)
include_from_test_key = request.args.get('include_from_test_key', 'True') != 'False' include_from_test_key = request.args.get('include_from_test_key', 'True') != 'False'
trial_mode_services = request.args.get('trial_mode_services')
# If start and end date are not set, we are expecting today's stats. # If start and end date are not set, we are expecting today's stats.
today = str(datetime.utcnow().date()) today = str(datetime.utcnow().date())
@@ -92,12 +93,15 @@ def get_services():
if user_id: if user_id:
services = dao_fetch_all_services_by_user(user_id, only_active) services = dao_fetch_all_services_by_user(user_id, only_active)
elif detailed: elif detailed:
return jsonify(data=get_detailed_services(start_date=start_date, end_date=end_date, result = jsonify(data=get_detailed_services(start_date=start_date, end_date=end_date,
only_active=only_active, include_from_test_key=include_from_test_key only_active=only_active, include_from_test_key=include_from_test_key,
trial_mode_services = trial_mode_services
)) ))
return result
else: else:
services = dao_fetch_all_services(only_active) services = dao_fetch_all_services(only_active)
data = service_schema.dump(services, many=True).data data = service_schema.dump(services, many=True).data
return jsonify(data=data) return jsonify(data=data)
@@ -353,10 +357,11 @@ def get_detailed_service(service_id, today_only=False):
return detailed_service_schema.dump(service).data return detailed_service_schema.dump(service).data
def get_detailed_services(start_date, end_date, only_active=False, include_from_test_key=True): def get_detailed_services(start_date, end_date, only_active=False, include_from_test_key=True,
trial_mode_services=True):
services = {service.id: service for service in dao_fetch_all_services(only_active)} services = {service.id: service for service in dao_fetch_all_services(only_active)}
if start_date == datetime.utcnow().date(): if start_date == datetime.utcnow().date():
stats = dao_fetch_todays_stats_for_all_services(include_from_test_key=include_from_test_key) stats = dao_fetch_todays_stats_for_all_services(include_from_test_key=include_from_test_key, trial_mode_services=trial_mode_services)
else: else:
stats = fetch_stats_by_date_range_for_all_services(start_date=start_date, stats = fetch_stats_by_date_range_for_all_services(start_date=start_date,