Metadata-Version: 2.1
Name: codemie-mcp-datasources
Version: 0.1.374
Summary: MCP server for connecting to CodeMie Datasources
Author: Nikita Levyankov
Author-email: nikita_levyankov@epam.com
Requires-Python: >=3.12,<4.0
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Requires-Dist: certifi (>=2025.1.31,<2026.0.0)
Requires-Dist: codemie-sdk-python (==0.1.374)
Requires-Dist: httpx (>=0.27.0,<0.28.0)
Requires-Dist: mcp (>=1.6.0,<2.0.0)
Description-Content-Type: text/markdown

# CodeMie Datasources MCP Server

Python server implementing Model Context Protocol (MCP) for CodeMie Datasources operations.

## Features
- List and filter datasources
- Get datasource details
- Create code datasources
- Update datasources
- Delete datasources
- Monitor datasource processing status

Note: The server requires authentication credentials via environment variables.

## API

### Tools

#### list_datasources
Get list of available datasources with filtering and pagination
Inputs:
- `page (integer, optional)`: Page number (default: 0)
- `per_page (integer, optional)`: Items per page (default: 10)
- `sort_key (string, optional)`: Sort by 'date' or 'update_date' (default: 'update_date')
- `sort_order (string, optional)`: Sort order 'asc' or 'desc' (default: 'desc')
- `datasource_types (array, optional)`: Filter by datasource types
- `projects (array, optional)`: Filter by project names
- `owner (string, optional)`: Filter by owner
- `status (string, optional)`: Filter by status

Returns list of datasources with their details

#### get_datasource
Get detailed information about a specific datasource
Inputs:
- `datasource_id (string)`: ID of the datasource to retrieve

Returns complete datasource details including configuration

#### create_code_datasource
Create a new code datasource
Inputs:
- `name (string)`: Datasource name (lowercase letters and underscores only)
- `description (string)`: Datasource description
- `project_name (string)`: Project name
- `repository_link (string)`: Git repository URL
- `branch (string)`: Git branch name
- `index_type (string, optional)`: Type of indexing - 'code', 'summary', or 'chunk-summary' (default: 'code')
- `files_filter (string, optional)`: File patterns to include/exclude
- `embeddings_model (string, optional)`: Model for embeddings generation
- `shared_with_project (boolean, optional)`: Whether datasource is shared with project (default: false)

Returns created datasource details

#### update_code_datasource
Update an existing code datasource
Inputs:
- `datasource_id (string)`: ID of the datasource to update
- `name (string, optional)`: New name
- `description (string, optional)`: New description
- `branch (string, optional)`: New branch
- `files_filter (string, optional)`: New files filter
- `full_reindex (boolean, optional)`: Whether to perform full reindex
- `skip_reindex (boolean, optional)`: Whether to skip reindex
- `resume_indexing (boolean, optional)`: Whether to resume indexing

Returns updated datasource details

#### delete_datasource
Delete a datasource
Inputs:
- `datasource_id (string)`: ID of the datasource to delete

Returns deletion confirmation

#### get_datasource_processing_info
Get datasource processing status and progress
Inputs:
- `datasource_id (string)`: ID of the datasource to get info for

Returns processing information including status, progress, and file counts

## Installation

Ensure you have `Python 3.12` or later installed.

**Important:** Before running the MCP server, you must configure the required environment variables (see [Environment Variables](#environment-variables) section below).

### Using uv (recommended)

When using [`uv`](https://docs.astral.sh/uv/) no specific installation is needed. We will
use [`uvx`](https://docs.astral.sh/uv/guides/tools/) to directly run *codemie-mcp-datasources*.

```bash
uvx codemie-mcp-datasources
```

### Using Poetry

Alternatively you can install via Poetry:

```bash
poetry install codemie-mcp-datasources
```

After installation, you can run it as a script using:

```bash
poetry run codemie-mcp-datasources
```

## Configuration

### Configure for Claude.app

Add to your Claude settings:

<details>
<summary>Using uvx</summary>

**Required variables:**
```json
"mcpServers": {
  "codemie-datasources": {
    "command": "uvx",
    "args": ["codemie-mcp-datasources"],
    "env": {
      "CODEMIE_USERNAME": "your-username",
      "CODEMIE_PASSWORD": "your-password"
    }
  }
}
```

**Optional variables (with defaults):**
```json
"env": {
  "CODEMIE_API_DOMAIN": "https://codemie.lab.epam.com/code-assistant-api",
  "CODEMIE_AUTH_CLIENT_ID": "codemie-sdk",
  "CODEMIE_AUTH_SERVER_URL": "https://keycloak.eks-core.aws.main.edp.projects.epam.com/auth",
  "CODEMIE_AUTH_REALM_NAME": "codemie-prod"
}
```
</details>

<details>
<summary>Using poetry installation</summary>

**Required variables:**
```json
"mcpServers": {
  "codemie-datasources": {
    "command": "poetry",
    "args": ["run", "codemie-mcp-datasources"],
    "env": {
      "CODEMIE_USERNAME": "your-username",
      "CODEMIE_PASSWORD": "your-password"
    }
  }
}
```

**Optional variables (with defaults):**
```json
"env": {
  "CODEMIE_API_DOMAIN": "https://codemie.lab.epam.com/code-assistant-api",
  "CODEMIE_AUTH_CLIENT_ID": "codemie-sdk",
  "CODEMIE_AUTH_SERVER_URL": "https://keycloak.eks-core.aws.main.edp.projects.epam.com/auth",
  "CODEMIE_AUTH_REALM_NAME": "codemie-prod"
}
```
</details>

### Environment Variables

#### Mandatory Variables

The following environment variables **must** be configured before running the MCP server:

**Authentication (choose one method):**

*Option 1: Username/Password*
- `CODEMIE_USERNAME`: Your CodeMie username
- `CODEMIE_PASSWORD`: Your CodeMie password

*Option 2: Client Credentials*
- `CODEMIE_AUTH_CLIENT_SECRET`: Auth client secret

#### Optional Variables (Environment-Specific)

By default, the server connects to the **production environment** with these settings:
- `CODEMIE_API_DOMAIN`: `https://codemie.lab.epam.com/code-assistant-api`
- `CODEMIE_AUTH_CLIENT_ID`: `codemie-sdk`
- `CODEMIE_AUTH_SERVER_URL`: `https://keycloak.eks-core.aws.main.edp.projects.epam.com/auth`
- `CODEMIE_AUTH_REALM_NAME`: `codemie-prod`

You can override these variables to point to a different environment.

**Example: Preview Environment Configuration**
```bash
CODEMIE_API_DOMAIN="https://codemie-preview.lab.epam.com/code-assistant-api"
CODEMIE_AUTH_CLIENT_ID="codemie-preview-sdk"
CODEMIE_AUTH_SERVER_URL="https://keycloak.eks-core.aws.main.edp.projects.epam.com/auth"
CODEMIE_AUTH_REALM_NAME="codemie-prod"
```

**Other Optional Variables:**
- `CODEMIE_VERIFY_SSL`: SSL verification flag (default: `true`)

## Build

### Make build:
```bash
make build
```

