[project]
name = "code-graph"
version = "0.9.0"
description = "Enterprise knowledge management platform with Neo4j graph database, multi-interface architecture (MCP/Web/REST), and intelligent code analysis"
readme = "README.md"
requires-python = ">=3.13"
dependencies = [
"fastapi",
"uvicorn[standard]",
"python-multipart",
"sqlglot",
"neo4j",
"llama-index-core",
"llama-index-llms-ollama",
"llama-index-llms-gemini",
"llama-index-embeddings-ollama",
"llama-index-embeddings-gemini",
"llama-index-graph-stores-neo4j",
"httpx",
"aiofiles",
"python-jose[cryptography]",
"pydantic",
"pydantic-settings",
"python-dotenv",
"loguru",
"mcp",
"google-generativeai",
"prometheus-client",
]
[project.optional-dependencies]
openrouter = [
"llama-index-llms-openrouter",
]
dev = [
"bump-my-version>=0.26.0",
"pytest>=8.0.0",
"pytest-asyncio>=0.23.0",
"pytest-cov>=4.1.0",
"black>=24.0.0",
"isort>=5.13.0",
"ruff>=0.6.0",
]
[project.scripts]
codebase-rag = "codebase_rag.__main__:main"
codebase-rag-web = "codebase_rag.server.web:main"
codebase-rag-mcp = "codebase_rag.server.mcp:main"
[tool.setuptools]
packages = {find = {where = ["src"]}}
[tool.setuptools.package-data]
codebase_rag = ["py.typed"]
[tool.pytest.ini_options]
minversion = "6.0"
addopts = "-ra -q --strict-markers"
testpaths = ["tests"]
python_files = ["test_*.py"]
python_classes = ["Test*"]
python_functions = ["test_*"]
markers = [
"unit: mark test as a unit test (no external dependencies)",
"integration: mark test as an integration test (requires Neo4j, etc.)",
"slow: mark test as slow running",
]
asyncio_mode = "auto"
asyncio_default_fixture_loop_scope = "function"
[tool.coverage.run]
source = ["src/codebase_rag"]
omit = [
"*/tests/*",
"*/test_*.py",
"*/__pycache__/*",
"*/venv/*",
"*/.venv/*",
]
[tool.coverage.report]
exclude_lines = [
"pragma: no cover",
"def __repr__",
"raise AssertionError",
"raise NotImplementedError",
"if __name__ == .__main__.:",
"if TYPE_CHECKING:",
"@abstractmethod",
]
[tool.black]
line-length = 100
target-version = ['py311', 'py312', 'py313']
include = '\.pyi?$'
extend-exclude = '''
/(
# directories
\.eggs
| \.git
| \.hg
| \.mypy_cache
| \.tox
| \.venv
| _build
| buck-out
| build
| dist
)/
'''
[tool.isort]
profile = "black"
line_length = 100
multi_line_output = 3
include_trailing_comma = true
force_grid_wrap = 0
use_parentheses = true
ensure_newline_before_comments = true
[tool.ruff]
line-length = 100
target-version = "py311"
select = [
"E", # pycodestyle errors
"W", # pycodestyle warnings
"F", # pyflakes
"I", # isort
"C", # flake8-comprehensions
"B", # flake8-bugbear
]
ignore = [
"E501", # line too long (handled by black)
"B008", # do not perform function calls in argument defaults
"C901", # too complex
]
exclude = [
".git",
".venv",
"__pycache__",
"build",
"dist",
]