BlitzReels Video Editing
Edit videos via the BlitzReels API: upload media, transcribe, edit timeline, apply captions, add overlays and backgrounds, then export.
If the task is specifically long-form to shorts, podcast-to-shorts, suggestion-backed clipping, or public automatic-layout reframe planning, prefer the blitzreels-clipping skill first and come back here for lower-level timeline work.
Important: project preview and visual QA endpoints now exist. Use them when an agent needs to verify framing, caption placement, or layout visually before export.
Quick Start
bash scripts/editor.sh upload-url PROJECT_ID "https://example.com/video.mp4"
bash scripts/editor.sh add-media PROJECT_ID MEDIA_ID
bash scripts/editor.sh transcribe PROJECT_ID MEDIA_ID
bash scripts/editor.sh trim PROJECT_ID ITEM_ID 1.0 -2.0
bash scripts/editor.sh captions PROJECT_ID viral-center
bash scripts/editor.sh export PROJECT_ID --resolution 1080p
Primary Workflow
- Create project —
POST /projects {"name":"...", "aspect_ratio":"9:16"}
- Upload media —
editor.sh upload-url (URL import) or 2-step presigned upload
- Add to timeline —
editor.sh add-media places media on the timeline
- Transcribe —
editor.sh transcribe generates word-level captions
- Get context —
editor.sh context to see timeline state
- Edit timeline — trim, split, delete, reorder, auto-remove silences
- Apply captions —
editor.sh captions <presetId> for styled subtitles
- Add overlays — text overlays, motion code, motion graphics
- Add background — fill layers (gradients, cinematic, patterns)
- Export —
editor.sh export renders final video with download URL
Scripts
scripts/editor.sh
Subcommand wrapper for common editing operations.
| Command |
Usage |
Description |
upload-url |
<projectId> <url> [name] |
Upload media from URL |
transcribe |
<projectId> <mediaId> |
Transcribe + poll until done |
context |
<projectId> [mode] |
Get project context (default: timeline) |
timeline-at |
<projectId> <seconds> |
Get items at timestamp |
trim |
<projectId> <itemId> <startDelta> <endDelta> |
Trim item edges |
split |
<projectId> <itemId> <atSeconds> |
Split item at time |
delete-item |
<projectId> <itemId> |
Delete timeline item |
add-media |
<projectId> <mediaId> [startSec] |
Add media to timeline |
add-broll |
<projectId> <JSON> |
Add B-roll clip |
captions |
<projectId> <presetId> |
Apply caption preset |
export |
<projectId> [--resolution R] |
Export + poll + download URL |
Run bash scripts/editor.sh --help for full usage.
scripts/blitzreels.sh
Generic API helper for direct endpoint calls. Use for overlays, effects, and advanced operations where editor.sh doesn't have a shortcut.
bash scripts/blitzreels.sh METHOD /path [JSON_BODY]
Environment Variables
| Variable |
Required |
Description |
BLITZREELS_API_KEY |
Yes |
API key (br_live_...) |
BLITZREELS_API_BASE_URL |
No |
Override base URL (default: https://www.blitzreels.com/api/v1) |
BLITZREELS_ALLOW_EXPENSIVE |
No |
Set to 1 for export calls via blitzreels.sh |
API Endpoint Index
Projects
| Method |
Path |
Description |
| POST |
/projects |
Create project |
| GET |
/projects/{id} |
Get project details |
| PATCH |
/projects/{id} |
Update project settings |
| DELETE |
/projects/{id} |
Delete project |
| GET |
/projects |
List projects |
Media
| Method |
Path |
Description |
| POST |
/projects/{id}/media |
Import media from URL |
| POST |
/projects/{id}/upload/presigned |
Get presigned upload URL |
| POST |
/projects/{id}/upload/finalize |
Finalize presigned upload |
Transcription
| Method |
Path |
Description |
| POST |
/projects/{id}/transcribe |
Start transcription job |
| GET |
/jobs/{jobId} |
Poll job status |
| GET |
/projects/{id}/context?mode=transcript |
Get transcript |
| POST |
/projects/{id}/captions/regenerate |
Re-transcribe media |
Captions
| Method |
Path |
Description |
| POST |
/projects/{id}/captions |
Apply caption preset |
| GET |
/projects/{id}/captions/style |
Get current style |
| PATCH |
/projects/{id}/captions/style |
Update style settings |
| GET |
/projects/{id}/captions/presets |
List presets by category |
| PATCH |
/projects/{id}/captions/{captionId} |
Update caption words/timing |
| DELETE |
/projects/{id}/captions/{captionId} |
Delete caption |
| POST |
/projects/{id}/captions/words/emphasis |
Emphasize specific words |
Timeline Editing
| Method |
Path |
Description |
| POST |
/projects/{id}/timeline/media |
Add media to timeline |
| POST |
/projects/{id}/timeline/trim |
Trim item by deltas |
| POST |
/projects/{id}/timeline/split |
Split item at timestamp |
| DELETE |
/projects/{id}/timeline/items/{itemId} |
Delete item |
| PATCH |
/projects/{id}/timeline/items/{itemId} |
Update item |
| POST |
/projects/{id}/timeline/items/batch-update |
Batch update items |
| PATCH |
/projects/{id}/timeline/items/{itemId}/volume |
Set volume |
| PATCH |
/projects/{id}/timeline/items/{itemId}/transform |
Set transform |
| POST |
/projects/{id}/timeline/pack-clips |
Remove gaps |
| POST |
/projects/{id}/timeline/silence-detection |
Detect silences |
| POST |
/projects/{id}/timeline/mistake-detection |
AI mistake detection |
| POST |
/projects/{id}/timeline/caption-recut |
Caption-based recut plan |
Overlays — Text, Motion Code, Motion Graphics
| Method |
Path |
Description |
| POST |
/projects/{id}/text-overlays |
Add text overlay |
| PATCH |
/projects/{id}/text-overlays/{oid} |
Update text overlay |
| DELETE |
/projects/{id}/text-overlays/{oid} |
Remove text overlay |
| POST |
/projects/{id}/motion-code |
Add animated code block |
| PATCH |
/projects/{id}/motion-code/{cid} |
Update code block |
| POST |
/projects/{id}/motion-graphics |
Add motion graphic |
| PATCH |
/projects/{id}/motion-graphics/{gid} |
Update motion graphic |
Backgrounds
| Method |
Path |
Description |
| POST |
/projects/{id}/fill-layers |
Add fill layer |
| PATCH |
/projects/{id}/fill-layers/{lid} |
Update fill layer |
Context & State
| Method |
Path |
Description |
| GET |
/projects/{id}/context?mode=... |
Get project context |
| GET |
/projects/{id}/timeline/at?time_seconds=X |
Items at timestamp |
| POST |
/projects/{id}/preview-frame |
Render one still preview |
| POST |
/projects/{id}/preview-frames |
Render multiple still previews |
| POST |
/projects/{id}/visual-analysis |
Run structured frame QA |
| GET |
/projects/{id}/visual-debug |
Get machine-readable layout geometry |
| POST |
/projects/{id}/timeline/undo |
Undo last action |
Media View Repair
| Method |
Path |
Description |
| POST |
/projects/{id}/timeline/media-views/{timelineItemId} |
Upsert source-view crop/canvas state for one item |
| POST |
/projects/{id}/timeline/media-views/duplicate |
Duplicate a linked source view to another item |
Clipping / Reframe Preview
| Method |
Path |
Description |
| POST |
/workspace/media/assets/{assetId}/reframe-plan/preview |
Generate a reframe plan plus preview stills before apply |
Export & Jobs
| Method |
Path |
Description |
| POST |
/projects/{id}/export |
Start export (expensive) |
| GET |
/exports/{exportId} |
Export status + download URL |
| GET |
/projects/{id}/exports |
Export history |
| DELETE |
/projects/{id}/exports |
Delete all exports |
| GET |
/jobs/{jobId} |
Generic job polling |
Effects & Keyframes
| Method |
Path |
Description |
| POST |
/projects/{id}/timeline/effects/zoom |
Add zoom effect |
| POST |
/projects/{id}/timeline/effects/mask |
Add mask effect |
| POST |
/projects/{id}/timeline/effects/color-grade |
Add color grade |
| POST |
/projects/{id}/timeline/items/{itemId}/keyframes |
Create keyframe |
Context Modes
Use ?mode= to control what data the context endpoint returns:
| Mode |
Returns |
summary |
Project metadata, duration, media count |
assets |
All media assets with metadata |
timeline |
Full timeline with items, layers, timing |
transcript |
Word-level transcript from transcription |
full |
Everything combined |
Default: timeline
bash scripts/editor.sh context PROJECT_ID timeline
bash scripts/editor.sh context PROJECT_ID full
Upload Modes
URL Import (Simpler)
bash scripts/editor.sh upload-url PROJECT_ID "https://example.com/video.mp4"
Presigned 2-Step (For Local Files)
PRESIGNED=$(bash scripts/blitzreels.sh POST /projects/PROJECT_ID/upload/presigned \
'{"fileName":"video.mp4","contentType":"video/mp4"}')
curl -X PUT "$(echo $PRESIGNED | jq -r '.url')" \
-H "Content-Type: video/mp4" \
--data-binary @video.mp4
bash scripts/blitzreels.sh POST /projects/PROJECT_ID/upload/finalize \
"{\"storageKey\":\"$(echo $PRESIGNED | jq -r '.key')\"}"
Quick Reference
- Caption presets: 30+ presets across 6 categories — see
references/caption-styles.md
- Active word animations: highlight, scale, glow, lift, bounce, punch, slam, elastic, shake, none
- Motion code themes: github-dark, one-dark, dracula, nord, monokai, tokyo-night
- Fill layer presets: 38+ across 7 categories — see
references/fill-layers.md
- Timeline layer order: caption(0) → effect(1) → image(2) → video(3) → audio(4) → background(5)
References
references/clipping.md — Long-form to short workflow, podcast QA loop, preview/repair endpoints
references/caption-styles.md — All 30+ presets, CaptionStyleSettings schema, animations
references/overlays.md — Text overlays, motion code, motion graphics schemas
references/fill-layers.md — 38+ background presets, FillLayerSettings schema
references/timeline-ops.md — Timeline endpoints, AI features, keyframes, effects
references/export-settings.md — Export params, codecs, polling pattern
examples/edit-uploaded-video.md — Full upload→edit→export walkthrough
examples/enhance-with-overlays.md — Adding graphics to existing project
Safety & Notes
- Use
https://www.blitzreels.com/api/v1 as base URL (avoid redirect from non-www)
- Export and B-roll generation are expensive — require
BLITZREELS_ALLOW_EXPENSIVE=1
editor.sh export sets this automatically; blitzreels.sh requires explicit opt-in
- Download URLs are temporary (24h TTL)
- Full OpenAPI spec:
https://www.blitzreels.com/api/openapi.json
Rate Limits
| Plan |
Requests/min |
Requests/day |
| Free |
10 |
100 |
| Lite |
30 |
1,000 |
| Creator |
60 |
5,000 |
| Agency |
120 |
20,000 |