google-meetGoogle Meet API integration with managed OAuth. Create meeting spaces, list conference records, and manage meeting participants. Use this skill when users want to interact with Google Meet. For other third party apps, use the api-gateway skill (https://clawhub.ai/byungkyu/api-gateway).
Install via ClawdBot CLI:
clawdbot install byungkyu/google-meetAccess the Google Meet API with managed OAuth authentication. Create and manage meeting spaces, list conference records, and retrieve participant information.
# Create a meeting space
python <<'EOF'
import urllib.request, os, json
data = json.dumps({}).encode()
req = urllib.request.Request('https://gateway.maton.ai/google-meet/v2/spaces', data=data, method='POST')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
req.add_header('Content-Type', 'application/json')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
https://gateway.maton.ai/google-meet/{native-api-path}
Replace {native-api-path} with the actual Google Meet API endpoint path. The gateway proxies requests to meet.googleapis.com and automatically injects your OAuth token.
All requests require the Maton API key in the Authorization header:
Authorization: Bearer $MATON_API_KEY
Environment Variable: Set your API key as MATON_API_KEY:
export MATON_API_KEY="YOUR_API_KEY"
Manage your Google OAuth connections at https://ctrl.maton.ai.
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://ctrl.maton.ai/connections?app=google-meet&status=ACTIVE')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
python <<'EOF'
import urllib.request, os, json
data = json.dumps({'app': 'google-meet'}).encode()
req = urllib.request.Request('https://ctrl.maton.ai/connections', data=data, method='POST')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
req.add_header('Content-Type', 'application/json')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://ctrl.maton.ai/connections/{connection_id}')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
Response:
{
"connection": {
"connection_id": "21fd90f9-5935-43cd-b6c8-bde9d915ca80",
"status": "ACTIVE",
"creation_time": "2025-12-08T07:20:53.488460Z",
"last_updated_time": "2026-01-31T20:03:32.593153Z",
"url": "https://connect.maton.ai/?session_token=...",
"app": "google-meet",
"metadata": {}
}
}
Open the returned url in a browser to complete OAuth authorization.
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://ctrl.maton.ai/connections/{connection_id}', method='DELETE')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
If you have multiple Google Meet connections, specify which one to use with the Maton-Connection header:
python <<'EOF'
import urllib.request, os, json
data = json.dumps({}).encode()
req = urllib.request.Request('https://gateway.maton.ai/google-meet/v2/spaces', data=data, method='POST')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
req.add_header('Content-Type', 'application/json')
req.add_header('Maton-Connection', '21fd90f9-5935-43cd-b6c8-bde9d915ca80')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
If omitted, the gateway uses the default (oldest) active connection.
POST /google-meet/v2/spaces
Content-Type: application/json
{}
Response:
{
"name": "spaces/abc123",
"meetingUri": "https://meet.google.com/abc-defg-hij",
"meetingCode": "abc-defg-hij",
"config": {
"accessType": "OPEN",
"entryPointAccess": "ALL"
}
}
GET /google-meet/v2/spaces/{spaceId}
PATCH /google-meet/v2/spaces/{spaceId}
Content-Type: application/json
{
"config": {
"accessType": "TRUSTED"
}
}
POST /google-meet/v2/spaces/{spaceId}:endActiveConference
GET /google-meet/v2/conferenceRecords
With filter:
GET /google-meet/v2/conferenceRecords?filter=space.name="spaces/abc123"
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/participants
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/participants/{participantId}
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/participants/{participantId}/participantSessions
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/recordings
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/recordings/{recordingId}
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/transcripts
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/transcripts/{transcriptId}
GET /google-meet/v2/conferenceRecords/{conferenceRecordId}/transcripts/{transcriptId}/entries
// Create a meeting space
const response = await fetch(
'https://gateway.maton.ai/google-meet/v2/spaces',
{
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${process.env.MATON_API_KEY}`
},
body: JSON.stringify({})
}
);
const space = await response.json();
console.log(`Meeting URL: ${space.meetingUri}`);
import os
import requests
headers = {
'Content-Type': 'application/json',
'Authorization': f'Bearer {os.environ["MATON_API_KEY"]}'
}
# Create a meeting space
response = requests.post(
'https://gateway.maton.ai/google-meet/v2/spaces',
headers=headers,
json={}
)
space = response.json()
print(f"Meeting URL: {space['meetingUri']}")
OPEN (anyone with link), TRUSTED (organization members only), RESTRICTED (invited only)curl -g when URLs contain brackets to disable glob parsingjq or other commands, environment variables like $MATON_API_KEY may not expand correctly in some shell environments. You may get "Invalid API key" errors when piping.| Status | Meaning |
|--------|---------|
| 400 | Missing Google Meet connection |
| 401 | Invalid or missing Maton API key |
| 429 | Rate limited (10 req/sec per account) |
| 4xx/5xx | Passthrough error from Google Meet API |
When you receive a "Invalid API key" error, ALWAYS follow these steps before concluding there is an issue:
MATON_API_KEY environment variable is set:echo $MATON_API_KEY
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://ctrl.maton.ai/connections')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
google-meet. For example:https://gateway.maton.ai/google-meet/v2/spaceshttps://gateway.maton.ai/meet/v2/spacesGenerated Mar 1, 2026
Educational institutions can automate Google Meet creation for scheduled classes, track student attendance through participant records, and manage recordings for absent students. Teachers can focus on teaching while the system handles meeting logistics and post-session analytics.
Companies can programmatically create meeting spaces for daily stand-ups, project reviews, and client calls while maintaining security through access controls. The system can automatically end meetings after scheduled durations and archive conference records for compliance purposes.
Healthcare providers can integrate Google Meet into patient portals to create secure consultation rooms, track session durations for billing, and maintain encrypted records of telemedicine appointments. The system ensures HIPAA-compliant meeting management with proper access restrictions.
Event organizers can automate the creation of multiple concurrent meeting spaces for workshops, breakout sessions, and networking rooms during virtual conferences. The system can track participant engagement across sessions and generate attendance reports for sponsors.
Support teams can create on-demand meeting spaces for screen-sharing sessions with customers, record troubleshooting sessions for training purposes, and analyze call patterns to optimize support workflows. The system integrates with ticketing platforms to automatically generate meeting links for high-priority cases.
Offer this Google Meet integration as part of a larger productivity suite, charging monthly subscription fees based on API call volume and number of active connections. Provide premium features like advanced analytics, custom meeting templates, and priority support tiers.
Target large organizations with custom implementations that integrate Google Meet with their existing HR, CRM, and project management systems. Charge implementation fees plus annual maintenance contracts for ongoing support, customization, and compliance monitoring.
Offer this skill through a developer marketplace where third-party applications can access Google Meet functionality through simple API calls. Monetize through pay-per-use pricing, with tiered rates based on request volume and additional features like webhook notifications.
💬 Integration Tip
Start by testing connection management endpoints before implementing meeting creation, and use the Maton-Connection header when managing multiple Google accounts to ensure proper session isolation.
Use the mcporter CLI to list, configure, auth, and call MCP servers/tools directly (HTTP or stdio), including ad-hoc servers, config edits, and CLI/type generation.
Connect to 100+ APIs (Google Workspace, Microsoft 365, GitHub, Notion, Slack, Airtable, HubSpot, etc.) with managed OAuth. Use this skill when users want to...
Build, debug, and deploy websites using HTML, CSS, JavaScript, and modern frameworks following production best practices.
YouTube Data API integration with managed OAuth. Search videos, manage playlists, access channel data, and interact with comments. Use this skill when users want to interact with YouTube. For other third party apps, use the api-gateway skill (https://clawhub.ai/byungkyu/api-gateway).
Scaffold, test, document, and debug REST and GraphQL APIs. Use when the user needs to create API endpoints, write integration tests, generate OpenAPI specs, test with curl, mock APIs, or troubleshoot HTTP issues.
Search for jobs across LinkedIn, Indeed, Glassdoor, ZipRecruiter, Google Jobs, Bayt, Naukri, and BDJobs using the JobSpy MCP server.