kodit 0.4.2__tar.gz → 0.4.3__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.

Potentially problematic release.


This version of kodit might be problematic. Click here for more details.

Files changed (296) hide show
  1. {kodit-0.4.2 → kodit-0.4.3}/.vscode/settings.json +3 -0
  2. {kodit-0.4.2 → kodit-0.4.3}/PKG-INFO +1 -1
  3. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/index.md +68 -1
  4. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/openapi.json +158 -1
  5. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/_version.py +2 -2
  6. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/app.py +6 -1
  7. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/factories/code_indexing_factory.py +14 -12
  8. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/factories/reporting_factory.py +10 -5
  9. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/services/auto_indexing_service.py +28 -32
  10. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/services/code_indexing_application_service.py +43 -26
  11. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/services/indexing_worker_service.py +10 -12
  12. kodit-0.4.3/src/kodit/application/services/reporting.py +104 -0
  13. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/cli.py +68 -78
  14. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/config.py +2 -2
  15. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/entities.py +99 -1
  16. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/protocols.py +28 -3
  17. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/services/index_service.py +11 -9
  18. kodit-0.4.3/src/kodit/domain/services/task_status_query_service.py +19 -0
  19. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/value_objects.py +26 -29
  20. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/dependencies.py +19 -4
  21. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/routers/indexes.py +45 -0
  22. kodit-0.4.3/src/kodit/infrastructure/api/v1/schemas/task_status.py +39 -0
  23. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/cloning/git/working_copy.py +9 -2
  24. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/enrichment/local_enrichment_provider.py +41 -30
  25. kodit-0.4.3/src/kodit/infrastructure/mappers/task_status_mapper.py +85 -0
  26. kodit-0.4.3/src/kodit/infrastructure/reporting/db_progress.py +23 -0
  27. kodit-0.4.3/src/kodit/infrastructure/reporting/log_progress.py +37 -0
  28. kodit-0.4.3/src/kodit/infrastructure/reporting/tdqm_progress.py +38 -0
  29. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/sqlalchemy/entities.py +61 -0
  30. kodit-0.4.3/src/kodit/infrastructure/sqlalchemy/task_status_repository.py +79 -0
  31. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/mcp.py +6 -2
  32. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/env.py +0 -1
  33. kodit-0.4.3/src/kodit/migrations/versions/b9cd1c3fd762_add_task_status.py +77 -0
  34. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/code_indexing_application_service_test.py +0 -2
  35. kodit-0.4.3/tests/kodit/application/services/reporting_test.py +39 -0
  36. kodit-0.4.3/tests/kodit/infrastructure/sqlalchemy/test_status_repository.py +324 -0
  37. {kodit-0.4.2 → kodit-0.4.3}/tests/smoke.sh +6 -1
  38. kodit-0.4.2/src/kodit/application/services/reporting.py +0 -86
  39. kodit-0.4.2/src/kodit/infrastructure/reporting/log_progress.py +0 -65
  40. kodit-0.4.2/src/kodit/infrastructure/reporting/tdqm_progress.py +0 -73
  41. {kodit-0.4.2 → kodit-0.4.3}/.claude/commands/debug.md +0 -0
  42. {kodit-0.4.2 → kodit-0.4.3}/.claude/commands/new-requirement.md +0 -0
  43. {kodit-0.4.2 → kodit-0.4.3}/.claude/commands/refactor.md +0 -0
  44. {kodit-0.4.2 → kodit-0.4.3}/.claude/commands/update-docs.md +0 -0
  45. {kodit-0.4.2 → kodit-0.4.3}/.claude/settings.json +0 -0
  46. {kodit-0.4.2 → kodit-0.4.3}/.cursor/rules/kodit.mdc +0 -0
  47. {kodit-0.4.2 → kodit-0.4.3}/.cursor/rules/style.mdc +0 -0
  48. {kodit-0.4.2 → kodit-0.4.3}/.dockerignore +0 -0
  49. {kodit-0.4.2 → kodit-0.4.3}/.github/CODE_OF_CONDUCT.md +0 -0
  50. {kodit-0.4.2 → kodit-0.4.3}/.github/CONTRIBUTING.md +0 -0
  51. {kodit-0.4.2 → kodit-0.4.3}/.github/ISSUE_TEMPLATE/bug_report.md +0 -0
  52. {kodit-0.4.2 → kodit-0.4.3}/.github/ISSUE_TEMPLATE/feature_request.md +0 -0
  53. {kodit-0.4.2 → kodit-0.4.3}/.github/PULL_REQUEST_TEMPLATE.md +0 -0
  54. {kodit-0.4.2 → kodit-0.4.3}/.github/dependabot.yml +0 -0
  55. {kodit-0.4.2 → kodit-0.4.3}/.github/workflows/docker.yaml +0 -0
  56. {kodit-0.4.2 → kodit-0.4.3}/.github/workflows/docs.yaml +0 -0
  57. {kodit-0.4.2 → kodit-0.4.3}/.github/workflows/pull_request.yaml +0 -0
  58. {kodit-0.4.2 → kodit-0.4.3}/.github/workflows/pypi-test.yaml +0 -0
  59. {kodit-0.4.2 → kodit-0.4.3}/.github/workflows/pypi.yaml +0 -0
  60. {kodit-0.4.2 → kodit-0.4.3}/.github/workflows/test.yaml +0 -0
  61. {kodit-0.4.2 → kodit-0.4.3}/.gitignore +0 -0
  62. {kodit-0.4.2 → kodit-0.4.3}/.python-version +0 -0
  63. {kodit-0.4.2 → kodit-0.4.3}/.vscode/launch.json +0 -0
  64. {kodit-0.4.2 → kodit-0.4.3}/CLAUDE.md +0 -0
  65. {kodit-0.4.2 → kodit-0.4.3}/Dockerfile +0 -0
  66. {kodit-0.4.2 → kodit-0.4.3}/LICENSE +0 -0
  67. {kodit-0.4.2 → kodit-0.4.3}/Makefile +0 -0
  68. {kodit-0.4.2 → kodit-0.4.3}/README.md +0 -0
  69. {kodit-0.4.2 → kodit-0.4.3}/alembic.ini +0 -0
  70. {kodit-0.4.2 → kodit-0.4.3}/docs/_index.md +0 -0
  71. {kodit-0.4.2 → kodit-0.4.3}/docs/demos/_index.md +0 -0
  72. {kodit-0.4.2 → kodit-0.4.3}/docs/demos/go-simple-microservice/index.md +0 -0
  73. {kodit-0.4.2 → kodit-0.4.3}/docs/demos/knock-knock-auth/index.md +0 -0
  74. {kodit-0.4.2 → kodit-0.4.3}/docs/developer/index.md +0 -0
  75. {kodit-0.4.2 → kodit-0.4.3}/docs/getting-started/_index.md +0 -0
  76. {kodit-0.4.2 → kodit-0.4.3}/docs/getting-started/installation/index.md +0 -0
  77. {kodit-0.4.2 → kodit-0.4.3}/docs/getting-started/integration/index.md +0 -0
  78. {kodit-0.4.2 → kodit-0.4.3}/docs/getting-started/quick-start/index.md +0 -0
  79. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/_index.md +0 -0
  80. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/templates/_content.md.j2 +0 -0
  81. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/templates/_example.md.j2 +0 -0
  82. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/templates/_object_schema.md.j2 +0 -0
  83. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/templates/_security_scheme.md.j2 +0 -0
  84. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/api/templates/api_doc_template.md.j2 +0 -0
  85. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/configuration/index.md +0 -0
  86. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/deployment/docker-compose.yaml +0 -0
  87. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/deployment/index.md +0 -0
  88. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/deployment/kubernetes.yaml +0 -0
  89. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/hosted-kodit/index.md +0 -0
  90. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/indexing/index.md +0 -0
  91. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/mcp/index.md +0 -0
  92. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/sync/index.md +0 -0
  93. {kodit-0.4.2 → kodit-0.4.3}/docs/reference/telemetry/index.md +0 -0
  94. {kodit-0.4.2 → kodit-0.4.3}/pyproject.toml +0 -0
  95. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/.gitignore +0 -0
  96. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/__init__.py +0 -0
  97. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/__init__.py +0 -0
  98. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/factories/__init__.py +0 -0
  99. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/services/__init__.py +0 -0
  100. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/services/queue_service.py +0 -0
  101. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/application/services/sync_scheduler.py +0 -0
  102. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/cli_utils.py +0 -0
  103. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/database.py +0 -0
  104. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/__init__.py +0 -0
  105. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/errors.py +0 -0
  106. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/services/__init__.py +0 -0
  107. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/services/bm25_service.py +0 -0
  108. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/services/embedding_service.py +0 -0
  109. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/services/enrichment_service.py +0 -0
  110. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/domain/services/index_query_service.py +0 -0
  111. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/__init__.py +0 -0
  112. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/__init__.py +0 -0
  113. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/client/__init__.py +0 -0
  114. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/client/base.py +0 -0
  115. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/client/exceptions.py +0 -0
  116. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/client/generated_endpoints.py +0 -0
  117. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/client/index_client.py +0 -0
  118. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/client/search_client.py +0 -0
  119. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/middleware/__init__.py +0 -0
  120. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/middleware/auth.py +0 -0
  121. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/__init__.py +0 -0
  122. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/routers/__init__.py +0 -0
  123. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/routers/queue.py +0 -0
  124. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/routers/search.py +0 -0
  125. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/schemas/__init__.py +0 -0
  126. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/schemas/context.py +0 -0
  127. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/schemas/index.py +0 -0
  128. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/schemas/queue.py +0 -0
  129. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/api/v1/schemas/search.py +0 -0
  130. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/bm25/__init__.py +0 -0
  131. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/bm25/bm25_factory.py +0 -0
  132. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/bm25/local_bm25_repository.py +0 -0
  133. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/bm25/vectorchord_bm25_repository.py +0 -0
  134. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/cloning/__init__.py +0 -0
  135. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/cloning/git/__init__.py +0 -0
  136. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/cloning/metadata.py +0 -0
  137. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/__init__.py +0 -0
  138. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/embedding_factory.py +0 -0
  139. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/embedding_providers/__init__.py +0 -0
  140. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/embedding_providers/batching.py +0 -0
  141. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/embedding_providers/hash_embedding_provider.py +0 -0
  142. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/embedding_providers/litellm_embedding_provider.py +0 -0
  143. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/embedding_providers/local_embedding_provider.py +0 -0
  144. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/local_vector_search_repository.py +0 -0
  145. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/embedding/vectorchord_vector_search_repository.py +0 -0
  146. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/enrichment/__init__.py +0 -0
  147. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/enrichment/enrichment_factory.py +0 -0
  148. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/enrichment/litellm_enrichment_provider.py +0 -0
  149. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/enrichment/null_enrichment_provider.py +0 -0
  150. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/enrichment/utils.py +0 -0
  151. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/git/__init__.py +0 -0
  152. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/git/git_utils.py +0 -0
  153. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/ignore/__init__.py +0 -0
  154. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/ignore/ignore_pattern_provider.py +0 -0
  155. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/indexing/__init__.py +0 -0
  156. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/indexing/fusion_service.py +0 -0
  157. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/mappers/__init__.py +0 -0
  158. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/mappers/index_mapper.py +0 -0
  159. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/mappers/task_mapper.py +0 -0
  160. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/reporting/__init__.py +0 -0
  161. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/slicing/__init__.py +0 -0
  162. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/slicing/language_detection_service.py +0 -0
  163. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/slicing/slicer.py +0 -0
  164. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/sqlalchemy/__init__.py +0 -0
  165. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/sqlalchemy/embedding_repository.py +0 -0
  166. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/sqlalchemy/index_repository.py +0 -0
  167. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/sqlalchemy/task_repository.py +0 -0
  168. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/infrastructure/sqlalchemy/unit_of_work.py +0 -0
  169. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/log.py +0 -0
  170. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/middleware.py +0 -0
  171. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/README +0 -0
  172. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/__init__.py +0 -0
  173. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/script.py.mako +0 -0
  174. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/4073b33f9436_add_file_processing_flag.py +0 -0
  175. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/4552eb3f23ce_add_summary.py +0 -0
  176. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/7c3bbc2ab32b_add_embeddings_table.py +0 -0
  177. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/85155663351e_initial.py +0 -0
  178. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/9cf0e87de578_add_queue.py +0 -0
  179. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/9e53ea8bb3b0_add_authors.py +0 -0
  180. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/__init__.py +0 -0
  181. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/migrations/versions/c3f5137d30f5_index_all_the_things.py +0 -0
  182. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/utils/__init__.py +0 -0
  183. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/utils/dump_openapi.py +0 -0
  184. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/utils/generate_api_paths.py +0 -0
  185. {kodit-0.4.2 → kodit-0.4.3}/src/kodit/utils/path_utils.py +0 -0
  186. {kodit-0.4.2 → kodit-0.4.3}/tests/__init__.py +0 -0
  187. {kodit-0.4.2 → kodit-0.4.3}/tests/conftest.py +0 -0
  188. {kodit-0.4.2 → kodit-0.4.3}/tests/docker-smoke.sh +0 -0
  189. {kodit-0.4.2 → kodit-0.4.3}/tests/experiments/__init__.py +0 -0
  190. {kodit-0.4.2 → kodit-0.4.3}/tests/experiments/cline_prompt_tests/__init__.py +0 -0
  191. {kodit-0.4.2 → kodit-0.4.3}/tests/experiments/cline_prompt_tests/cline_prompt.txt +0 -0
  192. {kodit-0.4.2 → kodit-0.4.3}/tests/experiments/cline_prompt_tests/cline_prompt_test.py +0 -0
  193. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/__init__.py +0 -0
  194. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/app_test.py +0 -0
  195. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/__init__.py +0 -0
  196. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/services/__init__.py +0 -0
  197. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/services/auto_indexing_service_test.py +0 -0
  198. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/services/indexing_worker_service_test.py +0 -0
  199. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/services/queue_service_get_task_test.py +0 -0
  200. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/services/queue_service_test.py +0 -0
  201. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/application/services/sync_scheduler_test.py +0 -0
  202. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/cli_test.py +0 -0
  203. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/config_test.py +0 -0
  204. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/__init__.py +0 -0
  205. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/bm25_service_test.py +0 -0
  206. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/embedding_service_test.py +0 -0
  207. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/enrichment_service_test.py +0 -0
  208. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/entities_test.py +0 -0
  209. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/language_detection_service_test.py +0 -0
  210. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/services/__init__.py +0 -0
  211. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/services/index_service_test.py +0 -0
  212. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/domain/value_objects_test.py +0 -0
  213. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/e2e.py +0 -0
  214. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/__init__.py +0 -0
  215. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/bm25/__init__.py +0 -0
  216. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/bm25/local_bm25_repository_test.py +0 -0
  217. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/bm25/vectorchord_bm25_repository_test.py +0 -0
  218. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/cloning/git_cloning/__init__.py +0 -0
  219. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/cloning/git_cloning/working_copy_test.py +0 -0
  220. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/__init__.py +0 -0
  221. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/batching_test.py +0 -0
  222. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/embedding_factory_test.py +0 -0
  223. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/embedding_provider/__init__.py +0 -0
  224. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/embedding_provider/hash_embedding_provider_test.py +0 -0
  225. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/embedding_provider/litellm_embedding_provider_test.py +0 -0
  226. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/embedding_provider/local_embedding_provider_test.py +0 -0
  227. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/local_vector_search_repository_test.py +0 -0
  228. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/test_embedding_integration.py +0 -0
  229. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/test_litellm_socket_providers.py +0 -0
  230. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/embedding/vectorchord_vector_search_repository_test.py +0 -0
  231. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/__init__.py +0 -0
  232. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/enrichment_factory_test.py +0 -0
  233. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/enrichment_provider/__init__.py +0 -0
  234. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/enrichment_provider/litellm_enrichment_provider_test.py +0 -0
  235. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/enrichment_provider/local_enrichment_provider_test.py +0 -0
  236. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/enrichment_provider/null_enrichment_provider_test.py +0 -0
  237. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/enrichment/utils_test.py +0 -0
  238. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/mappers/__init__.py +0 -0
  239. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/mappers/index_mapper_test.py +0 -0
  240. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/__init__.py +0 -0
  241. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/__init__.py +0 -0
  242. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/c/main.c +0 -0
  243. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/c/models.c +0 -0
  244. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/c/models.h +0 -0
  245. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/c/utils.c +0 -0
  246. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/c/utils.h +0 -0
  247. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/cpp/main.cpp +0 -0
  248. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/cpp/models.cpp +0 -0
  249. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/cpp/models.hpp +0 -0
  250. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/cpp/utils.cpp +0 -0
  251. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/cpp/utils.hpp +0 -0
  252. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/csharp/Main.cs +0 -0
  253. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/csharp/Models.cs +0 -0
  254. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/csharp/Utils.cs +0 -0
  255. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/css/components.css +0 -0
  256. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/css/main.css +0 -0
  257. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/css/utilities.css +0 -0
  258. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/go/main.go +0 -0
  259. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/go/models.go +0 -0
  260. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/go/utils.go +0 -0
  261. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/html/components.html +0 -0
  262. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/html/forms.html +0 -0
  263. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/html/main.html +0 -0
  264. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/java/Main.java +0 -0
  265. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/java/Models.java +0 -0
  266. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/java/Utils.java +0 -0
  267. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/javascript/main.js +0 -0
  268. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/javascript/models.js +0 -0
  269. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/javascript/utils.js +0 -0
  270. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/python/__init__.py +0 -0
  271. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/python/main.py +0 -0
  272. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/python/models.py +0 -0
  273. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/python/utils.py +0 -0
  274. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/rust/main.rs +0 -0
  275. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/rust/models.rs +0 -0
  276. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/data/rust/utils.rs +0 -0
  277. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/slicing/slicer_test.py +0 -0
  278. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/__init__.py +0 -0
  279. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/csharp.cs +0 -0
  280. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/golang.go +0 -0
  281. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/javascript.js +0 -0
  282. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/knock_knock_server.py +0 -0
  283. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/python.py +0 -0
  284. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/snippets/typescript.tsx +0 -0
  285. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/sqlalchemy/__init__.py +0 -0
  286. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/sqlalchemy/embedding_repository_test.py +0 -0
  287. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/sqlalchemy/index_repository_test.py +0 -0
  288. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/infrastructure/sqlalchemy/task_repository_test.py +0 -0
  289. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/log_test.py +0 -0
  290. {kodit-0.4.2 → kodit-0.4.3}/tests/kodit/mcp_test.py +0 -0
  291. {kodit-0.4.2 → kodit-0.4.3}/tests/performance/__init__.py +0 -0
  292. {kodit-0.4.2 → kodit-0.4.3}/tests/performance/similarity.py +0 -0
  293. {kodit-0.4.2 → kodit-0.4.3}/tests/utils/__init__.py +0 -0
  294. {kodit-0.4.2 → kodit-0.4.3}/tests/utils/path_utils_test.py +0 -0
  295. {kodit-0.4.2 → kodit-0.4.3}/tests/vectorchord-smoke.sh +0 -0
  296. {kodit-0.4.2 → kodit-0.4.3}/uv.lock +0 -0
@@ -25,4 +25,7 @@
25
25
  "python.analysis.completeFunctionParens": true,
26
26
  "python.analysis.inlayHints.functionReturnTypes": true,
27
27
  "python.analysis.typeCheckingMode": "standard",
28
+ "cursorpyright.analysis.autoImportCompletions": true,
29
+ "cursorpyright.analysis.inlayHints.functionReturnTypes": true,
30
+ "cursorpyright.analysis.typeCheckingMode": "standard",
28
31
  }
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: kodit
3
- Version: 0.4.2
3
+ Version: 0.4.3
4
4
  Summary: Code indexing for better AI code generation
5
5
  Project-URL: Homepage, https://docs.helixml.tech/kodit/
6
6
  Project-URL: Documentation, https://docs.helixml.tech/kodit/
@@ -12,7 +12,7 @@ look at the [hosted version](https://kodit.helix.ml/docs).
12
12
  This is the REST API for the Kodit server. Please refer to the
13
13
  [Kodit documentation](https://docs.helix.ml/kodit/) for more information.
14
14
 
15
- Current version: 0.4.2
15
+ Current version: 0.4.3
16
16
 
17
17
  ## Authentication
18
18
 
@@ -126,6 +126,32 @@ Delete an index.
126
126
 
127
127
  - 404: Index not found
128
128
 
129
+ ### GET /api/v1/indexes/{index_id}/status
130
+
131
+ Get the status of tasks for an index.
132
+
133
+
134
+ #### Parameters
135
+
136
+ | Name | Type | Required | Description |
137
+ |------|------|----------|-------------|
138
+ | index_id | integer | True | |
139
+
140
+
141
+ #### Responses
142
+
143
+ - 200: Successful Response
144
+
145
+ [TaskStatusListResponse](#taskstatuslistresponse)
146
+
147
+ - 500: Internal server error
148
+
149
+ - 401: Unauthorized
150
+
151
+ - 422: Invalid request
152
+
153
+ - 404: Index not found
154
+
129
155
  ### GET /api/v1/queue
130
156
 
131
157
  List all tasks in the queue.
@@ -453,6 +479,47 @@ JSON:API response for single task.
453
479
  | data | | |
454
480
 
455
481
 
482
+ ### TaskStatusAttributes
483
+
484
+
485
+ Task status attributes for JSON:API responses.
486
+
487
+
488
+ | Field | Type | Description |
489
+ |-------|------|-------------|
490
+ | step | string | Name of the task/operation |
491
+ | state | string | Current state of the task |
492
+ | progress | number | Progress percentage (0-100) |
493
+ | total | integer | Total number of items to process |
494
+ | current | integer | Current number of items processed |
495
+ | created_at | | Task start time |
496
+ | updated_at | | Last update time |
497
+
498
+
499
+ ### TaskStatusData
500
+
501
+
502
+ Task status data for JSON:API responses.
503
+
504
+
505
+ | Field | Type | Description |
506
+ |-------|------|-------------|
507
+ | type | string | |
508
+ | id | string | |
509
+ | attributes | | |
510
+
511
+
512
+ ### TaskStatusListResponse
513
+
514
+
515
+ JSON:API response for task status list.
516
+
517
+
518
+ | Field | Type | Description |
519
+ |-------|------|-------------|
520
+ | data | array | |
521
+
522
+
456
523
  ### TaskType
457
524
 
458
525
 
@@ -3,7 +3,7 @@
3
3
  "info": {
4
4
  "title": "kodit API",
5
5
  "description": "\nThis is the REST API for the Kodit server. Please refer to the\n[Kodit documentation](https://docs.helix.ml/kodit/) for more information.\n ",
6
- "version": "0.4.2"
6
+ "version": "0.4.3"
7
7
  },
8
8
  "paths": {
9
9
  "/healthz": {
@@ -197,6 +197,56 @@
197
197
  }
198
198
  }
199
199
  },
200
+ "/api/v1/indexes/{index_id}/status": {
201
+ "get": {
202
+ "tags": [
203
+ "indexes"
204
+ ],
205
+ "summary": "Get Index Status",
206
+ "description": "Get the status of tasks for an index.",
207
+ "operationId": "get_index_status_api_v1_indexes__index_id__status_get",
208
+ "security": [
209
+ {
210
+ "Header (X-API-KEY)": []
211
+ }
212
+ ],
213
+ "parameters": [
214
+ {
215
+ "name": "index_id",
216
+ "in": "path",
217
+ "required": true,
218
+ "schema": {
219
+ "type": "integer",
220
+ "title": "Index Id"
221
+ }
222
+ }
223
+ ],
224
+ "responses": {
225
+ "200": {
226
+ "description": "Successful Response",
227
+ "content": {
228
+ "application/json": {
229
+ "schema": {
230
+ "$ref": "#/components/schemas/TaskStatusListResponse"
231
+ }
232
+ }
233
+ }
234
+ },
235
+ "500": {
236
+ "description": "Internal server error"
237
+ },
238
+ "401": {
239
+ "description": "Unauthorized"
240
+ },
241
+ "422": {
242
+ "description": "Invalid request"
243
+ },
244
+ "404": {
245
+ "description": "Index not found"
246
+ }
247
+ }
248
+ }
249
+ },
200
250
  "/api/v1/queue": {
201
251
  "get": {
202
252
  "tags": [
@@ -900,6 +950,113 @@
900
950
  "title": "TaskResponse",
901
951
  "description": "JSON:API response for single task."
902
952
  },
953
+ "TaskStatusAttributes": {
954
+ "properties": {
955
+ "step": {
956
+ "type": "string",
957
+ "title": "Step",
958
+ "description": "Name of the task/operation"
959
+ },
960
+ "state": {
961
+ "type": "string",
962
+ "title": "State",
963
+ "description": "Current state of the task"
964
+ },
965
+ "progress": {
966
+ "type": "number",
967
+ "maximum": 100.0,
968
+ "minimum": 0.0,
969
+ "title": "Progress",
970
+ "description": "Progress percentage (0-100)",
971
+ "default": 0.0
972
+ },
973
+ "total": {
974
+ "type": "integer",
975
+ "title": "Total",
976
+ "description": "Total number of items to process",
977
+ "default": 0
978
+ },
979
+ "current": {
980
+ "type": "integer",
981
+ "title": "Current",
982
+ "description": "Current number of items processed",
983
+ "default": 0
984
+ },
985
+ "created_at": {
986
+ "anyOf": [
987
+ {
988
+ "type": "string",
989
+ "format": "date-time"
990
+ },
991
+ {
992
+ "type": "null"
993
+ }
994
+ ],
995
+ "title": "Created At",
996
+ "description": "Task start time"
997
+ },
998
+ "updated_at": {
999
+ "anyOf": [
1000
+ {
1001
+ "type": "string",
1002
+ "format": "date-time"
1003
+ },
1004
+ {
1005
+ "type": "null"
1006
+ }
1007
+ ],
1008
+ "title": "Updated At",
1009
+ "description": "Last update time"
1010
+ }
1011
+ },
1012
+ "type": "object",
1013
+ "required": [
1014
+ "step",
1015
+ "state"
1016
+ ],
1017
+ "title": "TaskStatusAttributes",
1018
+ "description": "Task status attributes for JSON:API responses."
1019
+ },
1020
+ "TaskStatusData": {
1021
+ "properties": {
1022
+ "type": {
1023
+ "type": "string",
1024
+ "title": "Type",
1025
+ "default": "task_status"
1026
+ },
1027
+ "id": {
1028
+ "type": "string",
1029
+ "title": "Id"
1030
+ },
1031
+ "attributes": {
1032
+ "$ref": "#/components/schemas/TaskStatusAttributes"
1033
+ }
1034
+ },
1035
+ "type": "object",
1036
+ "required": [
1037
+ "id",
1038
+ "attributes"
1039
+ ],
1040
+ "title": "TaskStatusData",
1041
+ "description": "Task status data for JSON:API responses."
1042
+ },
1043
+ "TaskStatusListResponse": {
1044
+ "properties": {
1045
+ "data": {
1046
+ "items": {
1047
+ "$ref": "#/components/schemas/TaskStatusData"
1048
+ },
1049
+ "type": "array",
1050
+ "title": "Data"
1051
+ }
1052
+ },
1053
+ "type": "object",
1054
+ "required": [
1055
+ "data"
1056
+ ],
1057
+ "title": "TaskStatusListResponse",
1058
+ "description": "JSON:API response for task status list."
1059
+ },
903
1060
  "TaskType": {
904
1061
  "type": "integer",
905
1062
  "enum": [
@@ -28,7 +28,7 @@ version_tuple: VERSION_TUPLE
28
28
  commit_id: COMMIT_ID
29
29
  __commit_id__: COMMIT_ID
30
30
 
31
- __version__ = version = '0.4.2'
32
- __version_tuple__ = version_tuple = (0, 4, 2)
31
+ __version__ = version = '0.4.3'
32
+ __version_tuple__ = version_tuple = (0, 4, 3)
33
33
 
34
34
  __commit_id__ = commit_id = None
@@ -19,6 +19,9 @@ from kodit.infrastructure.api.v1.routers import (
19
19
  search_router,
20
20
  )
21
21
  from kodit.infrastructure.api.v1.schemas.context import AppLifespanState
22
+ from kodit.infrastructure.sqlalchemy.task_status_repository import (
23
+ create_task_status_repository,
24
+ )
22
25
  from kodit.mcp import mcp
23
26
  from kodit.middleware import ASGICancelledErrorMiddleware, logging_middleware
24
27
 
@@ -35,7 +38,9 @@ async def app_lifespan(_: FastAPI) -> AsyncIterator[AppLifespanState]:
35
38
  # App context has already been configured by the CLI.
36
39
  app_context = AppContext()
37
40
  db = await app_context.get_db()
38
- operation = create_server_operation()
41
+ operation = create_server_operation(
42
+ create_task_status_repository(db.session_factory)
43
+ )
39
44
 
40
45
  # Start the queue worker service
41
46
  _indexing_worker_service = IndexingWorkerService(
@@ -51,22 +51,26 @@ from kodit.infrastructure.sqlalchemy.entities import EmbeddingType
51
51
  from kodit.infrastructure.sqlalchemy.index_repository import (
52
52
  create_index_repository,
53
53
  )
54
+ from kodit.infrastructure.sqlalchemy.task_status_repository import (
55
+ create_task_status_repository,
56
+ )
54
57
 
55
58
 
56
59
  def create_code_indexing_application_service(
57
60
  app_context: AppContext,
58
- session: AsyncSession,
59
61
  session_factory: Callable[[], AsyncSession],
60
62
  operation: ProgressTracker,
61
63
  ) -> CodeIndexingApplicationService:
62
64
  """Create a unified code indexing application service with all dependencies."""
63
65
  # Create domain services
64
- bm25_service = BM25DomainService(bm25_repository_factory(app_context, session))
66
+ bm25_service = BM25DomainService(
67
+ bm25_repository_factory(app_context, session_factory())
68
+ )
65
69
  code_search_service = embedding_domain_service_factory(
66
- "code", app_context, session, session_factory
70
+ "code", app_context, session_factory(), session_factory
67
71
  )
68
72
  text_search_service = embedding_domain_service_factory(
69
- "text", app_context, session, session_factory
73
+ "text", app_context, session_factory(), session_factory
70
74
  )
71
75
  enrichment_service = enrichment_domain_service_factory(app_context)
72
76
  index_repository = create_index_repository(session_factory=session_factory)
@@ -95,20 +99,17 @@ def create_code_indexing_application_service(
95
99
  code_search_service=code_search_service,
96
100
  text_search_service=text_search_service,
97
101
  enrichment_service=enrichment_service,
98
- session=session,
99
102
  operation=operation,
100
103
  )
101
104
 
102
105
 
103
106
  def create_cli_code_indexing_application_service(
104
107
  app_context: AppContext,
105
- session: AsyncSession,
106
108
  session_factory: Callable[[], AsyncSession],
107
109
  ) -> CodeIndexingApplicationService:
108
110
  """Create a CLI code indexing application service."""
109
111
  return create_code_indexing_application_service(
110
112
  app_context,
111
- session,
112
113
  session_factory,
113
114
  create_cli_operation(),
114
115
  )
@@ -116,23 +117,25 @@ def create_cli_code_indexing_application_service(
116
117
 
117
118
  def create_server_code_indexing_application_service(
118
119
  app_context: AppContext,
119
- session: AsyncSession,
120
120
  session_factory: Callable[[], AsyncSession],
121
121
  ) -> CodeIndexingApplicationService:
122
122
  """Create a server code indexing application service."""
123
123
  return create_code_indexing_application_service(
124
- app_context, session, session_factory, create_server_operation()
124
+ app_context,
125
+ session_factory,
126
+ create_server_operation(create_task_status_repository(session_factory)),
125
127
  )
126
128
 
127
129
 
128
130
  def create_fast_test_code_indexing_application_service(
129
131
  app_context: AppContext,
130
- session: AsyncSession,
131
132
  session_factory: Callable[[], AsyncSession],
132
133
  ) -> CodeIndexingApplicationService:
133
134
  """Create a fast test code indexing application service."""
134
135
  # Create domain services
135
- bm25_service = BM25DomainService(bm25_repository_factory(app_context, session))
136
+ bm25_service = BM25DomainService(
137
+ bm25_repository_factory(app_context, session_factory())
138
+ )
136
139
  embedding_repository = create_embedding_repository(session_factory=session_factory)
137
140
  operation = create_noop_operation()
138
141
 
@@ -188,6 +191,5 @@ def create_fast_test_code_indexing_application_service(
188
191
  code_search_service=code_search_service,
189
192
  text_search_service=text_search_service,
190
193
  enrichment_service=enrichment_service,
191
- session=session,
192
194
  operation=operation,
193
195
  )
@@ -1,27 +1,32 @@
1
1
  """Reporting factory."""
2
2
 
3
- from kodit.application.services.reporting import OperationType, ProgressTracker
3
+ from kodit.application.services.reporting import ProgressTracker, TaskOperation
4
4
  from kodit.config import ReportingConfig
5
+ from kodit.domain.protocols import TaskStatusRepository
6
+ from kodit.infrastructure.reporting.db_progress import DBProgressReportingModule
5
7
  from kodit.infrastructure.reporting.log_progress import LoggingReportingModule
6
8
  from kodit.infrastructure.reporting.tdqm_progress import TQDMReportingModule
7
9
 
8
10
 
9
11
  def create_noop_operation() -> ProgressTracker:
10
12
  """Create a noop reporter."""
11
- return ProgressTracker(OperationType.ROOT.value)
13
+ return ProgressTracker.create(TaskOperation.ROOT)
12
14
 
13
15
 
14
16
  def create_cli_operation(config: ReportingConfig | None = None) -> ProgressTracker:
15
17
  """Create a CLI reporter."""
16
18
  shared_config = config or ReportingConfig()
17
- s = ProgressTracker(OperationType.ROOT.value)
19
+ s = ProgressTracker.create(TaskOperation.ROOT)
18
20
  s.subscribe(TQDMReportingModule(shared_config))
19
21
  return s
20
22
 
21
23
 
22
- def create_server_operation(config: ReportingConfig | None = None) -> ProgressTracker:
24
+ def create_server_operation(
25
+ task_status_repository: TaskStatusRepository, config: ReportingConfig | None = None
26
+ ) -> ProgressTracker:
23
27
  """Create a server reporter."""
24
28
  shared_config = config or ReportingConfig()
25
- s = ProgressTracker(OperationType.ROOT.value)
29
+ s = ProgressTracker.create(TaskOperation.ROOT)
26
30
  s.subscribe(LoggingReportingModule(shared_config))
31
+ s.subscribe(DBProgressReportingModule(task_status_repository, shared_config))
27
32
  return s
@@ -62,38 +62,34 @@ class AutoIndexingService:
62
62
  ) -> None:
63
63
  """Index all configured sources in the background."""
64
64
  operation = operation or create_noop_operation()
65
- async with self.session_factory() as session:
66
- queue_service = QueueService(session_factory=self.session_factory)
67
- service = create_code_indexing_application_service(
68
- app_context=self.app_context,
69
- session=session,
70
- session_factory=self.session_factory,
71
- operation=operation,
72
- )
73
-
74
- for source in sources:
75
- try:
76
- # Only auto-index a source if it is new
77
- if await service.does_index_exist(source):
78
- self.log.info("Index already exists, skipping", source=source)
79
- continue
80
-
81
- self.log.info("Adding auto-indexing task to queue", source=source)
82
-
83
- # Create index
84
- index = await service.create_index_from_uri(source)
85
-
86
- await queue_service.enqueue_task(
87
- Task.create_index_update_task(
88
- index.id, QueuePriority.BACKGROUND
89
- )
90
- )
91
-
92
- except Exception as exc:
93
- self.log.exception(
94
- "Failed to auto-index source", source=source, error=str(exc)
95
- )
96
- # Continue with other sources even if one fails
65
+ queue_service = QueueService(session_factory=self.session_factory)
66
+ service = create_code_indexing_application_service(
67
+ app_context=self.app_context,
68
+ session_factory=self.session_factory,
69
+ operation=operation,
70
+ )
71
+
72
+ for source in sources:
73
+ try:
74
+ # Only auto-index a source if it is new
75
+ if await service.does_index_exist(source):
76
+ self.log.info("Index already exists, skipping", source=source)
77
+ continue
78
+
79
+ self.log.info("Adding auto-indexing task to queue", source=source)
80
+
81
+ # Create index
82
+ index = await service.create_index_from_uri(source)
83
+
84
+ await queue_service.enqueue_task(
85
+ Task.create_index_update_task(index.id, QueuePriority.BACKGROUND)
86
+ )
87
+
88
+ except Exception as exc:
89
+ self.log.exception(
90
+ "Failed to auto-index source", source=source, error=str(exc)
91
+ )
92
+ # Continue with other sources even if one fails
97
93
 
98
94
  async def stop(self) -> None:
99
95
  """Stop background indexing."""