django-cfg 1.2.31__py3-none-any.whl → 1.3.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (256) hide show
  1. django_cfg/__init__.py +1 -1
  2. django_cfg/apps/api/health/views.py +4 -2
  3. django_cfg/apps/knowbase/config/settings.py +16 -15
  4. django_cfg/apps/payments/README.md +326 -0
  5. django_cfg/apps/payments/admin/__init__.py +20 -10
  6. django_cfg/apps/payments/admin/api_keys_admin.py +521 -237
  7. django_cfg/apps/payments/admin/balance_admin.py +592 -297
  8. django_cfg/apps/payments/admin/currencies_admin.py +526 -222
  9. django_cfg/apps/payments/admin/filters.py +306 -199
  10. django_cfg/apps/payments/admin/payments_admin.py +465 -70
  11. django_cfg/apps/payments/admin/subscriptions_admin.py +578 -128
  12. django_cfg/apps/payments/admin_interface/__init__.py +18 -0
  13. django_cfg/apps/payments/admin_interface/templates/payments/base.html +162 -0
  14. django_cfg/apps/payments/admin_interface/templates/payments/components/dev_tool_card.html +38 -0
  15. django_cfg/apps/payments/admin_interface/templates/payments/components/loading_spinner.html +16 -0
  16. django_cfg/apps/payments/admin_interface/templates/payments/components/notification.html +27 -0
  17. django_cfg/apps/payments/admin_interface/templates/payments/components/provider_card.html +86 -0
  18. django_cfg/apps/payments/admin_interface/templates/payments/components/status_card.html +39 -0
  19. django_cfg/apps/payments/admin_interface/templates/payments/currency_converter.html +382 -0
  20. django_cfg/apps/payments/admin_interface/templates/payments/payment_dashboard.html +300 -0
  21. django_cfg/apps/payments/admin_interface/templates/payments/payment_form.html +303 -0
  22. django_cfg/apps/payments/admin_interface/templates/payments/payment_list.html +382 -0
  23. django_cfg/apps/payments/admin_interface/templates/payments/payment_status.html +500 -0
  24. django_cfg/apps/payments/admin_interface/templates/payments/webhook_dashboard.html +594 -0
  25. django_cfg/apps/payments/admin_interface/views/__init__.py +23 -0
  26. django_cfg/apps/payments/admin_interface/views/payment_views.py +259 -0
  27. django_cfg/apps/payments/admin_interface/views/webhook_dashboard.py +37 -0
  28. django_cfg/apps/payments/apps.py +34 -9
  29. django_cfg/apps/payments/config/__init__.py +28 -51
  30. django_cfg/apps/payments/config/constance/__init__.py +22 -0
  31. django_cfg/apps/payments/config/constance/config_service.py +123 -0
  32. django_cfg/apps/payments/config/constance/fields.py +69 -0
  33. django_cfg/apps/payments/config/constance/settings.py +160 -0
  34. django_cfg/apps/payments/config/django_cfg_integration.py +202 -0
  35. django_cfg/apps/payments/config/helpers.py +130 -0
  36. django_cfg/apps/payments/management/__init__.py +1 -3
  37. django_cfg/apps/payments/management/commands/__init__.py +1 -3
  38. django_cfg/apps/payments/management/commands/manage_currencies.py +303 -151
  39. django_cfg/apps/payments/management/commands/manage_providers.py +333 -160
  40. django_cfg/apps/payments/middleware/__init__.py +3 -1
  41. django_cfg/apps/payments/middleware/api_access.py +329 -222
  42. django_cfg/apps/payments/middleware/rate_limiting.py +342 -152
  43. django_cfg/apps/payments/middleware/usage_tracking.py +249 -240
  44. django_cfg/apps/payments/migrations/0001_initial.py +708 -536
  45. django_cfg/apps/payments/models/__init__.py +13 -18
  46. django_cfg/apps/payments/models/api_keys.py +121 -43
  47. django_cfg/apps/payments/models/balance.py +150 -115
  48. django_cfg/apps/payments/models/base.py +68 -15
  49. django_cfg/apps/payments/models/currencies.py +172 -148
  50. django_cfg/apps/payments/models/managers/__init__.py +44 -0
  51. django_cfg/apps/payments/models/managers/api_key_managers.py +329 -0
  52. django_cfg/apps/payments/models/managers/balance_managers.py +599 -0
  53. django_cfg/apps/payments/models/managers/currency_managers.py +385 -0
  54. django_cfg/apps/payments/models/managers/payment_managers.py +511 -0
  55. django_cfg/apps/payments/models/managers/subscription_managers.py +641 -0
  56. django_cfg/apps/payments/models/payments.py +235 -285
  57. django_cfg/apps/payments/models/subscriptions.py +257 -177
  58. django_cfg/apps/payments/models/tariffs.py +147 -40
  59. django_cfg/apps/payments/services/__init__.py +209 -56
  60. django_cfg/apps/payments/services/cache/__init__.py +6 -6
  61. django_cfg/apps/payments/services/cache/{simple_cache.py → cache_service.py} +112 -12
  62. django_cfg/apps/payments/services/core/__init__.py +10 -6
  63. django_cfg/apps/payments/services/core/balance_service.py +435 -360
  64. django_cfg/apps/payments/services/core/base.py +166 -0
  65. django_cfg/apps/payments/services/core/currency_service.py +478 -0
  66. django_cfg/apps/payments/services/core/payment_service.py +346 -467
  67. django_cfg/apps/payments/services/core/subscription_service.py +425 -481
  68. django_cfg/apps/payments/services/core/webhook_service.py +410 -0
  69. django_cfg/apps/payments/services/integrations/__init__.py +29 -0
  70. django_cfg/apps/payments/services/integrations/ngrok_service.py +47 -0
  71. django_cfg/apps/payments/services/integrations/providers_config.py +107 -0
  72. django_cfg/apps/payments/services/providers/__init__.py +9 -14
  73. django_cfg/apps/payments/services/providers/base.py +234 -174
  74. django_cfg/apps/payments/services/providers/nowpayments.py +478 -0
  75. django_cfg/apps/payments/services/providers/registry.py +367 -301
  76. django_cfg/apps/payments/services/types/__init__.py +78 -0
  77. django_cfg/apps/payments/services/types/data.py +177 -0
  78. django_cfg/apps/payments/services/types/requests.py +150 -0
  79. django_cfg/apps/payments/services/types/responses.py +156 -0
  80. django_cfg/apps/payments/services/types/webhooks.py +232 -0
  81. django_cfg/apps/payments/signals/__init__.py +33 -8
  82. django_cfg/apps/payments/signals/api_key_signals.py +210 -129
  83. django_cfg/apps/payments/signals/balance_signals.py +174 -0
  84. django_cfg/apps/payments/signals/payment_signals.py +128 -103
  85. django_cfg/apps/payments/signals/subscription_signals.py +194 -142
  86. django_cfg/apps/payments/static/payments/css/components.css +380 -0
  87. django_cfg/apps/payments/static/payments/css/dashboard.css +188 -0
  88. django_cfg/apps/payments/static/payments/js/components.js +545 -0
  89. django_cfg/apps/payments/static/payments/js/utils.js +412 -0
  90. django_cfg/apps/payments/templatetags/__init__.py +1 -1
  91. django_cfg/apps/payments/templatetags/payment_tags.py +466 -0
  92. django_cfg/apps/payments/urls.py +45 -48
  93. django_cfg/apps/payments/urls_admin.py +33 -42
  94. django_cfg/apps/payments/views/api/__init__.py +101 -0
  95. django_cfg/apps/payments/views/api/api_keys.py +387 -0
  96. django_cfg/apps/payments/views/api/balances.py +381 -0
  97. django_cfg/apps/payments/views/api/base.py +298 -0
  98. django_cfg/apps/payments/views/api/currencies.py +402 -0
  99. django_cfg/apps/payments/views/api/payments.py +415 -0
  100. django_cfg/apps/payments/views/api/subscriptions.py +475 -0
  101. django_cfg/apps/payments/views/api/webhooks.py +476 -0
  102. django_cfg/apps/payments/views/serializers/__init__.py +99 -0
  103. django_cfg/apps/payments/views/serializers/api_keys.py +424 -0
  104. django_cfg/apps/payments/views/serializers/balances.py +300 -0
  105. django_cfg/apps/payments/views/serializers/currencies.py +335 -0
  106. django_cfg/apps/payments/views/serializers/payments.py +387 -0
  107. django_cfg/apps/payments/views/serializers/subscriptions.py +429 -0
  108. django_cfg/apps/payments/views/serializers/webhooks.py +137 -0
  109. django_cfg/config.py +1 -1
  110. django_cfg/core/config.py +40 -4
  111. django_cfg/core/generation.py +25 -4
  112. django_cfg/core/integration/README.md +363 -0
  113. django_cfg/core/integration/__init__.py +47 -0
  114. django_cfg/core/integration/commands_collector.py +239 -0
  115. django_cfg/core/integration/display/__init__.py +15 -0
  116. django_cfg/core/integration/display/base.py +157 -0
  117. django_cfg/core/integration/display/ngrok.py +164 -0
  118. django_cfg/core/integration/display/startup.py +815 -0
  119. django_cfg/core/integration/url_integration.py +123 -0
  120. django_cfg/core/integration/version_checker.py +160 -0
  121. django_cfg/management/commands/auto_generate.py +4 -0
  122. django_cfg/management/commands/check_settings.py +6 -0
  123. django_cfg/management/commands/clear_constance.py +5 -2
  124. django_cfg/management/commands/create_token.py +6 -0
  125. django_cfg/management/commands/list_urls.py +6 -0
  126. django_cfg/management/commands/migrate_all.py +6 -0
  127. django_cfg/management/commands/migrator.py +3 -0
  128. django_cfg/management/commands/rundramatiq.py +6 -0
  129. django_cfg/management/commands/runserver_ngrok.py +51 -29
  130. django_cfg/management/commands/script.py +6 -0
  131. django_cfg/management/commands/show_config.py +12 -2
  132. django_cfg/management/commands/show_urls.py +4 -0
  133. django_cfg/management/commands/superuser.py +6 -0
  134. django_cfg/management/commands/task_clear.py +4 -1
  135. django_cfg/management/commands/task_status.py +3 -1
  136. django_cfg/management/commands/test_email.py +3 -0
  137. django_cfg/management/commands/test_telegram.py +6 -0
  138. django_cfg/management/commands/test_twilio.py +6 -0
  139. django_cfg/management/commands/tree.py +6 -0
  140. django_cfg/management/commands/validate_config.py +155 -149
  141. django_cfg/models/constance.py +31 -11
  142. django_cfg/models/payments.py +175 -492
  143. django_cfg/modules/django_logger.py +160 -146
  144. django_cfg/modules/django_unfold/dashboard.py +64 -16
  145. django_cfg/registry/core.py +1 -0
  146. django_cfg/template_archive/django_sample.zip +0 -0
  147. django_cfg/utils/smart_defaults.py +222 -571
  148. django_cfg/utils/toolkit.py +51 -11
  149. {django_cfg-1.2.31.dist-info → django_cfg-1.3.1.dist-info}/METADATA +4 -1
  150. {django_cfg-1.2.31.dist-info → django_cfg-1.3.1.dist-info}/RECORD +153 -185
  151. django_cfg/apps/payments/__init__.py +0 -8
  152. django_cfg/apps/payments/admin/tariffs_admin.py +0 -199
  153. django_cfg/apps/payments/config/module.py +0 -70
  154. django_cfg/apps/payments/config/providers.py +0 -105
  155. django_cfg/apps/payments/config/settings.py +0 -96
  156. django_cfg/apps/payments/config/utils.py +0 -52
  157. django_cfg/apps/payments/decorators.py +0 -291
  158. django_cfg/apps/payments/management/commands/README.md +0 -146
  159. django_cfg/apps/payments/management/commands/currency_stats.py +0 -304
  160. django_cfg/apps/payments/managers/__init__.py +0 -23
  161. django_cfg/apps/payments/managers/api_key_manager.py +0 -35
  162. django_cfg/apps/payments/managers/balance_manager.py +0 -361
  163. django_cfg/apps/payments/managers/currency_manager.py +0 -306
  164. django_cfg/apps/payments/managers/payment_manager.py +0 -192
  165. django_cfg/apps/payments/managers/subscription_manager.py +0 -37
  166. django_cfg/apps/payments/managers/tariff_manager.py +0 -29
  167. django_cfg/apps/payments/migrations/0002_network_providercurrency_and_more.py +0 -241
  168. django_cfg/apps/payments/migrations/0003_add_usd_rate_cache.py +0 -30
  169. django_cfg/apps/payments/models/events.py +0 -73
  170. django_cfg/apps/payments/serializers/__init__.py +0 -57
  171. django_cfg/apps/payments/serializers/api_keys.py +0 -51
  172. django_cfg/apps/payments/serializers/balance.py +0 -59
  173. django_cfg/apps/payments/serializers/currencies.py +0 -63
  174. django_cfg/apps/payments/serializers/payments.py +0 -62
  175. django_cfg/apps/payments/serializers/subscriptions.py +0 -71
  176. django_cfg/apps/payments/serializers/tariffs.py +0 -56
  177. django_cfg/apps/payments/services/billing/__init__.py +0 -8
  178. django_cfg/apps/payments/services/cache/base.py +0 -30
  179. django_cfg/apps/payments/services/core/fallback_service.py +0 -432
  180. django_cfg/apps/payments/services/internal_types.py +0 -461
  181. django_cfg/apps/payments/services/middleware/__init__.py +0 -8
  182. django_cfg/apps/payments/services/monitoring/__init__.py +0 -22
  183. django_cfg/apps/payments/services/monitoring/api_schemas.py +0 -76
  184. django_cfg/apps/payments/services/monitoring/provider_health.py +0 -372
  185. django_cfg/apps/payments/services/providers/cryptapi/__init__.py +0 -4
  186. django_cfg/apps/payments/services/providers/cryptapi/config.py +0 -8
  187. django_cfg/apps/payments/services/providers/cryptapi/models.py +0 -192
  188. django_cfg/apps/payments/services/providers/cryptapi/provider.py +0 -439
  189. django_cfg/apps/payments/services/providers/cryptomus/__init__.py +0 -4
  190. django_cfg/apps/payments/services/providers/cryptomus/models.py +0 -176
  191. django_cfg/apps/payments/services/providers/cryptomus/provider.py +0 -429
  192. django_cfg/apps/payments/services/providers/cryptomus/provider_v2.py +0 -564
  193. django_cfg/apps/payments/services/providers/models/__init__.py +0 -34
  194. django_cfg/apps/payments/services/providers/models/currencies.py +0 -190
  195. django_cfg/apps/payments/services/providers/nowpayments/__init__.py +0 -4
  196. django_cfg/apps/payments/services/providers/nowpayments/models.py +0 -196
  197. django_cfg/apps/payments/services/providers/nowpayments/provider.py +0 -380
  198. django_cfg/apps/payments/services/providers/stripe/__init__.py +0 -4
  199. django_cfg/apps/payments/services/providers/stripe/models.py +0 -184
  200. django_cfg/apps/payments/services/providers/stripe/provider.py +0 -109
  201. django_cfg/apps/payments/services/security/__init__.py +0 -34
  202. django_cfg/apps/payments/services/security/error_handler.py +0 -635
  203. django_cfg/apps/payments/services/security/payment_notifications.py +0 -342
  204. django_cfg/apps/payments/services/security/webhook_validator.py +0 -474
  205. django_cfg/apps/payments/static/payments/css/payments.css +0 -340
  206. django_cfg/apps/payments/static/payments/js/notifications.js +0 -202
  207. django_cfg/apps/payments/static/payments/js/payment-utils.js +0 -318
  208. django_cfg/apps/payments/static/payments/js/theme.js +0 -86
  209. django_cfg/apps/payments/tasks/__init__.py +0 -12
  210. django_cfg/apps/payments/tasks/webhook_processing.py +0 -177
  211. django_cfg/apps/payments/templates/admin/payments/currency/change_list.html +0 -50
  212. django_cfg/apps/payments/templates/payments/base.html +0 -182
  213. django_cfg/apps/payments/templates/payments/components/payment_card.html +0 -201
  214. django_cfg/apps/payments/templates/payments/components/payment_qr_code.html +0 -109
  215. django_cfg/apps/payments/templates/payments/components/progress_bar.html +0 -43
  216. django_cfg/apps/payments/templates/payments/components/provider_stats.html +0 -40
  217. django_cfg/apps/payments/templates/payments/components/status_badge.html +0 -34
  218. django_cfg/apps/payments/templates/payments/components/status_overview.html +0 -148
  219. django_cfg/apps/payments/templates/payments/dashboard.html +0 -258
  220. django_cfg/apps/payments/templates/payments/dashboard_simple_test.html +0 -35
  221. django_cfg/apps/payments/templates/payments/payment_create.html +0 -579
  222. django_cfg/apps/payments/templates/payments/payment_detail.html +0 -373
  223. django_cfg/apps/payments/templates/payments/payment_list.html +0 -354
  224. django_cfg/apps/payments/templates/payments/stats.html +0 -261
  225. django_cfg/apps/payments/templates/payments/test.html +0 -213
  226. django_cfg/apps/payments/templatetags/payments_tags.py +0 -315
  227. django_cfg/apps/payments/utils/__init__.py +0 -43
  228. django_cfg/apps/payments/utils/billing_utils.py +0 -342
  229. django_cfg/apps/payments/utils/config_utils.py +0 -239
  230. django_cfg/apps/payments/utils/middleware_utils.py +0 -228
  231. django_cfg/apps/payments/utils/validation_utils.py +0 -94
  232. django_cfg/apps/payments/views/__init__.py +0 -63
  233. django_cfg/apps/payments/views/api_key_views.py +0 -164
  234. django_cfg/apps/payments/views/balance_views.py +0 -75
  235. django_cfg/apps/payments/views/currency_views.py +0 -122
  236. django_cfg/apps/payments/views/payment_views.py +0 -149
  237. django_cfg/apps/payments/views/subscription_views.py +0 -135
  238. django_cfg/apps/payments/views/tariff_views.py +0 -131
  239. django_cfg/apps/payments/views/templates/__init__.py +0 -25
  240. django_cfg/apps/payments/views/templates/ajax.py +0 -451
  241. django_cfg/apps/payments/views/templates/base.py +0 -212
  242. django_cfg/apps/payments/views/templates/dashboard.py +0 -60
  243. django_cfg/apps/payments/views/templates/payment_detail.py +0 -102
  244. django_cfg/apps/payments/views/templates/payment_management.py +0 -158
  245. django_cfg/apps/payments/views/templates/qr_code.py +0 -174
  246. django_cfg/apps/payments/views/templates/stats.py +0 -244
  247. django_cfg/apps/payments/views/templates/utils.py +0 -181
  248. django_cfg/apps/payments/views/webhook_views.py +0 -266
  249. django_cfg/apps/payments/viewsets.py +0 -66
  250. django_cfg/core/integration.py +0 -160
  251. django_cfg/template_archive/.gitignore +0 -1
  252. django_cfg/template_archive/__init__.py +0 -0
  253. django_cfg/urls.py +0 -33
  254. {django_cfg-1.2.31.dist-info → django_cfg-1.3.1.dist-info}/WHEEL +0 -0
  255. {django_cfg-1.2.31.dist-info → django_cfg-1.3.1.dist-info}/entry_points.txt +0 -0
  256. {django_cfg-1.2.31.dist-info → django_cfg-1.3.1.dist-info}/licenses/LICENSE +0 -0
@@ -1,342 +0,0 @@
1
- """
2
- Payment System Notification Service
3
- Uses existing django_telegram and django_email modules for admin notifications.
4
- """
5
-
6
- from django_cfg.modules.django_logger import get_logger
7
- from typing import Dict, Any, Optional
8
- from django.utils import timezone
9
- from django_cfg.modules.django_telegram import DjangoTelegram
10
- from django_cfg.modules.django_email import DjangoEmailService
11
- from django_cfg.core.config import get_current_config
12
-
13
- logger = get_logger("payment_notifications")
14
- config = get_current_config()
15
-
16
-
17
- class PaymentNotifications:
18
- """
19
- Payment system notifications using existing admin modules.
20
- Follows the pattern from accounts/utils/notifications.py
21
- """
22
-
23
- @staticmethod
24
- def send_security_alert(error_info, context_info):
25
- """Send security alert notification using existing modules."""
26
- try:
27
- # Prepare notification data following the accounts pattern
28
- notification_data = {
29
- "error_code": error_info.error_code,
30
- "category": error_info.category,
31
- "severity": error_info.severity,
32
- "message": error_info.message,
33
- "timestamp": error_info.timestamp.strftime("%Y-%m-%d %H:%M:%S UTC"),
34
- "provider": context_info.provider or "Unknown",
35
- "user_id": context_info.user_id or "Unknown",
36
- "operation": context_info.operation or "Unknown"
37
- }
38
-
39
- # Add request details if available
40
- if context_info.request:
41
- notification_data.update({
42
- "ip_address": context_info.request.get("ip_address", "Unknown"),
43
- "path": context_info.request.get("path", "Unknown"),
44
- "method": context_info.request.get("method", "Unknown")
45
- })
46
-
47
- # Send telegram notification based on severity
48
- if error_info.severity == "CRITICAL":
49
- DjangoTelegram.send_error(
50
- f"🚨 CRITICAL Payment Security Alert: {error_info.category}",
51
- notification_data
52
- )
53
- elif error_info.severity == "HIGH":
54
- DjangoTelegram.send_warning(
55
- f"⚠️ HIGH Payment Security Alert: {error_info.category}",
56
- notification_data
57
- )
58
- else:
59
- DjangoTelegram.send_info(
60
- f"ℹ️ Payment Security Alert: {error_info.category}",
61
- notification_data
62
- )
63
-
64
- logger.info(f"Security alert notification sent: {error_info.error_code}")
65
-
66
- except Exception as e:
67
- logger.error(f"Failed to send security alert notification: {e}")
68
-
69
- @staticmethod
70
- def send_provider_error(error_info, context_info):
71
- """Send provider error notification."""
72
- try:
73
- provider = context_info.provider or "Unknown"
74
-
75
- notification_data = {
76
- "provider": provider,
77
- "error_code": error_info.error_code,
78
- "message": error_info.message,
79
- "severity": error_info.severity,
80
- "timestamp": error_info.timestamp.strftime("%Y-%m-%d %H:%M:%S UTC"),
81
- "operation": context_info.operation or "Unknown",
82
- "recoverable": error_info.recoverable
83
- }
84
-
85
- # Add provider-specific details if available
86
- if hasattr(error_info.details, 'provider'):
87
- notification_data["provider_details"] = error_info.details.provider
88
-
89
- if error_info.severity in ["CRITICAL", "HIGH"]:
90
- DjangoTelegram.send_error(
91
- f"💳 Provider Error: {provider}",
92
- notification_data
93
- )
94
- else:
95
- DjangoTelegram.send_warning(
96
- f"💳 Provider Issue: {provider}",
97
- notification_data
98
- )
99
-
100
- logger.info(f"Provider error notification sent: {provider} - {error_info.error_code}")
101
-
102
- except Exception as e:
103
- logger.error(f"Failed to send provider error notification: {e}")
104
-
105
- @staticmethod
106
- def send_webhook_validation_failure(error_info, context_info):
107
- """Send webhook validation failure notification."""
108
- try:
109
- provider = context_info.provider or "Unknown"
110
-
111
- notification_data = {
112
- "provider": provider,
113
- "error_code": error_info.error_code,
114
- "validation_error": error_info.details.validation_error if hasattr(error_info.details, 'validation_error') else "Unknown",
115
- "timestamp": error_info.timestamp.strftime("%Y-%m-%d %H:%M:%S UTC"),
116
- "severity": "HIGH",
117
- "requires_attention": True
118
- }
119
-
120
- # Add IP and request details for security analysis
121
- if context_info.request:
122
- notification_data.update({
123
- "ip_address": context_info.request.get("ip_address", "Unknown"),
124
- "user_agent": context_info.request.get("user_agent", "Unknown")
125
- })
126
-
127
- DjangoTelegram.send_warning(
128
- f"🔒 Webhook Validation Failed: {provider}",
129
- notification_data
130
- )
131
-
132
- logger.info(f"Webhook validation failure notification sent: {provider}")
133
-
134
- except Exception as e:
135
- logger.error(f"Failed to send webhook validation failure notification: {e}")
136
-
137
- @staticmethod
138
- def send_api_security_breach(error_info, context_info):
139
- """Send API security breach notification."""
140
- try:
141
- notification_data = {
142
- "error_code": error_info.error_code,
143
- "message": error_info.message,
144
- "timestamp": error_info.timestamp.strftime("%Y-%m-%d %H:%M:%S UTC"),
145
- "severity": "CRITICAL",
146
- "middleware": context_info.middleware or "Unknown",
147
- "operation": context_info.operation or "Unknown",
148
- "requires_immediate_attention": True
149
- }
150
-
151
- # Add security-specific details
152
- if hasattr(error_info.details, 'api_key_prefix'):
153
- notification_data["api_key_prefix"] = error_info.details.api_key_prefix
154
-
155
- if context_info.request:
156
- notification_data.update({
157
- "ip_address": context_info.request.get("ip_address", "Unknown"),
158
- "path": context_info.request.get("path", "Unknown"),
159
- "method": context_info.request.get("method", "Unknown"),
160
- "user_agent": context_info.request.get("user_agent", "Unknown")
161
- })
162
-
163
- DjangoTelegram.send_error(
164
- "🚨 API Security Breach Detected",
165
- notification_data
166
- )
167
-
168
- logger.critical(f"API security breach notification sent: {error_info.error_code}")
169
-
170
- except Exception as e:
171
- logger.error(f"Failed to send API security breach notification: {e}")
172
-
173
- @staticmethod
174
- def send_payment_failure(error_info, context_info, payment_details=None):
175
- """Send payment failure notification."""
176
- try:
177
- notification_data = {
178
- "error_code": error_info.error_code,
179
- "category": error_info.category,
180
- "message": error_info.message,
181
- "timestamp": error_info.timestamp.strftime("%Y-%m-%d %H:%M:%S UTC"),
182
- "provider": context_info.provider or "Unknown",
183
- "user_id": context_info.user_id or "Unknown"
184
- }
185
-
186
- # Add payment-specific details if provided
187
- if payment_details:
188
- notification_data.update({
189
- "payment_id": payment_details.get("payment_id"),
190
- "amount_usd": payment_details.get("amount_usd"),
191
- "currency": payment_details.get("currency"),
192
- "order_id": payment_details.get("order_id")
193
- })
194
-
195
- if error_info.severity in ["CRITICAL", "HIGH"]:
196
- DjangoTelegram.send_error(
197
- f"💸 Payment Failure: {error_info.category}",
198
- notification_data
199
- )
200
- else:
201
- DjangoTelegram.send_warning(
202
- f"💸 Payment Issue: {error_info.category}",
203
- notification_data
204
- )
205
-
206
- logger.info(f"Payment failure notification sent: {error_info.error_code}")
207
-
208
- except Exception as e:
209
- logger.error(f"Failed to send payment failure notification: {e}")
210
-
211
- @staticmethod
212
- def send_system_error(error_info, context_info):
213
- """Send system error notification."""
214
- try:
215
- notification_data = {
216
- "error_code": error_info.error_code,
217
- "category": error_info.category,
218
- "message": error_info.message,
219
- "timestamp": error_info.timestamp.strftime("%Y-%m-%d %H:%M:%S UTC"),
220
- "operation": context_info.operation or "Unknown",
221
- "recoverable": error_info.recoverable
222
- }
223
-
224
- # Add system context
225
- if context_info.system:
226
- notification_data.update({
227
- "environment": context_info.system.get("environment", "Unknown"),
228
- "debug_mode": context_info.system.get("debug", False)
229
- })
230
-
231
- # Add exception details if available
232
- if hasattr(error_info.details, 'exception_type'):
233
- notification_data.update({
234
- "exception_type": error_info.details.exception_type,
235
- "exception_module": error_info.details.exception_module
236
- })
237
-
238
- if error_info.severity == "CRITICAL":
239
- DjangoTelegram.send_error(
240
- f"🔧 CRITICAL System Error",
241
- notification_data
242
- )
243
- elif error_info.severity == "HIGH":
244
- DjangoTelegram.send_warning(
245
- f"🔧 System Error",
246
- notification_data
247
- )
248
- else:
249
- DjangoTelegram.send_info(
250
- f"🔧 System Issue",
251
- notification_data
252
- )
253
-
254
- logger.info(f"System error notification sent: {error_info.error_code}")
255
-
256
- except Exception as e:
257
- logger.error(f"Failed to send system error notification: {e}")
258
-
259
- @staticmethod
260
- def send_high_error_rate_alert(category, error_count, threshold):
261
- """Send high error rate alert notification."""
262
- try:
263
- notification_data = {
264
- "category": category,
265
- "error_count": error_count,
266
- "threshold": threshold,
267
- "timestamp": timezone.now().strftime("%Y-%m-%d %H:%M:%S UTC"),
268
- "alert_type": "HIGH_ERROR_RATE",
269
- "requires_immediate_attention": True
270
- }
271
-
272
- DjangoTelegram.send_error(
273
- f"🚨 HIGH ERROR RATE DETECTED: {category}",
274
- notification_data
275
- )
276
-
277
- logger.critical(f"High error rate alert sent: {category} - {error_count} errors")
278
-
279
- except Exception as e:
280
- logger.error(f"Failed to send high error rate alert: {e}")
281
-
282
- @staticmethod
283
- def send_attack_pattern_alert(ip_address, error_count, error_details):
284
- """Send security attack pattern alert."""
285
- try:
286
- notification_data = {
287
- "ip_address": ip_address,
288
- "error_count": error_count,
289
- "timestamp": timezone.now().strftime("%Y-%m-%d %H:%M:%S UTC"),
290
- "alert_type": "SECURITY_ATTACK_PATTERN",
291
- "error_details": error_details,
292
- "requires_immediate_action": True,
293
- "recommended_action": "Consider IP blocking"
294
- }
295
-
296
- DjangoTelegram.send_error(
297
- f"🚨 SECURITY ATTACK PATTERN DETECTED",
298
- notification_data
299
- )
300
-
301
- logger.critical(f"Attack pattern alert sent: IP {ip_address} - {error_count} security errors")
302
-
303
- except Exception as e:
304
- logger.error(f"Failed to send attack pattern alert: {e}")
305
-
306
- @staticmethod
307
- def send_recovery_notification(error_info, context_info, recovery_result):
308
- """Send recovery attempt notification."""
309
- try:
310
- notification_data = {
311
- "error_code": error_info.error_code,
312
- "category": error_info.category,
313
- "recovery_attempted": recovery_result.attempted,
314
- "recovery_success": recovery_result.success,
315
- "recovery_actions": recovery_result.actions,
316
- "recovery_message": recovery_result.message,
317
- "timestamp": timezone.now().strftime("%Y-%m-%d %H:%M:%S UTC"),
318
- "provider": context_info.provider or "Unknown"
319
- }
320
-
321
- if recovery_result.error:
322
- notification_data["recovery_error"] = recovery_result.error
323
-
324
- if recovery_result.success:
325
- DjangoTelegram.send_success(
326
- f"🔄 Recovery Successful: {error_info.category}",
327
- notification_data
328
- )
329
- else:
330
- DjangoTelegram.send_warning(
331
- f"🔄 Recovery Attempted: {error_info.category}",
332
- notification_data
333
- )
334
-
335
- logger.info(f"Recovery notification sent: {error_info.error_code}")
336
-
337
- except Exception as e:
338
- logger.error(f"Failed to send recovery notification: {e}")
339
-
340
-
341
- # Singleton instance for import
342
- payment_notifications = PaymentNotifications()