Files
gh-k-dense-ai-claude-scient…/skills/protocolsio-integration/references/discussions.md
2025-11-30 08:30:10 +08:00

226 lines
6.8 KiB
Markdown

# Discussions API
## Overview
The Discussions API enables collaborative commenting on protocols. Comments can be added at both the protocol level and the individual step level, with support for threaded replies, editing, and deletion.
## Base URL
All discussion endpoints use the base URL: `https://protocols.io/api/v3`
## Protocol-Level Comments
### List Protocol Comments
Retrieve all comments for a protocol.
**Endpoint:** `GET /protocols/{protocol_id}/comments`
**Path Parameters:**
- `protocol_id`: The protocol's unique identifier
**Query Parameters:**
- `page_size`: Number of results per page (default: 10, max: 50)
- `page_id`: Page number for pagination (starts at 0)
**Response includes:**
- Comment ID and content
- Author information (name, affiliation, avatar)
- Timestamp (created and modified)
- Reply count and thread structure
### Create Protocol Comment
Add a new comment to a protocol.
**Endpoint:** `POST /protocols/{protocol_id}/comments`
**Request Body:**
- `body` (required): Comment text (supports HTML or Markdown)
- `parent_comment_id` (optional): ID of parent comment for threaded replies
**Example Request:**
```bash
curl -X POST \
-H "Authorization: Bearer YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"body": "This protocol worked excellently for our CRISPR experiments. We achieved 85% editing efficiency."
}' \
"https://protocols.io/api/v3/protocols/12345/comments"
```
### Create Threaded Reply
To reply to an existing comment, include the parent comment ID:
```bash
curl -X POST \
-H "Authorization: Bearer YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"body": "What cell type did you use?",
"parent_comment_id": 67890
}' \
"https://protocols.io/api/v3/protocols/12345/comments"
```
### Update Comment
Edit your own comment.
**Endpoint:** `PATCH /protocols/{protocol_id}/comments/{comment_id}`
**Request Body:**
- `body` (required): Updated comment text
**Authorization**: Only the comment author can edit their comments
### Delete Comment
Remove a comment.
**Endpoint:** `DELETE /protocols/{protocol_id}/comments/{comment_id}`
**Authorization**: Only the comment author can delete their comments
**Note**: Deleting a parent comment may affect the entire thread, depending on API implementation
## Step-Level Comments
### List Step Comments
Retrieve all comments for a specific protocol step.
**Endpoint:** `GET /protocols/{protocol_id}/steps/{step_id}/comments`
**Path Parameters:**
- `protocol_id`: The protocol's unique identifier
- `step_id`: The step's unique identifier
**Query Parameters:**
- `page_size`: Number of results per page
- `page_id`: Page number for pagination
### Create Step Comment
Add a comment to a specific step.
**Endpoint:** `POST /protocols/{protocol_id}/steps/{step_id}/comments`
**Request Body:**
- `body` (required): Comment text
- `parent_comment_id` (optional): ID of parent comment for replies
**Example Request:**
```bash
curl -X POST \
-H "Authorization: Bearer YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"body": "At this step, we found that increasing the incubation time to 2 hours improved results significantly."
}' \
"https://protocols.io/api/v3/protocols/12345/steps/67890/comments"
```
### Update Step Comment
**Endpoint:** `PATCH /protocols/{protocol_id}/steps/{step_id}/comments/{comment_id}`
**Request Body:**
- `body` (required): Updated comment text
### Delete Step Comment
**Endpoint:** `DELETE /protocols/{protocol_id}/steps/{step_id}/comments/{comment_id}`
## Common Use Cases
### 1. Discussion Thread Analysis
To analyze discussions around a protocol:
1. Retrieve protocol comments: `GET /protocols/{id}/comments`
2. For each step, retrieve step-specific comments
3. Build a discussion thread tree using `parent_comment_id`
4. Analyze feedback patterns and common issues
### 2. Collaborative Protocol Improvement
To gather feedback on a protocol:
1. Publish the protocol
2. Monitor new comments: `GET /protocols/{id}/comments`
3. Respond to questions with threaded replies
4. Update protocol based on feedback
5. Publish updated version with notes acknowledging contributors
### 3. Community Engagement
To engage with protocol users:
1. Set up monitoring for new comments on your protocols
2. Respond promptly to questions and issues
3. Use step-level comments to provide detailed clarifications
4. Create threaded discussions for complex topics
### 4. Protocol Troubleshooting
To document troubleshooting experiences:
1. Identify problematic steps in a protocol
2. Add step-level comments with specific issues encountered
3. Document solutions or workarounds
4. Create a discussion thread with other users experiencing similar issues
## Comment Formatting
Comments support rich text formatting:
- **HTML**: Use standard HTML tags for formatting
- **Markdown**: Use Markdown syntax for simpler formatting
- **Links**: Include URLs to related resources or publications
- **Mentions**: Reference other users (format may vary)
**Example with Markdown:**
```json
{
"body": "## Important Note\n\nWe achieved better results with:\n\n- Increasing temperature to 37°C\n- Extending incubation to 2 hours\n- Using freshly prepared reagents\n\nSee our publication: [doi:10.xxxx/xxxxx](https://doi.org/...)"
}
```
## Best Practices
1. **Be specific**: When commenting on steps, reference specific parameters or conditions
2. **Provide context**: Include relevant experimental details (cell type, reagent batch, equipment)
3. **Use step-level comments**: Direct feedback to specific steps rather than protocol-level when appropriate
4. **Engage constructively**: Respond to questions and feedback promptly
5. **Update protocols**: Incorporate validated feedback into protocol updates
6. **Thread related discussions**: Use reply functionality to keep related comments together
7. **Document variations**: Share protocol modifications that worked in your hands
## Permissions and Privacy
- **Public protocols**: Anyone can comment on published public protocols
- **Private protocols**: Only collaborators with access can comment
- **Comment ownership**: Only comment authors can edit or delete their comments
- **Moderation**: Protocol authors may have additional moderation capabilities
## Error Handling
Common error responses:
- `400 Bad Request`: Invalid comment format or missing required fields
- `401 Unauthorized`: Missing or invalid access token
- `403 Forbidden`: Insufficient permissions (e.g., trying to edit another user's comment)
- `404 Not Found`: Protocol, step, or comment not found
- `429 Too Many Requests`: Rate limit exceeded
## Notifications
Comments may trigger notifications:
- Protocol authors receive notifications for new comments
- Comment authors receive notifications for replies
- Users can manage notification preferences in their account settings