arpakitlib 1.7.61__tar.gz → 1.7.62__tar.gz

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 (182) hide show
  1. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/PKG-INFO +1 -1
  2. arpakitlib-1.7.61/arpakitlib/_arpakit_project_template/src/operation_execution/start_operation_executor_for_dev_.py → arpakitlib-1.7.62/arpakitlib/_arpakit_project_template/src/operation_execution/start_operation_executor_worker_for_dev.py +2 -2
  3. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_base_worker_util.py +27 -9
  4. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_util.py +4 -0
  5. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_logging_util.py +3 -3
  6. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_operation_execution_util.py +34 -26
  7. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/pyproject.toml +1 -1
  8. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/LICENSE +0 -0
  9. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/NOTICE +0 -0
  10. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/README.md +0 -0
  11. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/__init__.py +0 -0
  12. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/.gitignore +0 -0
  13. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/.python-version +0 -0
  14. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/ARPAKITLIB +0 -0
  15. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/AUTHOR.md +0 -0
  16. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/LICENSE +0 -0
  17. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/NOTICE +0 -0
  18. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/README.md +0 -0
  19. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/example.env +0 -0
  20. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/__init__.py +0 -0
  21. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/docker_ps.sh +0 -0
  22. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/docker_ps_a.sh +0 -0
  23. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/docker_run_postgres_for_dev.sh +0 -0
  24. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/docker_start_postgres_for_dev.sh +0 -0
  25. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/docker_stop_postgres_for_dev.sh +0 -0
  26. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/example_nginx_proxy.nginx +0 -0
  27. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/example_poetry_arpakitlib.sh +0 -0
  28. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/example_pyproject.toml +0 -0
  29. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/example_systemd.service +0 -0
  30. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_branch.sh +0 -0
  31. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_commit.sh +0 -0
  32. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_push_arpakit_company_github_1.sh +0 -0
  33. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_push_arpakit_company_gitlab_1.sh +0 -0
  34. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_push_arpakit_github_1.sh +0 -0
  35. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_push_arpakit_gitlab_1.sh +0 -0
  36. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_remote_v.sh +0 -0
  37. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_set_arpakit_company_origin.sh +0 -0
  38. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_set_arpakit_origin.sh +0 -0
  39. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/git_status.sh +0 -0
  40. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/hello_world.py +0 -0
  41. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/json_beutify.py +0 -0
  42. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/logging_check.py +0 -0
  43. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/note/__init__.py +0 -0
  44. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/note/note_1.txt +0 -0
  45. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/note/note_2.txt +0 -0
  46. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/note/note_3.txt +0 -0
  47. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/note/note_4.txt +0 -0
  48. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/note/note_5.txt +0 -0
  49. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_add_plugin_export.sh +0 -0
  50. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_check.sh +0 -0
  51. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_clear_cache.sh +0 -0
  52. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_config_virtualenvs_in_project_true.sh +0 -0
  53. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_generate_requirements.txt.sh +0 -0
  54. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_install.sh +0 -0
  55. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_lock.sh +0 -0
  56. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_remove_and_add_arpakitlib.sh +0 -0
  57. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_show.sh +0 -0
  58. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_show_arpakitlib.sh +0 -0
  59. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_update.sh +0 -0
  60. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/poetry_update_arpakitlib.sh +0 -0
  61. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/requirements.txt +0 -0
  62. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/__init__.py +0 -0
  63. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_1.py +0 -0
  64. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_2.py +0 -0
  65. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_3.py +0 -0
  66. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_4.py +0 -0
  67. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_5.py +0 -0
  68. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_6.py +0 -0
  69. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_7.py +0 -0
  70. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_8.sh +0 -0
  71. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sandbox/sandbox_9.sh +0 -0
  72. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/settings_check.py +0 -0
  73. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/settings_generate_env_example.py +0 -0
  74. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sqlalchemy_db_check_conn.py +0 -0
  75. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sqlalchemy_db_init.py +0 -0
  76. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/manage/sqlalchemy_db_reinit.py +0 -0
  77. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/resource/__init__.py +0 -0
  78. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/resource/static/__init__.py +0 -0
  79. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/resource/static/helloworld +0 -0
  80. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/__init__.py +0 -0
  81. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/additional_model/__init__.py +0 -0
  82. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/additional_model/additional_model.py +0 -0
  83. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/__init__.py +0 -0
  84. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/asgi.py +0 -0
  85. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/auth.py +0 -0
  86. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/const.py +0 -0
  87. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/create_api_app.py +0 -0
  88. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/event.py +0 -0
  89. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/router/__init__.py +0 -0
  90. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/router/main_router.py +0 -0
  91. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/router/v1/__init__.py +0 -0
  92. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/router/v1/get_api_error_info.py +0 -0
  93. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/router/v1/main_router.py +0 -0
  94. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/schema/__init__.py +0 -0
  95. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/schema/v1/__init__.py +0 -0
  96. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/schema/v1/in_.py +0 -0
  97. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/schema/v1/out.py +0 -0
  98. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/start_api_for_dev.py +0 -0
  99. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/start_api_for_dev_with_reload.py +0 -0
  100. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/transmitted_api_data.py +0 -0
  101. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/api/util.py +0 -0
  102. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/business_service/__init__.py +0 -0
  103. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/core/__init__.py +0 -0
  104. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/core/const.py +0 -0
  105. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/core/settings.py +0 -0
  106. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/core/util.py +0 -0
  107. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/db/__init__.py +0 -0
  108. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/db/sqlalchemy_model.py +0 -0
  109. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/db/util.py +0 -0
  110. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/operation_execution/__init__.py +0 -0
  111. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/operation_execution/const.py +0 -0
  112. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/operation_execution/operation_executor.py +0 -0
  113. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/operation_execution/scheduled_operations.py +0 -0
  114. /arpakitlib-1.7.61/arpakitlib/_arpakit_project_template/src/operation_execution/start_scheduled_operation_creator_for_dev.py → /arpakitlib-1.7.62/arpakitlib/_arpakit_project_template/src/operation_execution/start_scheduled_operation_creator_worker_for_dev.py +0 -0
  115. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/test_data/__init__.py +0 -0
  116. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/test_data/make_test_data_1.py +0 -0
  117. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/test_data/make_test_data_2.py +0 -0
  118. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/test_data/make_test_data_3.py +0 -0
  119. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/test_data/make_test_data_4.py +0 -0
  120. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/test_data/make_test_data_5.py +0 -0
  121. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/_arpakit_project_template/src/util/__init__.py +0 -0
  122. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/api_key_util.py +0 -0
  123. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_additional_model_util.py +0 -0
  124. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_aiogram_util.py +0 -0
  125. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_arpakit_lib_module_util.py +0 -0
  126. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_arpakit_project_template_util.py +0 -0
  127. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_arpakit_schedule_uust_api_client_util.py +0 -0
  128. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_arpakitlib_cli_util.py +0 -0
  129. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_base64_util.py +0 -0
  130. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_cache_file_util.py +0 -0
  131. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_datetime_util.py +0 -0
  132. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_dict_util.py +0 -0
  133. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_dream_ai_api_client_util.py +0 -0
  134. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_encrypt_decrypt_util.py +0 -0
  135. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_enumeration_util.py +0 -0
  136. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_exception_util.py +0 -0
  137. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/healthcheck +0 -0
  138. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/redoc/redoc.standalone.js +0 -0
  139. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/favicon-16x16.png +0 -0
  140. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/favicon-32x32.png +0 -0
  141. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/index.css +0 -0
  142. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/index.html +0 -0
  143. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/oauth2-redirect.html +0 -0
  144. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-initializer.js +0 -0
  145. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-bundle.js +0 -0
  146. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-bundle.js.map +0 -0
  147. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-es-bundle-core.js +0 -0
  148. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-es-bundle-core.js.map +0 -0
  149. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-es-bundle.js +0 -0
  150. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-es-bundle.js.map +0 -0
  151. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-standalone-preset.js +0 -0
  152. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui-standalone-preset.js.map +0 -0
  153. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui.css +0 -0
  154. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui.css.map +0 -0
  155. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui.js +0 -0
  156. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_fastapi_static/swagger-ui/swagger-ui.js.map +0 -0
  157. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_file_storage_in_dir_util.py +0 -0
  158. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_file_util.py +0 -0
  159. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_hash_util.py +0 -0
  160. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_http_request_util.py +0 -0
  161. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_ip_util.py +0 -0
  162. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_json_db_util.py +0 -0
  163. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_json_util.py +0 -0
  164. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_jwt_util.py +0 -0
  165. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_list_of_dicts_to_xlsx.py +0 -0
  166. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_list_util.py +0 -0
  167. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_mongodb_util.py +0 -0
  168. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_need_type_util.py +0 -0
  169. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_openai_api_client_util.py +0 -0
  170. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_parse_command.py +0 -0
  171. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_postgresql_util.py +0 -0
  172. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_run_cmd_util.py +0 -0
  173. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_schedule_uust_api_client_util.py +0 -0
  174. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_settings_util.py +0 -0
  175. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_sleep_util.py +0 -0
  176. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_sqlalchemy_model_util.py +0 -0
  177. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_sqlalchemy_util.py +0 -0
  178. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_ssh_runner_util.py +0 -0
  179. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_str_util.py +0 -0
  180. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_type_util.py +0 -0
  181. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_yookassa_api_client_util.py +0 -0
  182. {arpakitlib-1.7.61 → arpakitlib-1.7.62}/arpakitlib/ar_zabbix_api_client_util.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: arpakitlib
3
- Version: 1.7.61
3
+ Version: 1.7.62
4
4
  Summary: arpakitlib
5
5
  Home-page: https://github.com/ARPAKIT-Company/arpakitlib
6
6
  License: Apache-2.0
@@ -3,7 +3,7 @@ from src.core.util import get_cached_sqlalchemy_db, setup_logging
3
3
  from src.operation_execution.operation_executor import OperationExecutor
4
4
 
5
5
 
6
- def start_operation_executor_for_dev():
6
+ def start_operation_executor_worker_for_dev():
7
7
  setup_logging()
8
8
  worker = OperationExecutorWorker(
9
9
  sqlalchemy_db=get_cached_sqlalchemy_db(),
@@ -14,4 +14,4 @@ def start_operation_executor_for_dev():
14
14
 
15
15
 
16
16
  if __name__ == '__main__':
17
- start_operation_executor_for_dev()
17
+ start_operation_executor_worker_for_dev()
@@ -43,7 +43,7 @@ class BaseWorker(ABC):
43
43
  )
44
44
  res.start()
45
45
  else:
46
- raise ValueError(f"unrecognized safe_run_mode={safe_run_in_background_mode}")
46
+ raise ValueError(f"unknown safe_run_mode={safe_run_in_background_mode}")
47
47
  return res
48
48
 
49
49
  def sync_on_startup(self):
@@ -53,18 +53,27 @@ class BaseWorker(ABC):
53
53
  raise NotImplementedError()
54
54
 
55
55
  def sync_run_on_error(self, exception: BaseException, **kwargs):
56
- self._logger.exception(exception)
56
+ pass
57
57
 
58
58
  def sync_safe_run(self):
59
- self._logger.info("sync_safe_run")
60
- self.sync_on_startup()
59
+ self._logger.info("start sync_safe_run")
60
+ try:
61
+ self.sync_on_startup()
62
+ except BaseException as exception:
63
+ self._logger.error("error in sync_on_startup", exc_info=exception)
64
+ raise exception
61
65
  while True:
62
66
  try:
63
67
  self.sync_run()
64
68
  if self.timeout_after_run is not None:
65
69
  sync_safe_sleep(self.timeout_after_run)
66
70
  except BaseException as exception:
67
- self.sync_run_on_error(exception=exception)
71
+ self._logger.error("error in sync_run", exc_info=exception)
72
+ try:
73
+ self.sync_run_on_error(exception=exception)
74
+ except BaseException as exception_:
75
+ self._logger.error("error in sync_run_on_error", exc_info=exception_)
76
+ raise exception_
68
77
  if self.timeout_after_err_in_run is not None:
69
78
  sync_safe_sleep(self.timeout_after_err_in_run)
70
79
 
@@ -75,18 +84,27 @@ class BaseWorker(ABC):
75
84
  raise NotImplementedError()
76
85
 
77
86
  async def async_run_on_error(self, exception: BaseException, **kwargs):
78
- self._logger.exception(exception)
87
+ pass
79
88
 
80
89
  async def async_safe_run(self):
81
- self._logger.info("async_safe_run")
82
- await self.async_on_startup()
90
+ self._logger.info("start async_safe_run")
91
+ try:
92
+ await self.async_on_startup()
93
+ except BaseException as exception:
94
+ self._logger.error("error in async_on_startup", exc_info=exception)
95
+ raise exception
83
96
  while True:
84
97
  try:
85
98
  await self.async_run()
86
99
  if self.timeout_after_run is not None:
87
100
  await async_safe_sleep(self.timeout_after_run)
88
101
  except BaseException as exception:
89
- await self.async_run_on_error(exception=exception)
102
+ self._logger.error("error in async_run", exc_info=exception)
103
+ try:
104
+ await self.async_run_on_error(exception=exception)
105
+ except BaseException as exception_:
106
+ self._logger.error("error in async_run_on_error", exc_info=exception_)
107
+ raise exception_
90
108
  if self.timeout_after_err_in_run is not None:
91
109
  await async_safe_sleep(self.timeout_after_err_in_run)
92
110
 
@@ -633,6 +633,8 @@ def create_fastapi_app(
633
633
  media_dirpath: str | None = None,
634
634
  static_dirpath: str | None = None
635
635
  ):
636
+ _logger.info("start create_fastapi_app")
637
+
636
638
  setup_normal_logging(log_filepath=log_filepath)
637
639
 
638
640
  if contact is None:
@@ -688,6 +690,8 @@ def create_fastapi_app(
688
690
 
689
691
  app.include_router(router=main_api_router)
690
692
 
693
+ _logger.info("finish create_fastapi_app")
694
+
691
695
  return app
692
696
 
693
697
 
@@ -28,13 +28,13 @@ def setup_normal_logging(log_filepath: Optional[str] = None):
28
28
  if log_filepath:
29
29
  init_log_file(log_filepath=log_filepath)
30
30
 
31
- logger = logging.getLogger(__name__)
31
+ logger = logging.getLogger()
32
32
  logger.setLevel(logging.INFO)
33
33
 
34
34
  stream_handler = logging.StreamHandler()
35
35
  stream_handler.setLevel(logging.INFO)
36
36
  stream_formatter = logging.Formatter(
37
- "%(asctime)s | %(levelname)s | %(name)s | %(filename)s:%(lineno)d - %(message)s",
37
+ "%(asctime)s | %(levelname)s | %(name)s | %(filename)s:%(funcName)s:%(lineno)d - %(message)s",
38
38
  datefmt="%d.%m.%Y %I:%M:%S%p"
39
39
  )
40
40
  stream_handler.setFormatter(stream_formatter)
@@ -44,7 +44,7 @@ def setup_normal_logging(log_filepath: Optional[str] = None):
44
44
  file_handler = logging.FileHandler(log_filepath)
45
45
  file_handler.setLevel(logging.WARNING)
46
46
  file_formatter = logging.Formatter(
47
- "%(asctime)s | %(levelname)s | %(name)s | %(filename)s:%(lineno)d - %(message)s",
47
+ "%(asctime)s | %(levelname)s | %(name)s | %(filename)s:%(funcName)s:%(lineno)d - %(message)s",
48
48
  datefmt="%d.%m.%Y %I:%M:%S%p"
49
49
  )
50
50
  file_handler.setFormatter(file_formatter)
@@ -140,9 +140,10 @@ class BaseOperationExecutor:
140
140
 
141
141
  def sync_safe_execute_operation(self, operation_dbm: OperationDBM) -> OperationDBM:
142
142
  self._logger.info(
143
- f"start sync_safe_execute_operation"
144
- f", operation_dbm.id={operation_dbm.id}"
145
- f", operation_dbm.type={operation_dbm.type}"
143
+ f"start sync_safe_execute_operation, "
144
+ f"operation_dbm.id={operation_dbm.id}, "
145
+ f"operation_dbm.type={operation_dbm.type}, "
146
+ f"operation_dbm.status={operation_dbm.status}"
146
147
  )
147
148
 
148
149
  with self.sql_alchemy_db.new_session() as session:
@@ -160,7 +161,10 @@ class BaseOperationExecutor:
160
161
  try:
161
162
  self.sync_execute_operation(operation_dbm=operation_dbm)
162
163
  except BaseException as exception_:
163
- self._logger.error(f"Error while executing operation (id={operation_dbm.id})", exc_info=exception_)
164
+ self._logger.error(
165
+ f"error in sync_execute_operation (id={operation_dbm.id}, type={operation_dbm.type})",
166
+ exc_info=exception_
167
+ )
164
168
  exception = exception_
165
169
  traceback_str = traceback.format_exc()
166
170
 
@@ -186,7 +190,7 @@ class BaseOperationExecutor:
186
190
  if exception:
187
191
  story_log_dbm = StoryLogDBM(
188
192
  level=StoryLogDBM.Levels.error,
189
- title=f"Error while executing operation (id={operation_dbm.id}, type={operation_dbm.type})",
193
+ title=f"error in sync_execute_operation (id={operation_dbm.id}, type={operation_dbm.type})",
190
194
  data={
191
195
  "operation_id": operation_dbm.id,
192
196
  "exception_str": str(exception),
@@ -200,11 +204,11 @@ class BaseOperationExecutor:
200
204
  session.refresh(operation_dbm)
201
205
 
202
206
  self._logger.info(
203
- f"finish sync_safe_execute_operation"
204
- f", operation_dbm.id={operation_dbm.id}"
205
- f", operation_dbm.type={operation_dbm.type}"
206
- f", operation_dbm.status={operation_dbm.status}"
207
- f", operation_dbm.duration={operation_dbm.duration}"
207
+ f"finish sync_safe_execute_operation, "
208
+ f"operation_dbm.id={operation_dbm.id}, "
209
+ f"operation_dbm.type={operation_dbm.type}, "
210
+ f"operation_dbm.status={operation_dbm.status}, "
211
+ f"operation_dbm.duration={operation_dbm.duration}"
208
212
  )
209
213
 
210
214
  return operation_dbm
@@ -219,9 +223,10 @@ class BaseOperationExecutor:
219
223
 
220
224
  async def async_safe_execute_operation(self, operation_dbm: OperationDBM) -> OperationDBM:
221
225
  self._logger.info(
222
- f"start async_safe_execute_operation"
223
- f", operation_dbm.id={operation_dbm.id}"
224
- f", operation_dbm.type={operation_dbm.type}"
226
+ f"start async_safe_execute_operation, "
227
+ f"operation_dbm.id={operation_dbm.id}, "
228
+ f"operation_dbm.type={operation_dbm.type}, "
229
+ f"operation_dbm.status={operation_dbm.status}"
225
230
  )
226
231
 
227
232
  with self.sql_alchemy_db.new_session() as session:
@@ -239,7 +244,10 @@ class BaseOperationExecutor:
239
244
  try:
240
245
  await self.async_execute_operation(operation_dbm=operation_dbm)
241
246
  except BaseException as exception_:
242
- self._logger.error(f"Error while executing operation (id={operation_dbm.id})", exc_info=exception_)
247
+ self._logger.error(
248
+ f"error in async_execute_operation (id={operation_dbm.id}, type={operation_dbm.type})",
249
+ exc_info=exception_
250
+ )
243
251
  exception = exception_
244
252
  traceback_str = traceback.format_exc()
245
253
 
@@ -265,7 +273,7 @@ class BaseOperationExecutor:
265
273
  if exception:
266
274
  story_log_dbm = StoryLogDBM(
267
275
  level=StoryLogDBM.Levels.error,
268
- title=f"Error while executing operation (id={operation_dbm.id}, type={operation_dbm.type})",
276
+ title=f"error in async_execute_operation (id={operation_dbm.id}, type={operation_dbm.type})",
269
277
  data={
270
278
  "operation_id": operation_dbm.id,
271
279
  "exception_str": str(exception),
@@ -279,11 +287,11 @@ class BaseOperationExecutor:
279
287
  session.refresh(operation_dbm)
280
288
 
281
289
  self._logger.info(
282
- f"finish async_safe_execute_operation"
283
- f", operation_dbm.id={operation_dbm.id}"
284
- f", operation_dbm.type={operation_dbm.type}"
285
- f", operation_dbm.status={operation_dbm.status}"
286
- f", operation_dbm.duration={operation_dbm.duration}"
290
+ f"finish async_safe_execute_operation, "
291
+ f"operation_dbm.id={operation_dbm.id}, "
292
+ f"operation_dbm.type={operation_dbm.type}, "
293
+ f"operation_dbm.status={operation_dbm.status}, "
294
+ f"operation_dbm.duration={operation_dbm.duration}"
287
295
  )
288
296
 
289
297
  return operation_dbm
@@ -320,14 +328,12 @@ class OperationExecutorWorker(BaseWorker):
320
328
  sqlalchemy_db=self.sqlalchemy_db,
321
329
  filter_operation_types=self.filter_operation_types
322
330
  )
323
-
324
331
  if not operation_dbm:
325
332
  return
326
-
327
333
  self.sync_execute_operation(operation_dbm=operation_dbm)
328
334
 
329
335
  def sync_run_on_error(self, exception: BaseException, **kwargs):
330
- self._logger.exception(exception)
336
+ pass
331
337
 
332
338
  async def async_on_startup(self):
333
339
  self.sqlalchemy_db.init()
@@ -340,14 +346,12 @@ class OperationExecutorWorker(BaseWorker):
340
346
  sqlalchemy_db=self.sqlalchemy_db,
341
347
  filter_operation_types=self.filter_operation_types
342
348
  )
343
-
344
349
  if not operation_dbm:
345
350
  return
346
-
347
351
  await self.async_execute_operation(operation_dbm=operation_dbm)
348
352
 
349
353
  async def async_run_on_error(self, exception: BaseException, **kwargs):
350
- self._logger.exception(exception)
354
+ pass
351
355
 
352
356
 
353
357
  class ScheduledOperation(BaseModel):
@@ -383,8 +387,10 @@ class ScheduledOperationCreatorWorker(BaseWorker):
383
387
  timeout = None
384
388
 
385
389
  for scheduled_operation in self.scheduled_operations:
390
+
386
391
  if not scheduled_operation.is_time_func():
387
392
  continue
393
+
388
394
  with self.sqlalchemy_db.new_session() as session:
389
395
  operation_dbm = OperationDBM(
390
396
  type=scheduled_operation.type,
@@ -411,8 +417,10 @@ class ScheduledOperationCreatorWorker(BaseWorker):
411
417
  timeout: timedelta | None = None
412
418
 
413
419
  for scheduled_operation in self.scheduled_operations:
420
+
414
421
  if not scheduled_operation.is_time_func():
415
422
  continue
423
+
416
424
  with self.sqlalchemy_db.new_session() as session:
417
425
  operation_dbm = OperationDBM(
418
426
  type=scheduled_operation.type,
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "arpakitlib"
3
- version = "1.7.61"
3
+ version = "1.7.62"
4
4
  description = "arpakitlib"
5
5
  authors = ["arpakit <arpakit@gmail.com>", "arpakit_support <support@arpakit.com>"]
6
6
  license = "Apache License 2.0"
File without changes
File without changes
File without changes