tools/integrations/wistia.md
Video hosting, management, and analytics platform built for marketers with detailed engagement tracking.
| Integration | Available | Notes |
|---|---|---|
| API | ✓ | Data API (v1/modern), Stats API, Upload API |
| MCP | - | Not available |
| CLI | ✓ | wistia.js |
| SDK | ✓ | Ruby (official), community wrappers for other languages |
Authorization: Bearer {api_token}GET https://api.wistia.com/v1/projects.json?page=1&per_page=25
POST https://api.wistia.com/v1/projects.json
{
"name": "Marketing Videos Q1"
}
GET https://api.wistia.com/v1/medias.json?page=1&per_page=25
GET https://api.wistia.com/v1/medias/{media_hashed_id}.json
GET https://api.wistia.com/v1/medias/{media_hashed_id}/stats.json
GET https://api.wistia.com/v1/stats/account.json
GET https://api.wistia.com/v1/stats/medias/{media_id}/engagement.json
GET https://api.wistia.com/v1/stats/medias/{media_id}/by_date.json?start_date=2026-01-01&end_date=2026-01-31
GET https://api.wistia.com/v1/stats/visitors.json?page=1&per_page=25
GET https://api.wistia.com/v1/stats/events.json?media_id={media_id}
PUT https://api.wistia.com/v1/medias/{media_hashed_id}.json
{
"name": "Updated Video Title",
"description": "New description"
}
GET https://api.wistia.com/v1/medias/{media_hashed_id}/captions.json
Wistia has two API versions:
/v1/) - Legacy, perpetually supported, no breaking changes/modern/) - Current version, date-based versioning via X-Wistia-Api-Version headerThe CLI uses v1 for maximum stability.
plays - Total video playsvisitors - Unique visitorspageLoads - Page load countaveragePercentWatched - Average watch percentagepercentOfVisitorsClickingPlay - Play click ratetotal_medias - Total video counttotal_plays - Account-wide playstotal_hours_watched - Total hours of video watchedpage - Page number (default: 1)per_page - Results per page (default: 25, max: 100)project_id - Filter by projectname - Filter by nametype - Filter by type (Video, Audio, Image, etc.)start_date - Start date (YYYY-MM-DD)end_date - End date (YYYY-MM-DD)Retry-After header