Files
edx-platform/openedx/core/djangoapps/heartbeat/views.py
Kyle McCormick 151bd13666 Use full names for common.djangoapps imports; warn when using old style (#25477)
* Generate common/djangoapps import shims for LMS
* Generate common/djangoapps import shims for Studio
* Stop appending project root to sys.path
* Stop appending common/djangoapps to sys.path
* Import from common.djangoapps.course_action_state instead of course_action_state
* Import from common.djangoapps.course_modes instead of course_modes
* Import from common.djangoapps.database_fixups instead of database_fixups
* Import from common.djangoapps.edxmako instead of edxmako
* Import from common.djangoapps.entitlements instead of entitlements
* Import from common.djangoapps.pipline_mako instead of pipeline_mako
* Import from common.djangoapps.static_replace instead of static_replace
* Import from common.djangoapps.student instead of student
* Import from common.djangoapps.terrain instead of terrain
* Import from common.djangoapps.third_party_auth instead of third_party_auth
* Import from common.djangoapps.track instead of track
* Import from common.djangoapps.util instead of util
* Import from common.djangoapps.xblock_django instead of xblock_django
* Add empty common/djangoapps/__init__.py to fix pytest collection
* Fix pylint formatting violations
* Exclude import_shims/ directory tree from linting
2020-11-10 07:02:01 -05:00

39 lines
1.1 KiB
Python

"""
Views for verifying the health (heartbeat) of the app.
"""
import logging
import six
from common.djangoapps.util.json_request import JsonResponse
from .runchecks import runchecks
log = logging.getLogger(__name__)
def heartbeat(request):
"""
Simple view that a loadbalancer can check to verify that the app is up. Returns a json doc
of service id: status or message. If the status for any service is anything other than True,
it returns HTTP code 503 (Service Unavailable); otherwise, it returns 200.
"""
check_results = {}
try:
check_results = runchecks('extended' in request.GET)
status_code = 200 # Default to OK
for check in check_results:
if not check_results[check]['status']:
status_code = 503 # 503 on any failure
except Exception as e:
status_code = 503
check_results = {'error': six.text_type(e)}
if status_code == 503:
log.error(u'Heartbeat check failed (%s): %s', status_code, check_results)
return JsonResponse(check_results, status=status_code)