⚡ Developer API

Real kid voices, one POST away

The only TTS API built for children's content — real child voices in 11 languages. Pay per character with credits, no subscription required.

Quick start

  1. Create an account and buy credits (from $10 for 100).
  2. Create an API key on your dashboard.
  3. POST your text — get an MP3 back.
curl https://kidsstoryteller.ai/api/v1/tts \
  -H "Authorization: Bearer ksk_live_YOUR_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "text": "Once upon a time, in a forest full of wonder, a little fox found a glowing seed.",
    "voice": "kid-girl",
    "speed": "normal"
  }' \
  --output story.mp3

▶️ Try it

Hear any voice before you integrate. (Uses your account's character allowance — no API key needed here.)

80/300

POST /api/v1/tts

text required — up to 20,000 characters (~20 min of audio; long texts are synthesized seamlessly).

voice — voice id (default kid-girl). See the list below or GET /api/v1/voices.

speedslow | normal | gentle.

formatmp3 (binary, default) or json (base64).

const res = await fetch("https://kidsstoryteller.ai/api/v1/tts", {
  method: "POST",
  headers: {
    "Authorization": "Bearer ksk_live_YOUR_KEY",
    "Content-Type": "application/json",
  },
  body: JSON.stringify({
    text: "Era uma vez uma raposa azul…",
    voice: "kid-portuguese",
    format: "json", // base64 instead of binary
  }),
});
const { audio, credits_charged } = await res.json();

Errors are JSON: { "error": { "code", "message" } }401 bad key, 402 not enough credits, 400 invalid input or content rejected, 429 rate limited. You are never charged for a failed request.

Pricing

1 credit per 1,000 characters (minimum 1 credit per request), from the same credit balance as the rest of KidsStoryteller. Packs: 100 / $10 · 300 / $25 · 750 / $55 — so roughly $0.073–0.10 per 1,000 characters. Credits are valid for 30 days.

ElevenLabs APIThis API
Per 1,000 chars~$0.165–0.30$0.073–0.10
SubscriptionRequiredNone — packs from $10
Real child voicesProhibited by policy11 voices · 11 languages

Content safety

Every request is screened by an AI moderation layer before synthesis. Text that isn't appropriate for a kids platform is rejected (HTTP 400, no charge). This is non-negotiable — these are children's voices.

Voices

🧒 Kid voices (11)

kid-girlEnglish (US)
kid-britishEnglish (UK)
kid-spanishSpanish (Mexico)
kid-frenchFrench
kid-germanGerman
kid-chineseChinese (Mandarin)
kid-italianItalian
kid-portuguesePortuguese (Brazil)
kid-japaneseJapanese
kid-turkishTurkish
kid-koreanKorean

🎙 Adult narration voices (38)

azure-ariaEnglish (US)
azure-jennyEnglish (US)
azure-michelleEnglish (US)
azure-monicaEnglish (US)
azure-saraEnglish (US)
azure-guyEnglish (US)
azure-davisEnglish (US)
azure-tonyEnglish (US)
azure-freyaEnglish (AU)
azure-williamEnglish (AU)
azure-neerjaEnglish (IN)
azure-emilyEnglish (IE)
calm-momEnglish (US)
sweet-teacherEnglish (US)
sunny-friendEnglish (US)
bedtime-whisperEnglish (US)
playful-elfEnglish (US)
friendly-bearEnglish (US)
story-dadEnglish (US)
cozy-uncleEnglish (US)
gentle-giantEnglish (US)
story-grandpaEnglish (US)
azure-es-daliaSpanish (Mexico)
azure-es-jorgeSpanish (Mexico)
azure-es-elenaSpanish (Spain)
azure-fr-deniseFrench
azure-fr-henriFrench
azure-fr-vivienneFrench
azure-de-katjaGerman
azure-de-konradGerman
azure-de-amalaGerman
azure-pt-franciscaPortuguese (Brazil)
azure-pt-antonioPortuguese (Brazil)
azure-pt-thalitaPortuguese (Brazil)
azure-it-isabellaItalian
azure-it-giuseppeItalian
azure-ko-sunhiKorean
azure-ko-injoonKorean

Questions? Contact us — we reply within 24 hours.