Typeform
Verified@byungkyu
npx machina-cli add skill @byungkyu/typeform --openclawTypeform
Access the Typeform API with managed OAuth authentication. Create and manage forms, retrieve responses, and access insights.
Quick Start
# List forms
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://gateway.maton.ai/typeform/forms?page_size=10')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
print(json.dumps(json.load(urllib.request.urlopen(req)), indent=2))
EOF
Base URL
https://gateway.maton.ai/typeform/{native-api-path}
Replace {native-api-path} with the actual Typeform API endpoint path. The gateway proxies requests to api.typeform.com and automatically injects your OAuth token.
Authentication
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"
Getting Your API Key
- Sign in or create an account at maton.ai
- Go to maton.ai/settings
- Copy your API key
Connection Management
Manage your Typeform OAuth connections at https://ctrl.maton.ai.
List Connections
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://ctrl.maton.ai/connections?app=typeform&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
Create Connection
python <<'EOF'
import urllib.request, os, json
data = json.dumps({'app': 'typeform'}).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
Get Connection
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": "typeform",
"metadata": {}
}
}
Open the returned url in a browser to complete OAuth authorization.
Delete Connection
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
Specifying Connection
If you have multiple Typeform connections, specify which one to use with the Maton-Connection header:
python <<'EOF'
import urllib.request, os, json
req = urllib.request.Request('https://gateway.maton.ai/typeform/forms?page_size=10')
req.add_header('Authorization', f'Bearer {os.environ["MATON_API_KEY"]}')
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.
API Reference
User
GET /typeform/me
Forms
List Forms
GET /typeform/forms?page_size=10
Get Form
GET /typeform/forms/{formId}
Create Form
POST /typeform/forms
Content-Type: application/json
{
"title": "Customer Survey",
"fields": [
{"type": "short_text", "title": "What is your name?"},
{"type": "email", "title": "What is your email?"}
]
}
Update Form
PUT /typeform/forms/{formId}
Content-Type: application/json
{
"title": "Updated Survey Title",
"fields": [...]
}
Delete Form
DELETE /typeform/forms/{formId}
Responses
List Responses
GET /typeform/forms/{formId}/responses?page_size=25
With filters:
GET /typeform/forms/{formId}/responses?since=2024-01-01T00:00:00Z&until=2024-12-31T23:59:59Z&completed=true
Insights
GET /typeform/insights/{formId}/summary
Workspaces
GET /typeform/workspaces
GET /typeform/workspaces/{workspaceId}
Field Types
short_text- Single line textlong_text- Multi-line textemail- Email addressnumber- Numeric inputrating- Star ratingopinion_scale- 0-10 scalemultiple_choice- Single or multiple selectionyes_no- Booleandate- Date pickerdropdown- Dropdown selection
Code Examples
JavaScript
const response = await fetch(
'https://gateway.maton.ai/typeform/forms?page_size=10',
{
headers: {
'Authorization': `Bearer ${process.env.MATON_API_KEY}`
}
}
);
Python
import os
import requests
response = requests.get(
'https://gateway.maton.ai/typeform/forms',
headers={'Authorization': f'Bearer {os.environ["MATON_API_KEY"]}'},
params={'page_size': 10}
)
Notes
- Form IDs are alphanumeric strings
- Response pagination uses
beforetoken - Timestamps are in ISO 8601 format
- DELETE operations return HTTP 204
- IMPORTANT: When using curl commands, use
curl -gwhen URLs contain brackets (fields[],sort[],records[]) to disable glob parsing - IMPORTANT: When piping curl output to
jqor other commands, environment variables like$MATON_API_KEYmay not expand correctly in some shell environments. You may get "Invalid API key" errors when piping.
Error Handling
| Status | Meaning |
|---|---|
| 400 | Missing Typeform connection |
| 401 | Invalid or missing Maton API key |
| 429 | Rate limited (10 req/sec per account) |
| 4xx/5xx | Passthrough error from Typeform API |
Troubleshooting: API Key Issues
- Check that the
MATON_API_KEYenvironment variable is set:
echo $MATON_API_KEY
- Verify the API key is valid by listing connections:
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
Troubleshooting: Invalid App Name
- Ensure your URL path starts with
typeform. For example:
- Correct:
https://gateway.maton.ai/typeform/forms - Incorrect:
https://gateway.maton.ai/forms
Resources
Overview
This skill enables secure interaction with Typeform surveys by routing requests through the Maton gateway. It supports creating forms, retrieving responses, and accessing insights using a managed OAuth flow with MATON_API_KEY authentication.
How This Skill Works
Requests are proxied through https://gateway.maton.ai/typeform/{native-api-path} to api.typeform.com, with OAuth handled by the Maton gateway. Every call must include the MATON_API_KEY in the Authorization header, and you can specify a specific OAuth connection using the Maton-Connection header when managing multiple accounts.
When to Use It
- You need to create a new Typeform form programmatically.
- You want to retrieve responses for analysis or reporting.
- You manage multiple Typeform accounts and need to switch connections.
- You’re integrating Typeform data into your app via the gateway proxy.
- You want to fetch form insights for dashboards and analytics.
Quick Start
- Step 1: export MATON_API_KEY='YOUR_API_KEY'
- Step 2: list forms using the gateway URL https://gateway.maton.ai/typeform/forms?page_size=10 with Authorization header
- Step 3: if using multiple accounts, add Maton-Connection: <connection_id> to your requests
Best Practices
- Always set Authorization: Bearer $MATON_API_KEY for every request.
- Use the Maton-Connection header to target the correct Typeform OAuth connection.
- Paginate large result sets with page_size and handle responses gracefully.
- Keep your MATON_API_KEY secret and rotate keys regularly in the Maton settings.
- Test changes in a staging environment before applying to production integrations.
Example Use Cases
- List the first 10 forms via the gateway and inspect form metadata.
- Create a new Typeform form and retrieve its form_id for later data pulls.
- Fetch all responses for a specific form and export to a CSV-friendly format.
- Access insights for a form to populate a dashboard with response metrics.
- Manage connections by listing, creating, and selecting a specific OAuth connection.