a212ef399f
A network operation can fail because of different reasons - yet in many places just one error message is provided. Combined with too broad exception clause, and incorrect assumptions on the reasons of failure (e.g. Neutron service being unavailable causes all other sorts of errors like inability to Allocate IP or Associate it) this leads to multiple errors when just one would suffice. The fix aims to provide sensible error messages in case the network service is down. This includes returning only unique messages in a single response. Partial-Bug: #1301374 Change-Id: Id6c620ca51f7703f35c0c172e39fdf237fa42278 Co-Authored-By: Timur Sufiev <tsufiev@mirantis.com>
84 lines
3.3 KiB
Python
84 lines
3.3 KiB
Python
# Copyright 2012 Nebula, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
"""
|
|
Drop-in replacement for django.contrib.messages which handles Horizon's
|
|
messaging needs (e.g. AJAX communication, etc.).
|
|
"""
|
|
|
|
from django.contrib import messages as _messages
|
|
from django.contrib.messages import constants
|
|
from django.utils.encoding import force_text
|
|
from django.utils.safestring import SafeData # noqa
|
|
|
|
|
|
def horizon_message_already_queued(request, message):
|
|
_message = force_text(message)
|
|
if request.is_ajax():
|
|
for tag, msg, extra in request.horizon['async_messages']:
|
|
if _message == msg:
|
|
return True
|
|
else:
|
|
for msg in _messages.get_messages(request)._queued_messages:
|
|
if msg.message == _message:
|
|
return True
|
|
return False
|
|
|
|
|
|
def add_message(request, level, message, extra_tags='', fail_silently=False):
|
|
"""Attempts to add a message to the request using the 'messages' app."""
|
|
if not horizon_message_already_queued(request, message):
|
|
if request.is_ajax():
|
|
tag = constants.DEFAULT_TAGS[level]
|
|
# if message is marked as safe, pass "safe" tag as extra_tags so
|
|
# that client can skip HTML escape for the message when rendering
|
|
if isinstance(message, SafeData):
|
|
extra_tags = extra_tags + ' safe'
|
|
request.horizon['async_messages'].append([tag,
|
|
force_text(message),
|
|
extra_tags])
|
|
else:
|
|
return _messages.add_message(request, level, message,
|
|
extra_tags, fail_silently)
|
|
|
|
|
|
def debug(request, message, extra_tags='', fail_silently=False):
|
|
"""Adds a message with the ``DEBUG`` level."""
|
|
add_message(request, constants.DEBUG, message, extra_tags=extra_tags,
|
|
fail_silently=fail_silently)
|
|
|
|
|
|
def info(request, message, extra_tags='', fail_silently=False):
|
|
"""Adds a message with the ``INFO`` level."""
|
|
add_message(request, constants.INFO, message, extra_tags=extra_tags,
|
|
fail_silently=fail_silently)
|
|
|
|
|
|
def success(request, message, extra_tags='', fail_silently=False):
|
|
"""Adds a message with the ``SUCCESS`` level."""
|
|
add_message(request, constants.SUCCESS, message, extra_tags=extra_tags,
|
|
fail_silently=fail_silently)
|
|
|
|
|
|
def warning(request, message, extra_tags='', fail_silently=False):
|
|
"""Adds a message with the ``WARNING`` level."""
|
|
add_message(request, constants.WARNING, message, extra_tags=extra_tags,
|
|
fail_silently=fail_silently)
|
|
|
|
|
|
def error(request, message, extra_tags='', fail_silently=False):
|
|
"""Adds a message with the ``ERROR`` level."""
|
|
add_message(request, constants.ERROR, message, extra_tags=extra_tags,
|
|
fail_silently=fail_silently)
|