Generate Tarot Reading (PDF or HTML)
POST /reports/tarot
POST
/reports/tarot
Render a tarot reading PDF. Default spread three-card (Past/Present/Future from Rider-Waite-Smith deck). Available spreads: single-card, three-card, celtic-cross, horseshoe, relationship, year-ahead, decision, chakra, career, love-triangle. Pass seed for reproducibility (deterministic mulberry32 RNG); omit to use a daily seed. Set allowReversed: false to draw upright cards only.
Authorizations
Section titled “Authorizations ”Code Samples
Section titled “ Code Samples ”curl -X POST https://api.astroway.info/v1/reports/tarot \ -H "X-Api-Key: aw_live_..." \ -H "Content-Type: application/json" \ -d '{ "spread": "three-card", "seed": 1234, "name": "Sample Reading", "allowReversed": true, "language": "uk" }'const res = await fetch('https://api.astroway.info/v1/reports/tarot', { method: 'POST', headers: { 'X-Api-Key': process.env.ASTROWAY_API_KEY, 'Content-Type': 'application/json', }, body: JSON.stringify({ "spread": "three-card", "seed": 1234, "name": "Sample Reading", "allowReversed": true, "language": "uk" }),});const { ok, data, error } = await res.json();if (!ok) throw new Error(error.message);console.log(data);import os, requests
r = requests.post( 'https://api.astroway.info/v1/reports/tarot', headers={'X-Api-Key': os.environ['ASTROWAY_API_KEY'], 'Content-Type': 'application/json'}, json={ 'spread': "three-card", 'seed': 1234, 'name': "Sample Reading", 'allowReversed': True, 'language': "uk" },)result = r.json()if not result['ok']: raise RuntimeError(result['error']['message'])print(result['data'])<?phpuse GuzzleHttp\Client;
$client = new Client(['base_uri' => 'https://api.astroway.info/v1/']);$r = $client->post('reports/tarot', [ 'headers' => ['X-Api-Key' => getenv('ASTROWAY_API_KEY')], 'json' => [ 'spread' => 'three-card', 'seed' => 1234, 'name' => 'Sample Reading', 'allowReversed' => true, 'language' => 'uk', ],]);$result = json_decode($r->getBody(), true);if (!$result['ok']) throw new \RuntimeException($result['error']['message']);print_r($result['data']);Request Body required
Section titled “Request Body required ”object
spread
string
seed
integer
name
string
allowReversed
boolean
language
string
whitelabel
boolean
Example
{ "spread": "three-card", "seed": 1234, "name": "Sample Reading", "allowReversed": true, "language": "uk"}Responses
Section titled “ Responses ”Successful calculation
object
ok
boolean
Example
true data
object
url
string
storage_key
string
byte_length
number
page_count
number
duration_ms
number
expires_at
string
Example
{ "ok": true, "data": { "url": "https://api.astroway.info/reports/abc-tarot.pdf", "storage_key": "reports/abc-tarot.pdf", "byte_length": 95000, "page_count": 1, "duration_ms": 2400, "expires_at": "2026-05-09T07:00:00Z" }}Validation error
Example
{ "ok": false, "error": { "code": "INVALID_INPUT", "message": "Validation failed: date: Date must be YYYY-MM-DD", "details": [ { "path": "date", "message": "Date must be YYYY-MM-DD" } ] }}Missing or invalid API key
Example
{ "ok": false, "error": { "code": "INVALID_API_KEY", "message": "Invalid API key" }} Корисно?
Дякуємо за фідбек.