devrev-Python-SDK 2.10.1__tar.gz → 2.10.2__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.
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/api-check.yml +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/deploy.yml +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/docs.yml +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/release.yml +2 -2
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/PKG-INFO +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/changelog.md +13 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/llms-mcp.txt +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/llms.txt +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/pyproject.toml +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/articles.py +70 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/parts.py +16 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/articles.py +27 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/articles.py +24 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/parts.py +10 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_parts.py +79 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/uv.lock +1 -1
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/bug-fixer.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/builder.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/documentation.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/foreman.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/pr-review-boss.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/release-manager.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/simplifier.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/agents/tester.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/commands/foreman-work.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/commands/release-prepare.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/commands/review-start.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/commands/simplify-code.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/code-quality.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/data-modeling.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/devrev-sdk.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/git-workflow.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/pull-requests.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/python-development.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/security.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.augment/rules/testing.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.dockerignore +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.env.sample +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/ISSUE_TEMPLATE/article-artifact-simplification.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/ISSUE_TEMPLATE/bug_report.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/ISSUE_TEMPLATE/config.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/ISSUE_TEMPLATE/feature_request.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/ISSUE_TEMPLATE/question.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/dependabot.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/pull_request_template.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/ci.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/claude-code-review.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/claude.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/integration-tests.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.github/workflows/sync-openapi.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.gitignore +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/.pre-commit-config.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/CLAUDE.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/CODE_OF_CONDUCT.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/CONTRIBUTING.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/DEPRECATIONS.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/Dockerfile +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/KNOWN_ISSUES.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/OPENAPI_SPEC_DISCREPANCIES.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/SECURITY.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/augment-mcp-config-remote.json +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/augment-mcp-config.json +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/augment-settings.json +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/benchmarks/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/benchmarks/bench_http_client.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/benchmarks/bench_models.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/benchmarks/bench_pagination.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/benchmarks/conftest.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/context7.json +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/audit-logging-setup.sh +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/cloudbuild.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/monitoring/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/monitoring/alert-policies.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/monitoring/dashboard.json +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/monitoring/validate-config.sh +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/deploy/service.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docker-compose.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/brands.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/engagements.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/incidents.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/question-answers.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/recommendations.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/search.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta/uoms.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/beta-api-differences.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/client.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/config.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/exceptions.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/models/accounts.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/models/base.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/models/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/models/users.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/models/works.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/accounts.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/articles.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/code-changes.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/conversations.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/dev-users.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/groups.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/links.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/parts.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/rev-users.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/slas.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/tags.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/timeline-entries.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/webhooks.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/api/services/works.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/examples/advanced.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/examples/basic.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/examples/beta-features.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/examples/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/examples/integrations.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/getting-started/authentication.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/getting-started/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/getting-started/installation.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/getting-started/quickstart.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/beta-api.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/compatibility.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/configuration.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/error-handling.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/github-actions-setup.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/logging.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/pagination.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/sync-vs-async.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/testing.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/version-support.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/guides/write-integration-testing-strategy.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/hooks/copy_llms.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/mcp/deployment.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/mcp/index.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/mcp/quickstart.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/mcp/tools-reference.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/docs/stylesheets/extra.css +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/async_example.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/create_work.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/error_handling.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/list_accounts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/pagination.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/basic/search_users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/cloud_functions/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/cloud_functions/main.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/cloud_functions/requirements.txt +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/fastapi/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/fastapi/main.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/fastapi/requirements.txt +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/flask/README.md +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/flask/app.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/examples/integrations/flask/requirements.txt +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/llms-ctx-full.txt +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/llms-ctx.txt +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/mkdocs.yml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/openapi-beta.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/openapi-public.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/openapi-spec-corrections.yaml +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/scripts/build_ai_docs.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/scripts/debug_articles.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/scripts/setup-github-secrets.sh +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/client.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/config.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/exceptions.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/accounts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/artifacts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/base.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/brands.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/code_changes.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/conversations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/dev_users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/engagements.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/groups.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/incidents.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/links.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/notifications.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/preferences.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/question_answers.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/recommendations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/rev_users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/search.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/slas.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/sync.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/tags.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/tasks.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/timeline_entries.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/timeline_events.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/track_events.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/uoms.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/webhooks.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/widgets.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/models/works.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/py.typed +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/accounts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/artifacts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/base.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/brands.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/code_changes.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/conversations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/dev_users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/engagements.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/groups.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/incidents.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/links.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/notifications.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/parts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/preferences.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/question_answers.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/recommendations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/rev_users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/search.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/slas.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/tags.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/timeline_entries.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/track_events.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/uoms.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/webhooks.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/services/works.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/utils/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/utils/content_converter.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/utils/deprecation.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/utils/http.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/utils/logging.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev/utils/pagination.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/__main__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/config.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/middleware/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/middleware/audit.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/middleware/auth.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/middleware/health.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/middleware/rate_limit.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/prompts/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/prompts/escalation.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/prompts/investigate.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/prompts/response.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/prompts/summarize.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/prompts/triage.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/account.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/article.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/conversation.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/part.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/server_info.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/ticket.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/resources/user.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/server.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/accounts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/conversations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/engagements.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/groups.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/incidents.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/links.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/recommendations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/search.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/server_info.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/slas.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/tags.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/timeline.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/tools/works.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/utils/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/utils/errors.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/utils/formatting.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/src/devrev_mcp/utils/pagination.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/conftest.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/conftest.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_accounts_e2e.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_all_readonly_endpoints.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_articles_lifecycle.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_backwards_compatibility.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_contacts_e2e.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_core_services_phase1.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_extended_services_phase2.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_get_endpoints.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_issues_e2e.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_kb_articles_e2e.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_mcp_articles.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_ping.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_question_answers_e2e.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_readonly_endpoints.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_specialized_services_phase3.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_tickets_e2e.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/test_write_operations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/utils/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/utils/cleanup.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/utils/constants.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/integration/utils/data_manager.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/performance/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/performance/test_articles_performance.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/conftest.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_audit.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_config.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_phase4_transport.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_prompts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_resources.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_server_info.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_accounts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_articles.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_conversations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_engagements.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_groups.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_incidents.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_links.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_recommendations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_search.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_slas.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_tags.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_timeline.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_users.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_tools_works.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/mcp/test_utils.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/models/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/models/test_user_state_regression.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/__init__.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/conftest.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_articles.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_async_services.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_brands.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_code_changes.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_conversations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_engagements.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_groups.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_incidents.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_links.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_notifications.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_parts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_preferences.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_question_answers.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_recommendations.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_search.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_slas.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_tags.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_timeline_entries.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_track_events.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_uoms.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_webhooks.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/services/test_works.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_articles_unified.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_artifacts.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_backward_compatibility.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_base_service.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_client.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_config.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_content_converter.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_deprecation.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_error_handling.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_exceptions.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_http.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_logging.py +0 -0
- {devrev_python_sdk-2.10.1 → devrev_python_sdk-2.10.2}/tests/unit/test_pagination.py +0 -0
|
@@ -32,7 +32,7 @@ jobs:
|
|
|
32
32
|
python-version: '3.12'
|
|
33
33
|
|
|
34
34
|
- name: Install uv
|
|
35
|
-
uses: astral-sh/setup-uv@
|
|
35
|
+
uses: astral-sh/setup-uv@v7
|
|
36
36
|
|
|
37
37
|
- name: Install dependencies
|
|
38
38
|
run: uv sync --frozen --all-extras
|
|
@@ -77,7 +77,7 @@ jobs:
|
|
|
77
77
|
python -c "import devrev; print(f'Installed: devrev')"
|
|
78
78
|
|
|
79
79
|
- name: Upload artifacts
|
|
80
|
-
uses: actions/upload-artifact@
|
|
80
|
+
uses: actions/upload-artifact@v7
|
|
81
81
|
with:
|
|
82
82
|
name: dist
|
|
83
83
|
path: dist/
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: devrev-Python-SDK
|
|
3
|
-
Version: 2.10.
|
|
3
|
+
Version: 2.10.2
|
|
4
4
|
Summary: A modern, type-safe Python SDK for the DevRev API
|
|
5
5
|
Project-URL: Homepage, https://github.com/mgmonteleone/py-dev-rev
|
|
6
6
|
Project-URL: Documentation, https://github.com/mgmonteleone/py-dev-rev
|
|
@@ -7,6 +7,19 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
7
7
|
|
|
8
8
|
## [Unreleased]
|
|
9
9
|
|
|
10
|
+
## [2.10.2] - 2026-03-11
|
|
11
|
+
|
|
12
|
+
### Fixed
|
|
13
|
+
|
|
14
|
+
- **Parts API missing parameters** (#158) — Added `owned_by`, `parent_part`, and `tags` parameters to `devrev_parts_create` MCP tool for full API compatibility.
|
|
15
|
+
- **Article API missing properties** (#159) — Added missing `access_level`, `authored_by`, `extracted_content`, `owned_by`, `published_at`, `scope`, `shared_with`, `tags`, and `verified_by` fields to article models.
|
|
16
|
+
|
|
17
|
+
### Maintenance
|
|
18
|
+
|
|
19
|
+
- **Dependency updates** (#182) — Consolidated Dependabot updates (March 2026):
|
|
20
|
+
- Multiple dependency version updates via automated security scanning
|
|
21
|
+
- **Documentation** — Updated `llms.txt` and `llms-mcp.txt` version references to 2.10.1.
|
|
22
|
+
|
|
10
23
|
## [2.10.1] - 2026-03-10
|
|
11
24
|
|
|
12
25
|
### Fixed
|
|
@@ -10,7 +10,7 @@ Key information:
|
|
|
10
10
|
- Both sync and async clients available (DevRevClient, AsyncDevRevClient)
|
|
11
11
|
- Uses Pydantic v2 for all request/response models
|
|
12
12
|
- MCP Server command: `devrev-mcp-server`
|
|
13
|
-
- Version 2.
|
|
13
|
+
- Version 2.10.1 (current)
|
|
14
14
|
|
|
15
15
|
## SDK Quick Start
|
|
16
16
|
|
|
@@ -94,6 +94,29 @@ class ArticleParentSummary(DevRevResponseModel):
|
|
|
94
94
|
display_id: str | None = Field(default=None, description="Display ID")
|
|
95
95
|
|
|
96
96
|
|
|
97
|
+
class ArtifactSummary(DevRevResponseModel):
|
|
98
|
+
"""Summary of an artifact (used for extracted_content)."""
|
|
99
|
+
|
|
100
|
+
id: str = Field(..., description="Artifact DON ID")
|
|
101
|
+
display_id: str | None = Field(default=None, description="Display ID")
|
|
102
|
+
file: dict[str, Any] | None = Field(default=None, description="File metadata")
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
class SyncMetadata(DevRevResponseModel):
|
|
106
|
+
"""Sync information for records synced into/from DevRev."""
|
|
107
|
+
|
|
108
|
+
external_reference: str | None = Field(default=None, description="External record URL")
|
|
109
|
+
origin_system: str | None = Field(
|
|
110
|
+
default=None, description="Where the record was first created"
|
|
111
|
+
)
|
|
112
|
+
last_sync_in: dict[str, Any] | None = Field(
|
|
113
|
+
default=None, description="Information about the sync to DevRev"
|
|
114
|
+
)
|
|
115
|
+
last_sync_out: dict[str, Any] | None = Field(
|
|
116
|
+
default=None, description="Information about the sync from DevRev"
|
|
117
|
+
)
|
|
118
|
+
|
|
119
|
+
|
|
97
120
|
class Article(DevRevResponseModel):
|
|
98
121
|
"""DevRev Article model.
|
|
99
122
|
|
|
@@ -106,13 +129,29 @@ class Article(DevRevResponseModel):
|
|
|
106
129
|
title: str = Field(..., description="Article title")
|
|
107
130
|
description: str | None = Field(default=None, description="Article description/body")
|
|
108
131
|
status: ArticleStatus | None = Field(default=None, description="Article status")
|
|
132
|
+
access_level: ArticleAccessLevel | None = Field(
|
|
133
|
+
default=None, description="Access level (external, internal, private, public, restricted)"
|
|
134
|
+
)
|
|
135
|
+
aliases: list[str] | None = Field(default=None, description="Aliases of the article")
|
|
109
136
|
article_type: str | None = Field(default=None, description="Article type (article, page, etc.)")
|
|
110
137
|
authored_by: list[UserSummary] | None = Field(
|
|
111
138
|
default=None, description="Authors of the article (API returns array, not single object)"
|
|
112
139
|
)
|
|
140
|
+
brand: dict[str, Any] | None = Field(
|
|
141
|
+
default=None, description="Brand associated with the article"
|
|
142
|
+
)
|
|
113
143
|
owned_by: list[UserSummary] | None = Field(default=None, description="Owners of the article")
|
|
114
144
|
created_date: datetime | None = Field(default=None, description="Creation date")
|
|
115
145
|
modified_date: datetime | None = Field(default=None, description="Last modified")
|
|
146
|
+
extracted_content: list[ArtifactSummary] | None = Field(
|
|
147
|
+
default=None, description="Extracted content artifacts"
|
|
148
|
+
)
|
|
149
|
+
num_downvotes: int | None = Field(
|
|
150
|
+
default=None, description="Number of downvotes on the article"
|
|
151
|
+
)
|
|
152
|
+
num_upvotes: int | None = Field(default=None, description="Number of upvotes on the article")
|
|
153
|
+
published_at: datetime | None = Field(default=None, description="Published date of the article")
|
|
154
|
+
rank: str | None = Field(default=None, description="Rank of the article")
|
|
116
155
|
resource: dict[str, Any] | None = Field(
|
|
117
156
|
default=None, description="Resource configuration including artifact references"
|
|
118
157
|
)
|
|
@@ -122,6 +161,9 @@ class Article(DevRevResponseModel):
|
|
|
122
161
|
scope: ArticleScope | None = Field(
|
|
123
162
|
default=None, description="Visibility scope (internal/external)"
|
|
124
163
|
)
|
|
164
|
+
sync_metadata: SyncMetadata | None = Field(
|
|
165
|
+
default=None, description="Sync information for records synced into/from DevRev"
|
|
166
|
+
)
|
|
125
167
|
tags: list[ArticleTagWithValue] | None = Field(
|
|
126
168
|
default=None, description="Tags applied to the article"
|
|
127
169
|
)
|
|
@@ -129,6 +171,7 @@ class Article(DevRevResponseModel):
|
|
|
129
171
|
default=None, description="Parent directory/collection"
|
|
130
172
|
)
|
|
131
173
|
language: str | None = Field(default=None, description="Language code (e.g., 'en')")
|
|
174
|
+
url: str | None = Field(default=None, description="URL of the external article")
|
|
132
175
|
|
|
133
176
|
|
|
134
177
|
class ArticleSummary(DevRevResponseModel):
|
|
@@ -168,6 +211,28 @@ class ArticlesCreateRequest(DevRevBaseModel):
|
|
|
168
211
|
title: str = Field(..., description="Article title")
|
|
169
212
|
description: str | None = Field(default=None, description="Article description/body")
|
|
170
213
|
status: ArticleStatus | None = Field(default=None, description="Article status")
|
|
214
|
+
access_level: ArticleAccessLevel | None = Field(
|
|
215
|
+
default=None, description="Access level (external, internal, private, public, restricted)"
|
|
216
|
+
)
|
|
217
|
+
aliases: list[str] | None = Field(default=None, description="Aliases of the article (max 5)")
|
|
218
|
+
authored_by: list[str] | None = Field(
|
|
219
|
+
default=None, description="List of user IDs who author the article"
|
|
220
|
+
)
|
|
221
|
+
brand: str | None = Field(default=None, description="Brand ID associated with the article")
|
|
222
|
+
content_format: ArticleContentFormat | None = Field(
|
|
223
|
+
default=None, description="Content format (drdfv2, rt)"
|
|
224
|
+
)
|
|
225
|
+
custom_fields: dict[str, Any] | None = Field(
|
|
226
|
+
default=None, description="Application-defined custom fields"
|
|
227
|
+
)
|
|
228
|
+
custom_schema_spec: CustomSchemaSpec | None = Field(
|
|
229
|
+
default=None, description="Custom schema spec"
|
|
230
|
+
)
|
|
231
|
+
extracted_content: list[str] | None = Field(
|
|
232
|
+
default=None, description="IDs of extracted content artifacts"
|
|
233
|
+
)
|
|
234
|
+
language: str | None = Field(default=None, description="Language of the article")
|
|
235
|
+
notify: bool | None = Field(default=None, description="Whether to notify users when published")
|
|
171
236
|
owned_by: list[str] = Field(..., description="List of dev user IDs who own the article")
|
|
172
237
|
resource: dict[str, Any] = Field(
|
|
173
238
|
default_factory=dict, description="Resource configuration for the article"
|
|
@@ -176,6 +241,9 @@ class ArticlesCreateRequest(DevRevBaseModel):
|
|
|
176
241
|
default=None, description="List of part IDs this article applies to"
|
|
177
242
|
)
|
|
178
243
|
scope: int | None = Field(default=None, description="Visibility scope: 1=internal, 2=external")
|
|
244
|
+
shared_with: list[SetSharedWithMembership] | None = Field(
|
|
245
|
+
default=None, description="Users/groups to share the article with"
|
|
246
|
+
)
|
|
179
247
|
tags: list[SetTagWithValue] | None = Field(
|
|
180
248
|
default=None, description="Tags to apply (list of {'id': 'tag_id', 'value': ...})"
|
|
181
249
|
)
|
|
@@ -183,6 +251,8 @@ class ArticlesCreateRequest(DevRevBaseModel):
|
|
|
183
251
|
article_type: str | None = Field(
|
|
184
252
|
default=None, description="Article type: 'article' (default), 'page', 'content_block'"
|
|
185
253
|
)
|
|
254
|
+
published_at: datetime | None = Field(default=None, description="Published date of the article")
|
|
255
|
+
release_notes: str | None = Field(default=None, description="Release notes for the article")
|
|
186
256
|
|
|
187
257
|
|
|
188
258
|
class ArticlesGetRequest(DevRevBaseModel):
|
|
@@ -53,11 +53,26 @@ class PartSummary(DevRevResponseModel):
|
|
|
53
53
|
|
|
54
54
|
|
|
55
55
|
class PartsCreateRequest(DevRevBaseModel):
|
|
56
|
-
"""Request to create a part.
|
|
56
|
+
"""Request to create a part.
|
|
57
|
+
|
|
58
|
+
For non-product parts (capability, feature, enhancement), the parent_part
|
|
59
|
+
parameter is required to specify the parent part in the hierarchy.
|
|
60
|
+
"""
|
|
57
61
|
|
|
58
62
|
name: str = Field(..., description="Part name")
|
|
59
63
|
type: PartType = Field(..., description="Part type")
|
|
60
64
|
description: str | None = Field(default=None, description="Description")
|
|
65
|
+
owned_by: list[str] | None = Field(
|
|
66
|
+
default=None,
|
|
67
|
+
description="List of owner user IDs (e.g., ['DEVU-4'] or full DON IDs)",
|
|
68
|
+
)
|
|
69
|
+
parent_part: list[str] | None = Field(
|
|
70
|
+
default=None,
|
|
71
|
+
description="Parent part ID (required for capability/feature/enhancement). "
|
|
72
|
+
"Array with at most 1 element.",
|
|
73
|
+
max_length=1,
|
|
74
|
+
)
|
|
75
|
+
tags: list[str] | None = Field(default=None, description="List of tag IDs")
|
|
61
76
|
|
|
62
77
|
|
|
63
78
|
class PartsGetRequest(DevRevBaseModel):
|
|
@@ -196,12 +196,15 @@ class ArticlesService(BaseService):
|
|
|
196
196
|
owned_by: builtins.list[str],
|
|
197
197
|
description: str | None = None,
|
|
198
198
|
status: ArticleStatus | None = None,
|
|
199
|
+
access_level: ArticleAccessLevel | None = None,
|
|
199
200
|
content_format: str = "text/plain",
|
|
200
201
|
applies_to_parts: builtins.list[str] | None = None,
|
|
201
202
|
scope: int | None = None,
|
|
202
203
|
tags: builtins.list[SetTagWithValue] | None = None,
|
|
203
204
|
parent: str | None = None,
|
|
204
205
|
article_type: str | None = None,
|
|
206
|
+
language: str | None = None,
|
|
207
|
+
authored_by: builtins.list[str] | None = None,
|
|
205
208
|
) -> Article:
|
|
206
209
|
"""Create an article with content in a single operation.
|
|
207
210
|
|
|
@@ -218,12 +221,15 @@ class ArticlesService(BaseService):
|
|
|
218
221
|
owned_by: List of dev user IDs who own the article
|
|
219
222
|
description: Optional short metadata description (NOT the article content)
|
|
220
223
|
status: Optional article status (draft, published, archived)
|
|
224
|
+
access_level: Optional access level (external, internal, private, public, restricted)
|
|
221
225
|
content_format: Content MIME type (default: text/plain)
|
|
222
226
|
applies_to_parts: Optional list of part IDs to associate with
|
|
223
227
|
scope: Optional visibility scope (1=internal, 2=external)
|
|
224
228
|
tags: Optional tags (list of SetTagWithValue)
|
|
225
229
|
parent: Optional parent directory/collection DON ID
|
|
226
230
|
article_type: Optional article type ('article', 'page', 'content_block')
|
|
231
|
+
language: Optional language code (e.g., 'en')
|
|
232
|
+
authored_by: Optional list of user IDs who author the article
|
|
227
233
|
|
|
228
234
|
Returns:
|
|
229
235
|
Created article
|
|
@@ -239,6 +245,7 @@ class ArticlesService(BaseService):
|
|
|
239
245
|
... content_format="text/html",
|
|
240
246
|
... applies_to_parts=["don:core:...:feature/30"],
|
|
241
247
|
... scope=2, # external
|
|
248
|
+
... access_level=ArticleAccessLevel.EXTERNAL,
|
|
242
249
|
... )
|
|
243
250
|
"""
|
|
244
251
|
if not self._parent_client:
|
|
@@ -275,6 +282,7 @@ class ArticlesService(BaseService):
|
|
|
275
282
|
title=title,
|
|
276
283
|
description=description,
|
|
277
284
|
status=status,
|
|
285
|
+
access_level=access_level,
|
|
278
286
|
owned_by=owned_by,
|
|
279
287
|
resource={"content_artifact": artifact_id},
|
|
280
288
|
applies_to_parts=applies_to_parts,
|
|
@@ -282,6 +290,8 @@ class ArticlesService(BaseService):
|
|
|
282
290
|
tags=tags,
|
|
283
291
|
parent=parent,
|
|
284
292
|
article_type=article_type,
|
|
293
|
+
language=language,
|
|
294
|
+
authored_by=authored_by,
|
|
285
295
|
)
|
|
286
296
|
return self.create(article_req)
|
|
287
297
|
|
|
@@ -443,6 +453,7 @@ class ArticlesService(BaseService):
|
|
|
443
453
|
applies_to_parts: builtins.list[str] | None = None,
|
|
444
454
|
access_level: ArticleAccessLevel | None = None,
|
|
445
455
|
tags: builtins.list[SetTagWithValue] | None = None,
|
|
456
|
+
language: str | None = None,
|
|
446
457
|
) -> Article:
|
|
447
458
|
"""Update article metadata and/or content.
|
|
448
459
|
|
|
@@ -460,6 +471,7 @@ class ArticlesService(BaseService):
|
|
|
460
471
|
applies_to_parts: Optional list of part IDs to associate with
|
|
461
472
|
access_level: Optional access level (internal, external, private, public)
|
|
462
473
|
tags: Optional list of tags to apply (list of SetTagWithValue objects)
|
|
474
|
+
language: Optional language code (e.g., 'en')
|
|
463
475
|
|
|
464
476
|
Returns:
|
|
465
477
|
Updated article
|
|
@@ -528,6 +540,7 @@ class ArticlesService(BaseService):
|
|
|
528
540
|
or applies_to_parts is not None
|
|
529
541
|
or access_level is not None
|
|
530
542
|
or tags is not None
|
|
543
|
+
or language is not None
|
|
531
544
|
)
|
|
532
545
|
if has_metadata:
|
|
533
546
|
update_req = ArticlesUpdateRequest(
|
|
@@ -538,6 +551,7 @@ class ArticlesService(BaseService):
|
|
|
538
551
|
applies_to_parts=applies_to_parts_req,
|
|
539
552
|
access_level=access_level,
|
|
540
553
|
tags=tags_req,
|
|
554
|
+
language=language,
|
|
541
555
|
)
|
|
542
556
|
return self.update(update_req)
|
|
543
557
|
|
|
@@ -642,12 +656,15 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
642
656
|
owned_by: builtins.list[str],
|
|
643
657
|
description: str | None = None,
|
|
644
658
|
status: ArticleStatus | None = None,
|
|
659
|
+
access_level: ArticleAccessLevel | None = None,
|
|
645
660
|
content_format: str = "text/plain",
|
|
646
661
|
applies_to_parts: builtins.list[str] | None = None,
|
|
647
662
|
scope: int | None = None,
|
|
648
663
|
tags: builtins.list[SetTagWithValue] | None = None,
|
|
649
664
|
parent: str | None = None,
|
|
650
665
|
article_type: str | None = None,
|
|
666
|
+
language: str | None = None,
|
|
667
|
+
authored_by: builtins.list[str] | None = None,
|
|
651
668
|
) -> Article:
|
|
652
669
|
"""Create an article with content in a single operation (async).
|
|
653
670
|
|
|
@@ -664,12 +681,15 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
664
681
|
owned_by: List of dev user IDs who own the article
|
|
665
682
|
description: Optional short metadata description (NOT the article content)
|
|
666
683
|
status: Optional article status (draft, published, archived)
|
|
684
|
+
access_level: Optional access level (external, internal, private, public, restricted)
|
|
667
685
|
content_format: Content MIME type (default: text/plain)
|
|
668
686
|
applies_to_parts: Optional list of part IDs to associate with
|
|
669
687
|
scope: Optional visibility scope (1=internal, 2=external)
|
|
670
688
|
tags: Optional tags (list of SetTagWithValue)
|
|
671
689
|
parent: Optional parent directory/collection DON ID
|
|
672
690
|
article_type: Optional article type ('article', 'page', 'content_block')
|
|
691
|
+
language: Optional language code (e.g., 'en')
|
|
692
|
+
authored_by: Optional list of user IDs who author the article
|
|
673
693
|
|
|
674
694
|
Returns:
|
|
675
695
|
Created article
|
|
@@ -710,6 +730,7 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
710
730
|
title=title,
|
|
711
731
|
description=description,
|
|
712
732
|
status=status,
|
|
733
|
+
access_level=access_level,
|
|
713
734
|
owned_by=owned_by,
|
|
714
735
|
resource={"content_artifact": artifact_id},
|
|
715
736
|
applies_to_parts=applies_to_parts,
|
|
@@ -717,6 +738,8 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
717
738
|
tags=tags,
|
|
718
739
|
parent=parent,
|
|
719
740
|
article_type=article_type,
|
|
741
|
+
language=language,
|
|
742
|
+
authored_by=authored_by,
|
|
720
743
|
)
|
|
721
744
|
return await self.create(article_req)
|
|
722
745
|
|
|
@@ -867,6 +890,7 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
867
890
|
applies_to_parts: builtins.list[str] | None = None,
|
|
868
891
|
access_level: ArticleAccessLevel | None = None,
|
|
869
892
|
tags: builtins.list[SetTagWithValue] | None = None,
|
|
893
|
+
language: str | None = None,
|
|
870
894
|
) -> Article:
|
|
871
895
|
"""Update article metadata and/or content (async).
|
|
872
896
|
|
|
@@ -884,6 +908,7 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
884
908
|
applies_to_parts: Optional list of part IDs to associate with
|
|
885
909
|
access_level: Optional access level (internal, external, private, public)
|
|
886
910
|
tags: Optional list of tags to apply (list of SetTagWithValue objects)
|
|
911
|
+
language: Optional language code (e.g., 'en')
|
|
887
912
|
|
|
888
913
|
Returns:
|
|
889
914
|
Updated article
|
|
@@ -919,6 +944,7 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
919
944
|
or applies_to_parts is not None
|
|
920
945
|
or access_level is not None
|
|
921
946
|
or tags is not None
|
|
947
|
+
or language is not None
|
|
922
948
|
)
|
|
923
949
|
if has_metadata:
|
|
924
950
|
update_req = ArticlesUpdateRequest(
|
|
@@ -929,6 +955,7 @@ class AsyncArticlesService(AsyncBaseService):
|
|
|
929
955
|
applies_to_parts=applies_to_parts_req,
|
|
930
956
|
access_level=access_level,
|
|
931
957
|
tags=tags_req,
|
|
958
|
+
language=language,
|
|
932
959
|
)
|
|
933
960
|
return await self.update(update_req)
|
|
934
961
|
|
|
@@ -104,10 +104,13 @@ if _config.enable_destructive_tools:
|
|
|
104
104
|
owned_by: list[str],
|
|
105
105
|
description: str | None = None,
|
|
106
106
|
status: str | None = None,
|
|
107
|
+
access_level: str | None = None,
|
|
107
108
|
content_format: str = "text/html",
|
|
108
109
|
applies_to_parts: list[str] | None = None,
|
|
109
110
|
scope: int | None = None,
|
|
110
111
|
tags: list[str] | None = None,
|
|
112
|
+
language: str | None = None,
|
|
113
|
+
authored_by: list[str] | None = None,
|
|
111
114
|
) -> dict[str, Any]:
|
|
112
115
|
"""Create a new article with content.
|
|
113
116
|
|
|
@@ -118,11 +121,14 @@ if _config.enable_destructive_tools:
|
|
|
118
121
|
owned_by: List of dev user IDs who own the article.
|
|
119
122
|
description: Optional short metadata description (NOT the article body).
|
|
120
123
|
status: Optional article status (draft, published, archived).
|
|
124
|
+
access_level: Optional access level (external, internal, private, public, restricted).
|
|
121
125
|
content_format: Content MIME type (default: text/html).
|
|
122
126
|
applies_to_parts: Optional list of part IDs (products, capabilities,
|
|
123
127
|
features, enhancements) to associate the article with.
|
|
124
128
|
scope: Optional visibility scope (1=internal, 2=external).
|
|
125
129
|
tags: Optional list of tag IDs to apply to the article.
|
|
130
|
+
language: Optional language code (e.g., 'en').
|
|
131
|
+
authored_by: Optional list of user IDs who author the article.
|
|
126
132
|
|
|
127
133
|
Returns:
|
|
128
134
|
Dictionary containing the created article details.
|
|
@@ -142,6 +148,17 @@ if _config.enable_destructive_tools:
|
|
|
142
148
|
f"Valid statuses: {', '.join(s.name for s in ArticleStatus)}"
|
|
143
149
|
) from e
|
|
144
150
|
|
|
151
|
+
# Convert access_level string to ArticleAccessLevel enum
|
|
152
|
+
article_access_level = None
|
|
153
|
+
if access_level:
|
|
154
|
+
try:
|
|
155
|
+
article_access_level = ArticleAccessLevel[access_level.upper()]
|
|
156
|
+
except KeyError as e:
|
|
157
|
+
raise RuntimeError(
|
|
158
|
+
f"Invalid access level: {e.args[0]}. "
|
|
159
|
+
f"Valid levels: {', '.join(a.name for a in ArticleAccessLevel)}"
|
|
160
|
+
) from e
|
|
161
|
+
|
|
145
162
|
# Convert tag IDs to SetTagWithValue objects
|
|
146
163
|
tags_list = (
|
|
147
164
|
[SetTagWithValue(id=tag_id) for tag_id in tags] if tags is not None else None
|
|
@@ -153,10 +170,13 @@ if _config.enable_destructive_tools:
|
|
|
153
170
|
owned_by=owned_by,
|
|
154
171
|
description=description,
|
|
155
172
|
status=article_status,
|
|
173
|
+
access_level=article_access_level,
|
|
156
174
|
content_format=content_format,
|
|
157
175
|
applies_to_parts=applies_to_parts,
|
|
158
176
|
scope=scope,
|
|
159
177
|
tags=tags_list,
|
|
178
|
+
language=language,
|
|
179
|
+
authored_by=authored_by,
|
|
160
180
|
)
|
|
161
181
|
return serialize_model(article)
|
|
162
182
|
except DevRevError as e:
|
|
@@ -173,6 +193,7 @@ if _config.enable_destructive_tools:
|
|
|
173
193
|
applies_to_parts: list[str] | None = None,
|
|
174
194
|
access_level: str | None = None,
|
|
175
195
|
tags: list[str] | None = None,
|
|
196
|
+
language: str | None = None,
|
|
176
197
|
) -> dict[str, Any]:
|
|
177
198
|
"""Update an existing article in DevRev.
|
|
178
199
|
|
|
@@ -186,11 +207,12 @@ if _config.enable_destructive_tools:
|
|
|
186
207
|
applies_to_parts: Optional list of part IDs (products, capabilities,
|
|
187
208
|
features, enhancements) to associate the article with.
|
|
188
209
|
Pass an empty list to remove all associations.
|
|
189
|
-
access_level: Optional access level (internal, external, private, public).
|
|
210
|
+
access_level: Optional access level (internal, external, private, public, restricted).
|
|
190
211
|
Note: For updates, use ``access_level`` (string enum). For creation,
|
|
191
212
|
use the ``scope`` parameter (integer: 1=internal, 2=external).
|
|
192
213
|
tags: Optional list of tag IDs to apply to the article.
|
|
193
214
|
Pass an empty list to remove all tags.
|
|
215
|
+
language: Optional language code (e.g., 'en').
|
|
194
216
|
|
|
195
217
|
Returns:
|
|
196
218
|
Dictionary containing the updated article details.
|
|
@@ -235,6 +257,7 @@ if _config.enable_destructive_tools:
|
|
|
235
257
|
applies_to_parts=applies_to_parts,
|
|
236
258
|
access_level=article_access_level,
|
|
237
259
|
tags=tags_list,
|
|
260
|
+
language=language,
|
|
238
261
|
)
|
|
239
262
|
return serialize_model(article)
|
|
240
263
|
except DevRevError as e:
|
|
@@ -87,6 +87,9 @@ if _config.enable_destructive_tools:
|
|
|
87
87
|
name: str,
|
|
88
88
|
type: str,
|
|
89
89
|
description: str | None = None,
|
|
90
|
+
owned_by: list[str] | None = None,
|
|
91
|
+
parent_part: list[str] | None = None,
|
|
92
|
+
tags: list[str] | None = None,
|
|
90
93
|
) -> dict[str, Any]:
|
|
91
94
|
"""Create a new DevRev part.
|
|
92
95
|
|
|
@@ -94,6 +97,10 @@ if _config.enable_destructive_tools:
|
|
|
94
97
|
name: The name of the part.
|
|
95
98
|
type: The type of part (PRODUCT, CAPABILITY, FEATURE, ENHANCEMENT).
|
|
96
99
|
description: Optional description of the part.
|
|
100
|
+
owned_by: List of owner user IDs (e.g., ["DEVU-4"] or full DON IDs).
|
|
101
|
+
parent_part: Parent part ID (required for capability/feature/enhancement).
|
|
102
|
+
Array with at most 1 element.
|
|
103
|
+
tags: List of tag IDs to associate with the part.
|
|
97
104
|
|
|
98
105
|
Returns:
|
|
99
106
|
Dictionary containing the created part details.
|
|
@@ -114,6 +121,9 @@ if _config.enable_destructive_tools:
|
|
|
114
121
|
name=name,
|
|
115
122
|
type=part_type,
|
|
116
123
|
description=description,
|
|
124
|
+
owned_by=owned_by,
|
|
125
|
+
parent_part=parent_part,
|
|
126
|
+
tags=tags,
|
|
117
127
|
)
|
|
118
128
|
part = await app.get_client().parts.create(request)
|
|
119
129
|
return serialize_model(part)
|
|
@@ -156,6 +156,85 @@ class TestPartsCreateTool:
|
|
|
156
156
|
call_args = mock_client.parts.create.call_args[0][0]
|
|
157
157
|
assert call_args.type == PartType.FEATURE
|
|
158
158
|
|
|
159
|
+
@pytest.mark.asyncio
|
|
160
|
+
async def test_create_with_owned_by(self, mock_ctx, mock_client):
|
|
161
|
+
"""Test creating a part with owned_by parameter."""
|
|
162
|
+
mock_part = _make_mock_part(id="PROD-100", name="Owned Product")
|
|
163
|
+
mock_client.parts.create.return_value = mock_part
|
|
164
|
+
|
|
165
|
+
result = await devrev_parts_create(
|
|
166
|
+
mock_ctx,
|
|
167
|
+
name="Owned Product",
|
|
168
|
+
type="product",
|
|
169
|
+
owned_by=["DEVU-4", "don:identity:dvrv-us-1:devo/1:devu/5"],
|
|
170
|
+
)
|
|
171
|
+
|
|
172
|
+
assert result["id"] == "PROD-100"
|
|
173
|
+
call_args = mock_client.parts.create.call_args[0][0]
|
|
174
|
+
assert call_args.owned_by == ["DEVU-4", "don:identity:dvrv-us-1:devo/1:devu/5"]
|
|
175
|
+
|
|
176
|
+
@pytest.mark.asyncio
|
|
177
|
+
async def test_create_with_parent_part(self, mock_ctx, mock_client):
|
|
178
|
+
"""Test creating a feature with parent_part parameter."""
|
|
179
|
+
mock_part = _make_mock_part(id="FEAT-200", name="Child Feature", type="feature")
|
|
180
|
+
mock_client.parts.create.return_value = mock_part
|
|
181
|
+
|
|
182
|
+
result = await devrev_parts_create(
|
|
183
|
+
mock_ctx,
|
|
184
|
+
name="Child Feature",
|
|
185
|
+
type="feature",
|
|
186
|
+
parent_part=["don:core:dvrv-us-1:devo/1:part/1"],
|
|
187
|
+
owned_by=["DEVU-4"],
|
|
188
|
+
)
|
|
189
|
+
|
|
190
|
+
assert result["id"] == "FEAT-200"
|
|
191
|
+
call_args = mock_client.parts.create.call_args[0][0]
|
|
192
|
+
assert call_args.parent_part == ["don:core:dvrv-us-1:devo/1:part/1"]
|
|
193
|
+
assert call_args.type == PartType.FEATURE
|
|
194
|
+
|
|
195
|
+
@pytest.mark.asyncio
|
|
196
|
+
async def test_create_with_tags(self, mock_ctx, mock_client):
|
|
197
|
+
"""Test creating a part with tags parameter."""
|
|
198
|
+
mock_part = _make_mock_part(id="CAP-300", name="Tagged Capability", type="capability")
|
|
199
|
+
mock_client.parts.create.return_value = mock_part
|
|
200
|
+
|
|
201
|
+
result = await devrev_parts_create(
|
|
202
|
+
mock_ctx,
|
|
203
|
+
name="Tagged Capability",
|
|
204
|
+
type="capability",
|
|
205
|
+
parent_part=["don:core:dvrv-us-1:devo/1:part/1"],
|
|
206
|
+
tags=["tag-1", "tag-2"],
|
|
207
|
+
)
|
|
208
|
+
|
|
209
|
+
assert result["id"] == "CAP-300"
|
|
210
|
+
call_args = mock_client.parts.create.call_args[0][0]
|
|
211
|
+
assert call_args.tags == ["tag-1", "tag-2"]
|
|
212
|
+
|
|
213
|
+
@pytest.mark.asyncio
|
|
214
|
+
async def test_create_with_all_optional_params(self, mock_ctx, mock_client):
|
|
215
|
+
"""Test creating a part with all optional parameters."""
|
|
216
|
+
mock_part = _make_mock_part(id="ENH-400", name="Full Enhancement", type="enhancement")
|
|
217
|
+
mock_client.parts.create.return_value = mock_part
|
|
218
|
+
|
|
219
|
+
result = await devrev_parts_create(
|
|
220
|
+
mock_ctx,
|
|
221
|
+
name="Full Enhancement",
|
|
222
|
+
type="enhancement",
|
|
223
|
+
description="A complete enhancement",
|
|
224
|
+
owned_by=["DEVU-1"],
|
|
225
|
+
parent_part=["FEAT-100"],
|
|
226
|
+
tags=["enhancement-tag"],
|
|
227
|
+
)
|
|
228
|
+
|
|
229
|
+
assert result["id"] == "ENH-400"
|
|
230
|
+
call_args = mock_client.parts.create.call_args[0][0]
|
|
231
|
+
assert call_args.name == "Full Enhancement"
|
|
232
|
+
assert call_args.type == PartType.ENHANCEMENT
|
|
233
|
+
assert call_args.description == "A complete enhancement"
|
|
234
|
+
assert call_args.owned_by == ["DEVU-1"]
|
|
235
|
+
assert call_args.parent_part == ["FEAT-100"]
|
|
236
|
+
assert call_args.tags == ["enhancement-tag"]
|
|
237
|
+
|
|
159
238
|
|
|
160
239
|
class TestPartsUpdateTool:
|
|
161
240
|
"""Tests for devrev_parts_update tool."""
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|