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
@@ -14,13 +14,18 @@ from django.core.exceptions import ValidationError
14
14
  from django.conf import settings
15
15
  import questionary
16
16
  from datetime import datetime
17
+ from django_cfg.modules.django_logger import get_logger
18
+
17
19
 
18
20
  from django_cfg import ConfigToolkit
19
21
 
20
22
  User = get_user_model()
21
23
 
22
24
 
25
+ logger = get_logger('superuser')
26
+
23
27
  class Command(BaseCommand):
28
+
24
29
  help = 'Create a superuser with enhanced validation and configuration'
25
30
 
26
31
  def add_arguments(self, parser):
@@ -56,6 +61,7 @@ class Command(BaseCommand):
56
61
  )
57
62
 
58
63
  def handle(self, *args, **options):
64
+ logger.info("Starting superuser command")
59
65
  if options['interactive'] or not any([options['username'], options['email'], options['password']]):
60
66
  self.create_superuser_interactive()
61
67
  else:
@@ -9,8 +9,9 @@ from django.core.management.base import BaseCommand, CommandError
9
9
  from django.conf import settings
10
10
  from typing import Any, Optional, List
11
11
  import logging
12
+ from django_cfg.modules.django_logger import get_logger
12
13
 
13
- logger = logging.getLogger(__name__)
14
+ logger = get_logger('task_clear')
14
15
 
15
16
 
16
17
  class Command(BaseCommand):
@@ -50,6 +51,8 @@ class Command(BaseCommand):
50
51
 
51
52
  def handle(self, *args, **options):
52
53
  """Handle the command execution."""
54
+ logger.info("Starting task_clear command")
55
+
53
56
  try:
54
57
  # Import here to avoid issues if dramatiq is not installed
55
58
  from django_cfg.modules.django_tasks import get_task_service
@@ -11,8 +11,9 @@ from django.conf import settings
11
11
  from typing import Any, Dict, List
12
12
  import json
13
13
  import logging
14
+ from django_cfg.modules.django_logger import get_logger
14
15
 
15
- logger = logging.getLogger(__name__)
16
+ logger = get_logger('task_status')
16
17
 
17
18
 
18
19
  class Command(BaseCommand):
@@ -45,6 +46,7 @@ class Command(BaseCommand):
45
46
 
46
47
  def handle(self, *args, **options):
47
48
  """Handle the command execution."""
49
+ logger.info("Starting task_status command")
48
50
  try:
49
51
  # Import here to avoid issues if dramatiq is not installed
50
52
  from django_cfg.modules.django_tasks import get_task_service
@@ -6,8 +6,10 @@ Tests email sending functionality using django_cfg configuration.
6
6
 
7
7
  from django.core.management.base import BaseCommand
8
8
  from django.contrib.auth import get_user_model
9
+ from django_cfg.modules.django_logger import get_logger
9
10
 
10
11
  User = get_user_model()
12
+ logger = get_logger('test_email')
11
13
 
12
14
 
13
15
  class Command(BaseCommand):
@@ -40,6 +42,7 @@ class Command(BaseCommand):
40
42
  subject = options["subject"]
41
43
  message = options["message"]
42
44
 
45
+ logger.info(f"Starting email test for {email}")
43
46
  self.stdout.write(f"🚀 Testing email service for {email}")
44
47
 
45
48
  # Create test user if not exists
@@ -5,10 +5,15 @@ Tests Telegram notification functionality using django_cfg configuration.
5
5
  """
6
6
 
7
7
  from django.core.management.base import BaseCommand
8
+ from django_cfg.modules.django_logger import get_logger
8
9
 
9
10
 
11
+
12
+ logger = get_logger('test_telegram')
13
+
10
14
  class Command(BaseCommand):
11
15
  """Command to test Telegram functionality."""
16
+
12
17
  help = "Test Telegram notification functionality"
13
18
 
14
19
  def add_arguments(self, parser):
@@ -20,6 +25,7 @@ class Command(BaseCommand):
20
25
  )
21
26
 
22
27
  def handle(self, *args, **options):
28
+ logger.info("Starting test_telegram command")
23
29
  message = options["message"]
24
30
 
25
31
  self.stdout.write("🚀 Testing Telegram notification service")
@@ -5,10 +5,15 @@ Tests Twilio messaging functionality using django_cfg configuration.
5
5
  """
6
6
 
7
7
  from django.core.management.base import BaseCommand
8
+ from django_cfg.modules.django_logger import get_logger
8
9
 
9
10
 
11
+
12
+ logger = get_logger('test_twilio')
13
+
10
14
  class Command(BaseCommand):
11
15
  """Command to test Twilio functionality."""
16
+
12
17
  help = "Test Twilio messaging functionality"
13
18
 
14
19
  def add_arguments(self, parser):
@@ -36,6 +41,7 @@ class Command(BaseCommand):
36
41
  )
37
42
 
38
43
  def handle(self, *args, **options):
44
+ logger.info("Starting test_twilio command")
39
45
  to_number = options["to"]
40
46
  message = options["message"]
41
47
  is_whatsapp = options["whatsapp"]
@@ -11,14 +11,19 @@ from typing import List, Optional
11
11
 
12
12
  from django.core.management.base import BaseCommand, CommandError
13
13
  from django.conf import settings
14
+ from django_cfg.modules.django_logger import get_logger
15
+
14
16
 
15
17
  from django_cfg.core.config import get_current_config
16
18
  from django_cfg.utils.path_resolution import PathResolver
17
19
 
18
20
 
21
+ logger = get_logger('tree')
22
+
19
23
  class Command(BaseCommand):
20
24
  """Display Django project structure in tree format."""
21
25
 
26
+
22
27
  help = "Display Django project structure based on django-cfg configuration"
23
28
 
24
29
  def add_arguments(self, parser):
@@ -78,6 +83,7 @@ class Command(BaseCommand):
78
83
 
79
84
  def handle(self, *args, **options):
80
85
  """Execute the command."""
86
+ logger.info("Starting tree command")
81
87
  try:
82
88
  # Get django-cfg configuration
83
89
  config = get_current_config()
@@ -1,183 +1,189 @@
1
- """
2
- Django management command to validate configuration.
1
+ # """
2
+ # Django management command to validate configuration.
3
3
 
4
- Usage:
5
- python manage.py validate_config
6
- """
4
+ # Usage:
5
+ # python manage.py validate_config
6
+ # """
7
7
 
8
- from django.core.management.base import BaseCommand, CommandError
9
- from django.conf import settings
10
- from django_cfg import ConfigToolkit
8
+ # from django.core.management.base import BaseCommand, CommandError
9
+ # from django.conf import settings
10
+ # from django.core.cache import cache
11
11
 
12
12
 
13
- class Command(BaseCommand):
14
- help = 'Validate Django Config Toolkit configuration'
15
13
 
16
- def add_arguments(self, parser):
17
- parser.add_argument(
18
- '--show-details',
19
- action='store_true',
20
- help='Show detailed configuration information',
21
- )
22
- parser.add_argument(
23
- '--check-connections',
24
- action='store_true',
25
- help='Test database and cache connections',
26
- )
14
+ # class Command(BaseCommand):
15
+ # help = 'Validate Django Config Toolkit configuration'
27
16
 
28
- def handle(self, *args, **options):
29
- """Validate configuration and optionally show details."""
30
- self.stdout.write(
31
- self.style.HTTP_INFO('🚀 Django Config Toolkit - Configuration Validation')
32
- )
33
- self.stdout.write('=' * 60)
17
+ # def add_arguments(self, parser):
18
+ # parser.add_argument(
19
+ # '--show-details',
20
+ # action='store_true',
21
+ # help='Show detailed configuration information',
22
+ # )
23
+ # parser.add_argument(
24
+ # '--check-connections',
25
+ # action='store_true',
26
+ # help='Test database and cache connections',
27
+ # )
28
+
29
+ # def handle(self, *args, **options):
30
+ # """Validate configuration and optionally show details."""
31
+ # self.stdout.write(
32
+ # self.style.HTTP_INFO('🚀 Django Config Toolkit - Configuration Validation')
33
+ # )
34
+ # self.stdout.write('=' * 60)
34
35
 
35
- try:
36
- # Initialize toolkit
37
- toolkit = ConfigToolkit()
36
+ # try:
37
+ # # Initialize toolkit
38
+ # toolkit = ConfigToolkit()
38
39
 
39
- # Basic validation
40
- self.stdout.write(
41
- self.style.SUCCESS(f'✅ Configuration loaded successfully')
42
- )
43
- self.stdout.write(f' Environment: {toolkit.environment}')
44
- self.stdout.write(f' Debug: {toolkit.debug}')
45
- self.stdout.write(f' Configs loaded: {toolkit._config_count}')
46
- self.stdout.write(f' Init time: {toolkit._init_time_ms:.2f}ms')
40
+ # # Basic validation
41
+ # self.stdout.write(
42
+ # self.style.SUCCESS(f'✅ Configuration loaded successfully')
43
+ # )
44
+ # self.stdout.write(f' Environment: {toolkit.environment}')
45
+ # self.stdout.write(f' Debug: {toolkit.debug}')
46
+ # self.stdout.write(f' Configs loaded: {toolkit._config_count}')
47
+ # self.stdout.write(f' Init time: {toolkit._init_time_ms:.2f}ms')
47
48
 
48
- # Check secret key
49
- if len(toolkit.secret_key) >= 50:
50
- self.stdout.write(self.style.SUCCESS('✅ Secret key is secure'))
51
- else:
52
- self.stdout.write(
53
- self.style.WARNING('⚠️ Secret key is too short (< 50 chars)')
54
- )
49
+ # # Check secret key
50
+ # if len(toolkit.secret_key) >= 50:
51
+ # self.stdout.write(self.style.SUCCESS('✅ Secret key is secure'))
52
+ # else:
53
+ # self.stdout.write(
54
+ # self.style.WARNING('⚠️ Secret key is too short (< 50 chars)')
55
+ # )
55
56
 
56
- # Check extended features
57
- self.stdout.write('\n🎨 Extended Features:')
58
- features = [
59
- ('Unfold Admin', toolkit.unfold_enabled),
60
- ('Revolution API', toolkit.revolution_enabled),
61
- ('Constance Settings', toolkit.constance_enabled),
62
- ('Advanced Logging', toolkit.logging_enabled),
63
- ]
57
+ # # Check extended features
58
+ # self.stdout.write('\n🎨 Extended Features:')
59
+ # features = [
60
+ # ('Unfold Admin', toolkit.unfold_enabled),
61
+ # ('Revolution API', toolkit.revolution_enabled),
62
+ # ('Constance Settings', toolkit.constance_enabled),
63
+ # ('Advanced Logging', toolkit.logging_enabled),
64
+ # ]
64
65
 
65
- for name, enabled in features:
66
- status = '✅' if enabled else '❌'
67
- self.stdout.write(f' {status} {name}')
66
+ # for name, enabled in features:
67
+ # status = '✅' if enabled else '❌'
68
+ # self.stdout.write(f' {status} {name}')
68
69
 
69
- # Detailed information
70
- if options['show_details']:
71
- self._show_detailed_config(toolkit)
70
+ # # Detailed information
71
+ # if options['show_details']:
72
+ # self._show_detailed_config(toolkit)
72
73
 
73
- # Connection tests
74
- if options['check_connections']:
75
- self._test_connections(toolkit)
74
+ # # Connection tests
75
+ # if options['check_connections']:
76
+ # self._test_connections(toolkit)
76
77
 
77
- except Exception as e:
78
- self.stdout.write(
79
- self.style.ERROR(f'❌ Configuration validation failed: {e}')
80
- )
81
- raise CommandError(f'Configuration error: {e}')
78
+ # except Exception as e:
79
+ # self.stdout.write(
80
+ # self.style.ERROR(f'❌ Configuration validation failed: {e}')
81
+ # )
82
+ # raise CommandError(f'Configuration error: {e}')
82
83
 
83
- self.stdout.write('=' * 60)
84
- self.stdout.write(
85
- self.style.SUCCESS('✨ Configuration validation completed!')
86
- )
84
+ # self.stdout.write('=' * 60)
85
+ # self.stdout.write(
86
+ # self.style.SUCCESS('✨ Configuration validation completed!')
87
+ # )
87
88
 
88
- def _show_detailed_config(self, toolkit):
89
- """Show detailed configuration information."""
90
- self.stdout.write('\n📋 Detailed Configuration:')
89
+ # def _show_detailed_config(self, toolkit):
90
+ # """Show detailed configuration information."""
91
+ # self.stdout.write('\n📋 Detailed Configuration:')
92
+
93
+ # # Environment configuration
94
+ # self.stdout.write('\n🌍 Environment:')
95
+ # if hasattr(toolkit._config, 'env_mode'):
96
+ # self.stdout.write(f' Mode: {toolkit._config.env_mode}')
97
+ # self.stdout.write(f' Debug: {toolkit._config.debug}')
91
98
 
92
- # Database configuration
93
- self.stdout.write('\n🗄️ Database:')
94
- self.stdout.write(f' Engine: {toolkit.database_engine}')
95
- self.stdout.write(f' Name: {toolkit.database_name}')
96
- if hasattr(toolkit._db_config, 'has_multiple_databases'):
97
- self.stdout.write(f' Multiple DBs: {toolkit._db_config.has_multiple_databases}')
99
+ # # Database configuration
100
+ # self.stdout.write('\n🗄️ Database:')
101
+ # self.stdout.write(f' Engine: {toolkit.database_engine}')
102
+ # self.stdout.write(f' Name: {toolkit.database_name}')
103
+ # if hasattr(toolkit._db_config, 'has_multiple_databases'):
104
+ # self.stdout.write(f' Multiple DBs: {toolkit._db_config.has_multiple_databases}')
98
105
 
99
- # Security configuration
100
- self.stdout.write('\n🔒 Security:')
101
- self.stdout.write(f' CORS Enabled: {toolkit.cors_enabled}')
102
- self.stdout.write(f' CSRF Enabled: {toolkit.csrf_enabled}')
103
- self.stdout.write(f' SSL Redirect: {toolkit.ssl_enabled}')
106
+ # # Security configuration
107
+ # self.stdout.write('\n🔒 Security:')
108
+ # self.stdout.write(f' CORS Enabled: {toolkit.cors_enabled}')
109
+ # self.stdout.write(f' CSRF Enabled: {toolkit.csrf_enabled}')
110
+ # self.stdout.write(f' SSL Redirect: {toolkit.ssl_enabled}')
104
111
 
105
- # API configuration
106
- self.stdout.write('\n🌐 API:')
107
- self.stdout.write(f' Page Size: {toolkit.api_page_size}')
108
- self.stdout.write(f' Rate Limiting: {toolkit.api_rate_limit_enabled}')
112
+ # # API configuration
113
+ # self.stdout.write('\n🌐 API:')
114
+ # self.stdout.write(f' Page Size: {toolkit.api_page_size}')
115
+ # self.stdout.write(f' Rate Limiting: {toolkit.api_rate_limit_enabled}')
109
116
 
110
- # Cache configuration
111
- self.stdout.write('\n💾 Cache:')
112
- self.stdout.write(f' Backend: {toolkit.cache_backend}')
113
- self.stdout.write(f' Timeout: {toolkit.cache_timeout}s')
117
+ # # Cache configuration
118
+ # self.stdout.write('\n💾 Cache:')
119
+ # self.stdout.write(f' Backend: {toolkit.cache_backend}')
120
+ # self.stdout.write(f' Timeout: {toolkit.cache_timeout}s')
114
121
 
115
- # Extended features details
116
- if toolkit.unfold_enabled:
117
- self.stdout.write('\n🎨 Unfold:')
118
- self.stdout.write(f' Site Title: {toolkit.site_title}')
122
+ # # Extended features details
123
+ # if toolkit.unfold_enabled:
124
+ # self.stdout.write('\n🎨 Unfold:')
125
+ # self.stdout.write(f' Site Title: {toolkit.site_title}')
119
126
 
120
- if toolkit.revolution_enabled:
121
- self.stdout.write('\n🚀 Revolution:')
122
- self.stdout.write(f' API Prefix: {toolkit.api_prefix}')
127
+ # if toolkit.revolution_enabled:
128
+ # self.stdout.write('\n🚀 Revolution:')
129
+ # self.stdout.write(f' API Prefix: {toolkit.api_prefix}')
123
130
 
124
- if toolkit.constance_enabled:
125
- self.stdout.write('\n⚙️ Constance:')
126
- self.stdout.write(f' Backend: {toolkit.constance_backend}')
131
+ # if toolkit.constance_enabled:
132
+ # self.stdout.write('\n⚙️ Constance:')
133
+ # self.stdout.write(f' Backend: {toolkit.constance_backend}')
127
134
 
128
- self.stdout.write('\n📝 Logging:')
129
- self.stdout.write(f' Log Level: {toolkit.log_level}')
135
+ # self.stdout.write('\n📝 Logging:')
136
+ # self.stdout.write(f' Log Level: {toolkit.log_level}')
130
137
 
131
- def _test_connections(self, toolkit):
132
- """Test database and cache connections."""
133
- self.stdout.write('\n🔗 Connection Tests:')
138
+ # def _test_connections(self, toolkit):
139
+ # """Test database and cache connections."""
140
+ # self.stdout.write('\n🔗 Connection Tests:')
134
141
 
135
- # Test database connections
136
- self.stdout.write('\n🗄️ Database connections:')
137
- try:
138
- from django.db import connections
142
+ # # Test database connections
143
+ # self.stdout.write('\n🗄️ Database connections:')
144
+ # try:
145
+ # from django.db import connections
139
146
 
140
- for db_name in connections:
141
- try:
142
- connection = connections[db_name]
143
- with connection.cursor() as cursor:
144
- cursor.execute("SELECT 1")
145
- cursor.fetchone()
147
+ # for db_name in connections:
148
+ # try:
149
+ # connection = connections[db_name]
150
+ # with connection.cursor() as cursor:
151
+ # cursor.execute("SELECT 1")
152
+ # cursor.fetchone()
146
153
 
147
- self.stdout.write(
148
- self.style.SUCCESS(f' ✅ {db_name}: Connected')
149
- )
150
- except Exception as e:
151
- self.stdout.write(
152
- self.style.ERROR(f' ❌ {db_name}: {str(e)}')
153
- )
154
+ # self.stdout.write(
155
+ # self.style.SUCCESS(f' ✅ {db_name}: Connected')
156
+ # )
157
+ # except Exception as e:
158
+ # self.stdout.write(
159
+ # self.style.ERROR(f' ❌ {db_name}: {str(e)}')
160
+ # )
154
161
 
155
- except Exception as e:
156
- self.stdout.write(
157
- self.style.ERROR(f' ❌ Database test failed: {e}')
158
- )
162
+ # except Exception as e:
163
+ # self.stdout.write(
164
+ # self.style.ERROR(f' ❌ Database test failed: {e}')
165
+ # )
159
166
 
160
- # Test cache connection
161
- self.stdout.write('\n💾 Cache connection:')
162
- try:
163
- from django.core.cache import cache
167
+ # # Test cache connection
168
+ # self.stdout.write('\n💾 Cache connection:')
169
+ # try:
164
170
 
165
- test_key = 'config_validation_test'
166
- test_value = 'test_value'
171
+ # test_key = 'config_validation_test'
172
+ # test_value = 'test_value'
167
173
 
168
- cache.set(test_key, test_value, 30)
169
- retrieved_value = cache.get(test_key)
174
+ # cache.set(test_key, test_value, 30)
175
+ # retrieved_value = cache.get(test_key)
170
176
 
171
- if retrieved_value == test_value:
172
- self.stdout.write(
173
- self.style.SUCCESS(' ✅ Cache: Working')
174
- )
175
- else:
176
- self.stdout.write(
177
- self.style.WARNING(' ⚠️ Cache: Read/write test failed')
178
- )
177
+ # if retrieved_value == test_value:
178
+ # self.stdout.write(
179
+ # self.style.SUCCESS(' ✅ Cache: Working')
180
+ # )
181
+ # else:
182
+ # self.stdout.write(
183
+ # self.style.WARNING(' ⚠️ Cache: Read/write test failed')
184
+ # )
179
185
 
180
- except Exception as e:
181
- self.stdout.write(
182
- self.style.ERROR(f' ❌ Cache test failed: {e}')
183
- )
186
+ # except Exception as e:
187
+ # self.stdout.write(
188
+ # self.style.ERROR(f' ❌ Cache test failed: {e}')
189
+ # )
@@ -7,7 +7,7 @@ Unfold admin integration and smart field grouping.
7
7
 
8
8
  from typing import Dict, List, Optional, Any, Union, Literal
9
9
  from pydantic import BaseModel, Field, field_validator
10
- from pathlib import Path
10
+ import traceback
11
11
  from django_cfg.models.cfg import BaseCfgAutoModule
12
12
 
13
13
 
@@ -150,14 +150,30 @@ class ConstanceConfig(BaseModel, BaseCfgAutoModule):
150
150
  default_factory=list,
151
151
  description="List of Constance fields",
152
152
  )
153
-
153
+
154
+ # Cache for app fields to avoid multiple calls
155
+ _app_fields_cache: Optional[List[ConstanceField]] = None
156
+
154
157
  def _get_app_constance_fields(self) -> List[ConstanceField]:
155
158
  """Automatically collect constance fields from django-cfg apps."""
159
+ # Return cached result if available
160
+ if self._app_fields_cache is not None:
161
+ return self._app_fields_cache
162
+
156
163
  app_fields = []
157
164
  config = self.get_config()
165
+
166
+ # Get fields from tasks app (only if knowbase or agents are enabled)
167
+ if config and config.should_enable_tasks():
168
+ try:
169
+ from django_cfg.modules.django_tasks import extend_constance_config_with_tasks
170
+ tasks_fields = extend_constance_config_with_tasks()
171
+ app_fields.extend(tasks_fields)
172
+ except (ImportError, Exception):
173
+ pass
158
174
 
159
175
  # Get fields from knowbase app (only if enabled)
160
- if config and getattr(config, 'enable_knowbase', False):
176
+ if config and config.enable_knowbase:
161
177
  try:
162
178
  from django_cfg.apps.knowbase.config import get_django_cfg_knowbase_constance_fields
163
179
  knowbase_fields = get_django_cfg_knowbase_constance_fields()
@@ -165,15 +181,19 @@ class ConstanceConfig(BaseModel, BaseCfgAutoModule):
165
181
  except (ImportError, Exception):
166
182
  pass
167
183
 
168
- # Get fields from tasks app (only if knowbase or agents are enabled)
169
- if config and (getattr(config, 'enable_knowbase', False) or getattr(config, 'enable_agents', False)):
184
+ # Get fields from payments app (only if enabled)
185
+ if config and config.payments and config.payments.enabled:
170
186
  try:
171
- from django_cfg.modules.django_tasks import extend_constance_config_with_tasks
172
- tasks_fields = extend_constance_config_with_tasks()
173
- app_fields.extend(tasks_fields)
174
- except (ImportError, Exception):
175
- pass
176
-
187
+ from django_cfg.apps.payments.config import get_django_cfg_payments_constance_fields
188
+ payments_fields = get_django_cfg_payments_constance_fields()
189
+ app_fields.extend(payments_fields)
190
+ print(f"✅ Added {len(payments_fields)} payments fields to Constance")
191
+ except (ImportError, Exception) as e:
192
+ print(f"❌ Failed to load payments constance fields: {e}")
193
+ traceback.print_exc()
194
+
195
+ # Cache the result
196
+ self._app_fields_cache = app_fields
177
197
  return app_fields
178
198
 
179
199
  def get_all_fields(self) -> List[ConstanceField]: