mirror of
https://github.com/farion1231/cc-switch.git
synced 2026-04-21 11:46:49 +08:00
Reorganize docs/user-manual/ from flat structure to language subdirectories (zh/, en/, ja/) with shared assets/. Move existing Chinese docs into zh/, fix image paths, add multilingual navigation README, and translate all 23 markdown files (~4500 lines each) to English and Japanese.
257 lines
6.6 KiB
Markdown
257 lines
6.6 KiB
Markdown
# 5.3 Deep Link Protocol
|
|
|
|
## Overview
|
|
|
|
CC Switch supports the `ccswitch://` deep link protocol, enabling one-click configuration import via links.
|
|
|
|
**Use cases**:
|
|
- Team configuration sharing
|
|
- One-click setup in tutorials
|
|
- Quick sync across devices
|
|
|
|
## Online Generator Tool
|
|
|
|
CC Switch provides an online deep link generator tool:
|
|
|
|
**URL**: [https://farion1231.github.io/cc-switch/deplink.html](https://farion1231.github.io/cc-switch/deplink.html)
|
|
|
|
### How to Use
|
|
|
|
1. Open the above URL
|
|
2. Select the import type (Provider/MCP/Prompt)
|
|
3. Fill in the configuration information
|
|
4. Click "Generate Link"
|
|
5. Copy the generated deep link
|
|
6. Share with others or use on other devices
|
|
|
|
## Protocol Format
|
|
|
|
### V1 Protocol
|
|
|
|
Uses URL parameter format, easy to read and generate:
|
|
|
|
```
|
|
ccswitch://v1/import?resource={type}&app={app}&name={name}&...
|
|
```
|
|
|
|
**Common parameters**:
|
|
|
|
| Parameter | Required | Description |
|
|
|-----------|----------|-------------|
|
|
| `resource` | Yes | Resource type: `provider` / `mcp` / `prompt` / `skill` |
|
|
| `app` | Yes | App type: `claude` / `codex` / `gemini` / `opencode` / `openclaw` |
|
|
| `name` | Yes | Name |
|
|
|
|
**Provider parameters** (resource=provider):
|
|
|
|
| Parameter | Required | Description |
|
|
|-----------|----------|-------------|
|
|
| `endpoint` | No | API endpoint URL (supports comma-separated multiple URLs) |
|
|
| `apiKey` | No | API key |
|
|
| `homepage` | No | Provider website |
|
|
| `model` | No | Default model |
|
|
| `haikuModel` | No | Haiku model (Claude only) |
|
|
| `sonnetModel` | No | Sonnet model (Claude only) |
|
|
| `opusModel` | No | Opus model (Claude only) |
|
|
| `notes` | No | Notes |
|
|
| `icon` | No | Icon |
|
|
| `config` | No | Base64-encoded configuration content |
|
|
| `configFormat` | No | Configuration format: `json` / `toml` |
|
|
| `configUrl` | No | Remote configuration URL |
|
|
| `enabled` | No | Whether to enable (boolean) |
|
|
| `usageScript` | No | Usage query script |
|
|
| `usageEnabled` | No | Whether to enable usage query (default true) |
|
|
| `usageApiKey` | No | Usage query API Key |
|
|
| `usageBaseUrl` | No | Usage query base URL |
|
|
| `usageAccessToken` | No | Usage query access token |
|
|
| `usageUserId` | No | Usage query user ID |
|
|
| `usageAutoInterval` | No | Auto query interval (minutes) |
|
|
|
|
**Prompt parameters** (resource=prompt):
|
|
|
|
| Parameter | Required | Description |
|
|
|-----------|----------|-------------|
|
|
| `content` | Yes | Prompt content |
|
|
| `description` | No | Description |
|
|
| `enabled` | No | Whether to enable (boolean) |
|
|
|
|
**MCP parameters** (resource=mcp):
|
|
|
|
| Parameter | Required | Description |
|
|
|-----------|----------|-------------|
|
|
| `apps` | Yes | App list (comma-separated, e.g., `claude,codex,gemini,opencode`) |
|
|
| `config` | Yes | MCP server configuration (JSON format) |
|
|
| `enabled` | No | Whether to enable (boolean) |
|
|
|
|
**Skill parameters** (resource=skill):
|
|
|
|
| Parameter | Required | Description |
|
|
|-----------|----------|-------------|
|
|
| `repo` | Yes | Repository (format: `owner/name`) |
|
|
| `directory` | No | Directory path |
|
|
| `branch` | No | Git branch |
|
|
|
|
**Example**:
|
|
```
|
|
ccswitch://v1/import?resource=provider&app=claude&name=My%20Provider&endpoint=https%3A%2F%2Fapi.example.com&apiKey=sk-xxx
|
|
```
|
|
|
|
## Import Type Examples
|
|
|
|
### Import Provider
|
|
|
|
```
|
|
ccswitch://v1/import?resource=provider&app=claude&name=My%20Provider&endpoint=https%3A%2F%2Fapi.example.com&apiKey=sk-xxx
|
|
```
|
|
|
|
### Import MCP Server
|
|
|
|
```
|
|
ccswitch://v1/import?resource=mcp&apps=claude,codex&config=%7B%22command%22%3A%22uvx%22%2C%22args%22%3A%5B%22mcp-server-fetch%22%5D%7D&name=mcp-fetch
|
|
```
|
|
|
|
### Import Prompt Preset
|
|
|
|
```
|
|
ccswitch://v1/import?resource=prompt&app=claude&name=%E4%BB%A3%E7%A0%81%E5%AE%A1%E6%9F%A5&content=%23%20%E8%A7%92%E8%89%B2%0A%E4%BD%A0%E6%98%AF%E4%B8%80%E4%B8%AA%E4%B8%93%E4%B8%9A%E7%9A%84%E4%BB%A3%E7%A0%81%E5%AE%A1%E6%9F%A5%E4%B8%93%E5%AE%B6
|
|
```
|
|
|
|
### Import Skill
|
|
|
|
```
|
|
ccswitch://v1/import?resource=skill&name=my-skill&repo=owner/repo&directory=skills/my-skill&branch=main
|
|
```
|
|
|
|
## Generate Deep Links
|
|
|
|
### Manual Generation
|
|
|
|
1. Prepare parameters
|
|
2. Assemble the URL following V1 protocol format
|
|
3. URL-encode special characters
|
|
|
|
**Example**:
|
|
|
|
```javascript
|
|
const params = new URLSearchParams({
|
|
resource: 'provider',
|
|
app: 'claude',
|
|
name: 'My Provider',
|
|
endpoint: 'https://api.example.com',
|
|
apiKey: 'sk-xxx'
|
|
});
|
|
|
|
const url = `ccswitch://v1/import?${params.toString()}`;
|
|
```
|
|
|
|
### Online Tool
|
|
|
|
Using CC Switch's official online deep link generator tool is more convenient.
|
|
|
|
## Using Deep Links
|
|
|
|
### Click the Link
|
|
|
|
Click a deep link in a browser or other application:
|
|
|
|
1. The system asks whether to open CC Switch
|
|
2. After confirming, CC Switch opens
|
|
3. An import confirmation dialog is displayed
|
|
4. Confirm the import
|
|
|
|
### Import Confirmation
|
|
|
|
A confirmation dialog is shown before import, containing:
|
|
|
|
- Import type
|
|
- Configuration preview
|
|
- Confirm/Cancel buttons
|
|
|
|
**Security tip**: Only import configurations from trusted sources.
|
|
|
|
## Protocol Registration
|
|
|
|
### Automatic Registration
|
|
|
|
CC Switch automatically registers the `ccswitch://` protocol during installation.
|
|
|
|
### Manual Registration
|
|
|
|
If the protocol is not registered correctly:
|
|
|
|
**macOS**:
|
|
Reinstall the app, or run:
|
|
```bash
|
|
/usr/bin/open -a "CC Switch" --args --register-protocol
|
|
```
|
|
|
|
**Windows**:
|
|
Reinstall the app, or check the registry:
|
|
```
|
|
HKEY_CLASSES_ROOT\ccswitch
|
|
```
|
|
|
|
**Linux**:
|
|
Check the `MimeType` configuration in the `.desktop` file.
|
|
|
|
## Security Considerations
|
|
|
|
### Sensitive Information
|
|
|
|
Deep links may contain sensitive information (e.g., API Keys):
|
|
|
|
- Do not share links containing API Keys in public
|
|
- Remove or replace sensitive information before sharing
|
|
- Use secure channels to transmit links
|
|
|
|
### Source Verification
|
|
|
|
Before import, CC Switch will:
|
|
|
|
1. Validate the data format
|
|
2. Display a configuration preview
|
|
3. Require user confirmation
|
|
|
|
### Malicious Link Protection
|
|
|
|
CC Switch checks:
|
|
|
|
- Whether the data format is valid
|
|
- Whether required fields are complete
|
|
- Whether configuration values are within reasonable ranges
|
|
|
|
## Example Links
|
|
|
|
### Example: Import Claude Provider
|
|
|
|
```
|
|
ccswitch://v1/import?resource=provider&app=claude&name=Test%20Provider&apiKey=sk-xxx&endpoint=https%3A%2F%2Fapi.example.com
|
|
```
|
|
|
|
### Example: Import MCP Server
|
|
|
|
```
|
|
ccswitch://v1/import?resource=mcp&name=mcp-fetch&apps=claude,codex,gemini&config=%7B%22command%22%3A%22uvx%22%2C%22args%22%3A%5B%22mcp-server-fetch%22%5D%7D
|
|
```
|
|
|
|
## Troubleshooting
|
|
|
|
### Link Won't Open
|
|
|
|
**Check**:
|
|
1. Is CC Switch installed
|
|
2. Is the protocol registered correctly
|
|
3. Is the link format correct
|
|
|
|
### Import Failed
|
|
|
|
**Possible causes**:
|
|
- Base64 encoding error
|
|
- JSON format error
|
|
- Missing required fields
|
|
|
|
**Solutions**:
|
|
1. Check the original JSON format
|
|
2. Re-encode in Base64
|
|
3. Ensure all required fields are present
|