# Snelnotuleren Python SDK
[](https://badge.fury.io/py/snelnotuleren-sdk)
[](https://pypi.org/project/snelnotuleren-sdk/)
Python SDK voor de Snelnotuleren.nl API. Automatiseer het verwerken van audio-opnames naar notulen.
## Installatie
```bash
pip install snelnotuleren-sdk
```
## Gebruik
### API Credentials aanmaken
Je kunt op twee manieren API credentials krijgen:
1. Via het dashboard op [dashboard.snelnotuleren.nl](https://dashboard.snelnotuleren.nl)
2. Programmatisch via de SDK:
```python
from snelnotuleren import SnelNotulerenClient
# Maak nieuwe credentials aan
client = SnelNotulerenClient()
credentials = client.create_client_credentials(
label="Mijn API Client",
description="Voor automatische verwerking"
)
print(f"Client ID: {credentials['client_id']}")
print(f"Client Secret: {credentials['client_secret']}")
print(f"Webhook Secret: {credentials['webhook_secret']}") # Voor webhook verificatie
```
### Notulen verwerken
```python
from snelnotuleren import SnelNotulerenClient
# Initialiseer met je credentials
client = SnelNotulerenClient(
client_id='jouw_client_id',
client_secret='jouw_client_secret'
)
# Basis gebruik met verplichte velden
order_id = client.create_order(
file_path='vergadering.mp3', # Verplicht,
email='contact@bedrijf.nl', # Verplicht,
context='Maandelijkse vergadering', # Verplicht,
meeting_date='2025-02-23', # Verplicht, format: YYYY-MM-DD
smart_detection=True, # Verplicht, voor automatische agendapunt detectie
report_type='middel_notulen', # Optional, standaard op 'transcriptie'
webhook_url='https://jouw-domein.nl/webhook'
)
# Met experimentele features
order_id = client.create_order(
file_path='vergadering.mp3',
email='contact@bedrijf.nl',
context='Maandelijkse vergadering',
meeting_date='2025-02-23',
smart_detection=True,
# Experimentele features
speaker_diarization=True, # Optioneel, experimenteel
speaker_count=4, # Optioneel, experimenteel (1-10)
speaker_names=['Jan', 'Piet', 'Marie', 'Anna'], # Optioneel, experimenteel
webhook_url='https://jouw-domein.nl/webhook'
)
```
Implementeer een webhook handler:
```python
from flask import Flask, request
import hmac
import hashlib
app = Flask(__name__)
@app.route('/webhook', methods=['POST'])
def webhook():
# Verifieer de webhook signature
signature = request.headers.get('X-Webhook-Signature')
payload = request.get_data().decode('utf-8')
expected_signature = hmac.new(
'jouw_webhook_secret'.encode(), # Van je credentials
payload.encode(),
hashlib.sha256
).hexdigest()
if signature != expected_signature:
return 'Invalid signature', 401
# Verwerk de webhook
data = request.json
if data['event'] == 'processing.completed':
# Notulen zijn klaar
notulen = data['data']['notulen']
print(f"✅ Notulen ontvangen voor order {data['order_id']}")
elif data['event'] == 'processing.failed':
print(f"❌ Error voor order {data['order_id']}: {data['error']}")
return 'OK', 200
if __name__ == '__main__':
app.run(port=8080)
```
## Verplichte Velden
- `file_path`: Pad naar het audio bestand
- `email`: Email adres voor notificaties
- `context`: Naam/context van de vergadering
- `meeting_date`: Datum van de vergadering (format: YYYY-MM-DD)
- `smart_detection`: Automatische agendapunt detectie (boolean)
- `webhook_url`: URL voor webhook notificaties
## Optionele Velden
- `report_type`: Type rapport (default: 'transcriptie')
- `unstructured_agenda`: Ongestructureerde agenda tekst
## Experimentele Features
De volgende features zijn in beta en kunnen wijzigen:
- `speaker_diarization`: Sprekerherkenning gebruiken (boolean)
- `speaker_count`: Verwacht aantal sprekers (1-10)
- `speaker_names`: Lijst met namen van sprekers
## Report Types
- `transcriptie`: Alleen transcriptie (€5)
- `korte_notulen`: Beknopte notulen (€10)
- `middel_notulen`: Uitgebreide notulen (€20)
- `lange_notulen`: Complete notulen met details (€25)
## Webhook Events
Je kunt deze events verwachten:
- `processing.completed`: Notulen zijn succesvol verwerkt
```json
{
"event": "processing.completed",
"order_id": "order_123",
"status": "completed",
"data": {
"meeting_name": "Maandelijkse vergadering",
"meeting_date": "2024-02-22",
"notulen": "De vergadering wordt geopend...",
"speakers": ["Spreker 1", "Spreker 2"],
"metadata": {
"speaker_diarization": true,
"speakers_expected": 2,
"detected_language": "nl",
"categories": ["Opening", "Rondvraag"]
}
}
}
```
- `processing.failed`: Er is een fout opgetreden
```json
{
"event": "processing.failed",
"order_id": "order_123",
"status": "failed",
"error": "Beschrijving van de fout"
}
```
## Security Best Practices
1. Bewaar je client secret en webhook secret veilig
2. Verifieer altijd de webhook signature
3. Gebruik HTTPS voor je webhook endpoint
4. Implementeer rate limiting op je webhook endpoint
Raw data
{
"_id": null,
"home_page": "https://github.com/snelnotuleren/python-sdk",
"name": "snelnotuleren-sdk",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": "notulen, transcriptie, api, webhook",
"author": "Snelnotuleren.nl",
"author_email": "niels@snelnotuleren.nl",
"download_url": "https://files.pythonhosted.org/packages/53/10/666ec942496c42cb8c0c095eecf5dc416b0055e4a8c74ba14c43ef67244d/snelnotuleren_sdk-1.1.12.tar.gz",
"platform": null,
"description": "# Snelnotuleren Python SDK\n[](https://badge.fury.io/py/snelnotuleren-sdk)\n[](https://pypi.org/project/snelnotuleren-sdk/)\n\nPython SDK voor de Snelnotuleren.nl API. Automatiseer het verwerken van audio-opnames naar notulen.\n\n## Installatie\n\n```bash\npip install snelnotuleren-sdk\n```\n\n## Gebruik\n\n### API Credentials aanmaken\nJe kunt op twee manieren API credentials krijgen:\n\n1. Via het dashboard op [dashboard.snelnotuleren.nl](https://dashboard.snelnotuleren.nl)\n2. Programmatisch via de SDK:\n\n```python\nfrom snelnotuleren import SnelNotulerenClient\n\n# Maak nieuwe credentials aan\nclient = SnelNotulerenClient()\ncredentials = client.create_client_credentials(\n label=\"Mijn API Client\",\n description=\"Voor automatische verwerking\"\n)\n\nprint(f\"Client ID: {credentials['client_id']}\")\nprint(f\"Client Secret: {credentials['client_secret']}\")\nprint(f\"Webhook Secret: {credentials['webhook_secret']}\") # Voor webhook verificatie\n```\n\n### Notulen verwerken\n\n```python\nfrom snelnotuleren import SnelNotulerenClient\n\n# Initialiseer met je credentials\nclient = SnelNotulerenClient(\n client_id='jouw_client_id',\n client_secret='jouw_client_secret'\n)\n\n# Basis gebruik met verplichte velden\norder_id = client.create_order(\n file_path='vergadering.mp3', # Verplicht, \n email='contact@bedrijf.nl', # Verplicht, \n context='Maandelijkse vergadering', # Verplicht, \n meeting_date='2025-02-23', # Verplicht, format: YYYY-MM-DD\n smart_detection=True, # Verplicht, voor automatische agendapunt detectie\n report_type='middel_notulen', # Optional, standaard op 'transcriptie'\n webhook_url='https://jouw-domein.nl/webhook'\n)\n\n# Met experimentele features\norder_id = client.create_order(\n file_path='vergadering.mp3',\n email='contact@bedrijf.nl',\n context='Maandelijkse vergadering',\n meeting_date='2025-02-23',\n smart_detection=True,\n # Experimentele features\n speaker_diarization=True, # Optioneel, experimenteel\n speaker_count=4, # Optioneel, experimenteel (1-10)\n speaker_names=['Jan', 'Piet', 'Marie', 'Anna'], # Optioneel, experimenteel\n webhook_url='https://jouw-domein.nl/webhook'\n)\n```\n\nImplementeer een webhook handler:\n\n```python\nfrom flask import Flask, request\nimport hmac\nimport hashlib\n\napp = Flask(__name__)\n\n@app.route('/webhook', methods=['POST'])\ndef webhook():\n # Verifieer de webhook signature\n signature = request.headers.get('X-Webhook-Signature')\n payload = request.get_data().decode('utf-8')\n \n expected_signature = hmac.new(\n 'jouw_webhook_secret'.encode(), # Van je credentials\n payload.encode(),\n hashlib.sha256\n ).hexdigest()\n \n if signature != expected_signature:\n return 'Invalid signature', 401\n\n # Verwerk de webhook\n data = request.json\n \n if data['event'] == 'processing.completed':\n # Notulen zijn klaar\n notulen = data['data']['notulen']\n print(f\"\u2705 Notulen ontvangen voor order {data['order_id']}\")\n \n elif data['event'] == 'processing.failed':\n print(f\"\u274c Error voor order {data['order_id']}: {data['error']}\")\n \n return 'OK', 200\n\nif __name__ == '__main__':\n app.run(port=8080)\n```\n\n## Verplichte Velden\n\n- `file_path`: Pad naar het audio bestand\n- `email`: Email adres voor notificaties\n- `context`: Naam/context van de vergadering\n- `meeting_date`: Datum van de vergadering (format: YYYY-MM-DD)\n- `smart_detection`: Automatische agendapunt detectie (boolean)\n- `webhook_url`: URL voor webhook notificaties\n\n## Optionele Velden\n\n- `report_type`: Type rapport (default: 'transcriptie')\n- `unstructured_agenda`: Ongestructureerde agenda tekst\n\n## Experimentele Features\n\nDe volgende features zijn in beta en kunnen wijzigen:\n\n- `speaker_diarization`: Sprekerherkenning gebruiken (boolean)\n- `speaker_count`: Verwacht aantal sprekers (1-10)\n- `speaker_names`: Lijst met namen van sprekers\n\n## Report Types\n\n- `transcriptie`: Alleen transcriptie (\u20ac5)\n- `korte_notulen`: Beknopte notulen (\u20ac10)\n- `middel_notulen`: Uitgebreide notulen (\u20ac20)\n- `lange_notulen`: Complete notulen met details (\u20ac25)\n\n## Webhook Events\n\nJe kunt deze events verwachten:\n\n- `processing.completed`: Notulen zijn succesvol verwerkt\n ```json\n {\n \"event\": \"processing.completed\",\n \"order_id\": \"order_123\",\n \"status\": \"completed\",\n \"data\": {\n \"meeting_name\": \"Maandelijkse vergadering\",\n \"meeting_date\": \"2024-02-22\",\n \"notulen\": \"De vergadering wordt geopend...\",\n \"speakers\": [\"Spreker 1\", \"Spreker 2\"],\n \"metadata\": {\n \"speaker_diarization\": true,\n \"speakers_expected\": 2,\n \"detected_language\": \"nl\",\n \"categories\": [\"Opening\", \"Rondvraag\"]\n }\n }\n }\n ```\n\n- `processing.failed`: Er is een fout opgetreden\n ```json\n {\n \"event\": \"processing.failed\",\n \"order_id\": \"order_123\",\n \"status\": \"failed\",\n \"error\": \"Beschrijving van de fout\"\n }\n ```\n\n## Security Best Practices\n\n1. Bewaar je client secret en webhook secret veilig\n2. Verifieer altijd de webhook signature\n3. Gebruik HTTPS voor je webhook endpoint\n4. Implementeer rate limiting op je webhook endpoint\n",
"bugtrack_url": null,
"license": null,
"summary": "Python SDK voor de Snelnotuleren.nl API",
"version": "1.1.12",
"project_urls": {
"Homepage": "https://github.com/snelnotuleren/python-sdk"
},
"split_keywords": [
"notulen",
" transcriptie",
" api",
" webhook"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "406761178a8568f18d48c68c2354242121203639dcc3e4fbfc853c1dec6becb9",
"md5": "50c94fef5021ce246f89b158a1b2e2f9",
"sha256": "c1d144ac5a0d8e2fd1a9ab16c0f4fbe4eeaa04617aee546f81a61acb69a25c4e"
},
"downloads": -1,
"filename": "snelnotuleren_sdk-1.1.12-py3-none-any.whl",
"has_sig": false,
"md5_digest": "50c94fef5021ce246f89b158a1b2e2f9",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 7541,
"upload_time": "2025-02-23T22:50:09",
"upload_time_iso_8601": "2025-02-23T22:50:09.772878Z",
"url": "https://files.pythonhosted.org/packages/40/67/61178a8568f18d48c68c2354242121203639dcc3e4fbfc853c1dec6becb9/snelnotuleren_sdk-1.1.12-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "5310666ec942496c42cb8c0c095eecf5dc416b0055e4a8c74ba14c43ef67244d",
"md5": "9271664ac844a16fae8f5311e2edae8e",
"sha256": "c85557f2790c639e722736579fd6ba63308358883e820cf9a53456d140c9fc2e"
},
"downloads": -1,
"filename": "snelnotuleren_sdk-1.1.12.tar.gz",
"has_sig": false,
"md5_digest": "9271664ac844a16fae8f5311e2edae8e",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 7286,
"upload_time": "2025-02-23T22:50:10",
"upload_time_iso_8601": "2025-02-23T22:50:10.798134Z",
"url": "https://files.pythonhosted.org/packages/53/10/666ec942496c42cb8c0c095eecf5dc416b0055e4a8c74ba14c43ef67244d/snelnotuleren_sdk-1.1.12.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-02-23 22:50:10",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "snelnotuleren",
"github_project": "python-sdk",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [
{
"name": "requests",
"specs": [
[
">=",
"2.25.0"
]
]
}
],
"lcname": "snelnotuleren-sdk"
}