Development of an internal social media platform with personalised dashboards for students
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

signals.py 3.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. from __future__ import absolute_import, unicode_literals
  2. import weakref
  3. from django.core.signals import (
  4. got_request_exception, request_finished, request_started,
  5. )
  6. from django.db.backends.signals import connection_created
  7. from django.db.models.signals import (
  8. class_prepared, post_delete, post_init, post_migrate, post_save,
  9. pre_delete, pre_init, pre_save,
  10. )
  11. from django.utils.module_loading import import_string
  12. from django.utils.translation import ugettext_lazy as _, ungettext
  13. from debug_toolbar.panels import Panel
  14. class SignalsPanel(Panel):
  15. template = 'debug_toolbar/panels/signals.html'
  16. SIGNALS = {
  17. 'request_started': request_started,
  18. 'request_finished': request_finished,
  19. 'got_request_exception': got_request_exception,
  20. 'connection_created': connection_created,
  21. 'class_prepared': class_prepared,
  22. 'pre_init': pre_init,
  23. 'post_init': post_init,
  24. 'pre_save': pre_save,
  25. 'post_save': post_save,
  26. 'pre_delete': pre_delete,
  27. 'post_delete': post_delete,
  28. 'post_migrate': post_migrate,
  29. }
  30. def nav_subtitle(self):
  31. signals = self.get_stats()['signals']
  32. num_receivers = sum(len(s[2]) for s in signals)
  33. num_signals = len(signals)
  34. # here we have to handle a double count translation, hence the
  35. # hard coding of one signal
  36. if num_signals == 1:
  37. return ungettext("%(num_receivers)d receiver of 1 signal",
  38. "%(num_receivers)d receivers of 1 signal",
  39. num_receivers) % {'num_receivers': num_receivers}
  40. return ungettext("%(num_receivers)d receiver of %(num_signals)d signals",
  41. "%(num_receivers)d receivers of %(num_signals)d signals",
  42. num_receivers) % {'num_receivers': num_receivers,
  43. 'num_signals': num_signals}
  44. title = _("Signals")
  45. @property
  46. def signals(self):
  47. signals = self.SIGNALS.copy()
  48. for signal in self.toolbar.config['EXTRA_SIGNALS']:
  49. signal_name = signal.rsplit('.', 1)[-1]
  50. signals[signal_name] = import_string(signal)
  51. return signals
  52. def generate_stats(self, request, response):
  53. signals = []
  54. for name, signal in sorted(self.signals.items(), key=lambda x: x[0]):
  55. receivers = []
  56. for receiver in signal.receivers:
  57. receiver = receiver[1]
  58. if isinstance(receiver, weakref.ReferenceType):
  59. receiver = receiver()
  60. if receiver is None:
  61. continue
  62. receiver = getattr(receiver, '__wraps__', receiver)
  63. receiver_name = getattr(receiver, '__name__', str(receiver))
  64. if getattr(receiver, '__self__', None) is not None:
  65. receiver_class_name = getattr(receiver.__self__, '__class__', type).__name__
  66. text = "%s.%s" % (receiver_class_name, receiver_name)
  67. elif getattr(receiver, 'im_class', None) is not None: # Python 2 only
  68. receiver_class_name = receiver.im_class.__name__
  69. text = "%s.%s" % (receiver_class_name, receiver_name)
  70. else:
  71. text = "%s" % receiver_name
  72. receivers.append(text)
  73. signals.append((name, signal, receivers))
  74. self.record_stats({'signals': signals})