Create a Slide Deck from Text

Implements the text-based slide deck recipe with outputType: "slide_deck".

<?php

$token = getenv('AUTOCONTENT_TOKEN') ?: 'YOUR_API_TOKEN';
$endpoint = 'https://api.autocontentapi.com/content/Create';

$payload = [
  'outputType' => 'slide_deck',
  'resources' => [
    [
      'type' => 'text',
      'content' => 'Internal memo on the new analytics rollout, timeline, and launch messaging.'
    ]
  ],
  'text' => 'Build a 10-slide deck with an executive summary, timeline, risks, and next steps.',
  'duration' => 'default',
  'slideDeckFormat' => 'detailed'
];

$body = json_encode($payload);
if ($body === false) {
    fwrite(STDERR, 'Failed to encode payload: ' . json_last_error_msg() . PHP_EOL);
    exit(1);
}

$ch = curl_init($endpoint);
curl_setopt_array($ch, [
    CURLOPT_HTTPHEADER => [
        'Authorization: Bearer ' . $token,
        'Content-Type: application/json',
        'Accept: application/json',
    ],
    CURLOPT_POST => true,
    CURLOPT_POSTFIELDS => $body,
    CURLOPT_RETURNTRANSFER => true,
]);

$response = curl_exec($ch);
if ($response === false) {
    fwrite(STDERR, 'Request failed: ' . curl_error($ch) . PHP_EOL);
    curl_close($ch);
    exit(1);
}

$status = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);

if ($status >= 400) {
    fwrite(STDERR, "HTTP $status" . PHP_EOL . $response . PHP_EOL);
    exit(1);
}

echo "Slide deck request accepted:" . PHP_EOL . $response . PHP_EOL;

Set YOUR_API_TOKEN (or AUTOCONTENT_TOKEN) before running.

Last updated