Build media features in minutes

-const pain="s3 permissions" + "ffmpeg copypasta"
+let ittybit="scalable media handling in mins"

Everything your app needs for video, audio, and image files

We built ittybit for ourselves because we needed something faster and simpler than stitching together AWS services, but much more flexible (and affordable) than other hosted media services.

Storage made for media

Handle weird image formats, large videos, and audio input with a single consistent API

Intelligence built-in

No more opaque bytes! Analyse files and extract rich data using built-in AI features

Encode & transform

Crop, compress, and convert random uploads to standard modern formats

Low-latency delivery

Built-in CDN gets media to users in milliseconds, all for a single global rate

Scale with ease

Broadcast-grade systems let you handle millions of files without infra headaches

The data you need

Understand your media usage, and get insights into your users' behavior

Secure-by-default

We handle multiregion backups, and all data is encrypted at rest and in transit

By devs, for devs

We sweat the small details to create a delightful developer experience

Get started for free

10GB tasks. 100GB storage. 1TB delivery

One API to store, transform, and get rich intelligence from your media

-"5 services and glue code"
-"wtf is in this bucket?"
-"literally. too. many. bills"
+"1 consistent api"
+"built-in intelligence"
+"legit cheap"
hosting

Easy uploads, secure storage, and rapid global delivery

Add fast, reliable, uploads to your product in minutes. Store all your app's video, image, and audio files securely. Download or stream your media globally with built-in CDN.

await fetch('https://your-project.ittybit.net/uploaded-video.mov', {
  method: 'PUT',
  headers: { 'Authorization': 'Bearer ITTYBIT_API_KEY' },
  body: file
});
intelligence

Make your video, image, and audio files more useful

Describe or summarize images, videos, and audio. Make media searchable by extracting text, objects, and speech. Detect and filter out NSFW uploads before your users see them.

const task = {
  url: 'https://your-project.ittybit.net/uploaded-video.mov',
  kind: 'summary',
}
const response = await fetch('https://api.ittybit.com/tasks', {
  method: 'POST',
  headers: { 'Authorization': 'Bearer ITTYBIT_API_KEY' },
  body: JSON.stringify(task)
});
sources

Convert, compress, and transform your media files

Convert files to modern formats for maximum compatibility. Compress media files up to 90% without sacrificing quality. Resize and crop content to specific aspect ratios.

const task = {
  url: 'https://your-project.ittybit.net/uploaded-video.mov',
  width: 1280,
  height: 720,
  fit: 'cover',
  layers: [
    { kind: 'image', url: '/logo.png', right: 0 }
  ] 
tracks

Make your media player engaging and accessible

Add poster images to increase clickthrough and playback rates. Improve SEO and accessibility with automatic subtitles and captions. Help viewers navigate with interactive chapter markers.

<video>
  <source src='https://your-project.ittybit.net/uploaded-video.mp4' />
  <track src='https://your-project.ittybit.net/uploaded-video/subtitles.vtt' kind='subtitles' />
  <track src='https://your-project.ittybit.net/uploaded-video/chapters.vtt' kind='chapters' />
  <track src='https://your-project.ittybit.net/uploaded-video/thumbnails.vtt' kind='metadata' />
</video>

Get started for free

10GB tasks. 100GB storage. 1TB delivery

Build robust media workflows that scale-up with you

-const requirements = "GPUs", "microservices", "exponential backoff"
+const requirements = "about 30 lines of JSON"
workflow example animation
Robot mascot
Automations

Handle millions of files with one minute of setup

Automations let you trigger workflows for every new upload. Tasks can run in parallel, in sequence, or based on conditional logic. As your product grows ittybit's broadcast-grade infrastructure will scale up alongside you.

const automation = {
  trigger: { event: 'media.created' },
  workflow: [
    { kind: 'nsfw', confidence: 0.6,
      next: [{
        kind: 'conditions',
        conditions: [{ prop: 'detected', value: true }],
        next: [{ kind: 'webhook', url: 'https://your.api/ittybit' }]
      },{ 
        kind: 'conditions',
        conditions: [{ prop: 'detected', value: false }],
        next: [{
          kind: 'video', width: 720, height: 1280, label: 'web',
          next: [{
            kind: 'image', format: 'png', label: 'poster',
            next: [
              { kind: 'webhook', url: 'https://your.api/ittybit' },
              { kind: 'speech', speakers: true,
                next: [{ kind: 'subtitles', format: 'vtt' }]
              },
              { kind: 'chapters', format: 'vtt' }
            ]}
          ]}
        },{ 
          kind: 'image', long_edge: 240, label: 'thumbnail' 
        }]
      }]
    },
    { kind: 'description' }
  ]
}
const response = await fetch('https://api.ittybit.com/automations', {
  method: 'POST',
  headers: {'Authorization': 'Bearer ITTYBIT_API_KEY'},
  body: JSON.stringify(automation)
});

Get started for free

10GB tasks. 100GB storage. 1TB delivery

Ittybit helps us serve video lessons reliably and affordably. That means 80,000 kids can train wherever they are in the world.

Simon Brundish

Simon Brundish

Founder, Strength:Lab

Ittybit enables Blackbook to support user-generated content without worrying about weird formats, malicious files, or inappropriate material

Becky Fatemi

Becky Fatemi

Founder, BlackBook