# API синастрії та сумісності

Повний набір ендпоінтів для аналізу сумісності між людьми — від класичної синастрії до групових матриць на 10 людей.

## Що розраховується

- **Крос-аспекти** — аспекти між планетами двох карт (Sun-Venus trine, Moon-Mars square тощо)
- **Бал сумісності** — числовий бал 0–100 з міткою (harmonious, balanced, mixed, challenging)
- **Harmony/Tension** — зважена сума гармонійних і напружених аспектів
- **Композитна карта** — середні точки між планетами двох людей
- **Карта Давісона** — карта на середню дату і координати
- **Групова матриця** — парна сумісність кожного з кожним (2–10 людей)

## Ендпоінти

| Ендпоінт | Кредити | Що повертає |
|---|---|---|
| `/v1/synastry` | 50 | Крос-аспекти + бал сумісності |
| `/v1/composite` | 50 | Композитна карта (мідпоінти) |
| `/v1/davison` | 50 | Карта Давісона (середня дата) |
| `/v1/coalescent` | 50 | Коалесцентна карта |
| `/v1/group-synastry` | 100 | Матриця сумісності 2–10 людей |
| `/v1/human-design/compatibility` | 100 | HD-сумісність |

## Приклад

<Tabs>
  <TabItem label="cURL">
    ```bash frame="terminal"
    curl -X POST https://api.astroway.info/v1/synastry \
      -H "X-Api-Key: aw_live_your_key_here" \
      -H "Content-Type: application/json" \
      -d '{
        "chart1": {
          "date": "1990-07-14", "time": "14:30:00",
          "timezoneOffset": 3, "latitude": 50.45, "longitude": 30.52
        },
        "chart2": {
          "date": "1992-03-22", "time": "09:15:00",
          "timezoneOffset": 2, "latitude": 48.85, "longitude": 2.35
        }
      }'
    ```
  </TabItem>
  <TabItem label="Node.js">
    ```ts
    const r = await fetch('https://api.astroway.info/v1/synastry', {
      method: 'POST',
      headers: {
        'X-Api-Key': process.env.ASTROWAY_API_KEY!,
        'Content-Type': 'application/json',
      },
      body: JSON.stringify({
        chart1: { date: '1990-07-14', time: '14:30:00', timezoneOffset: 3, latitude: 50.45, longitude: 30.52 },
        chart2: { date: '1992-03-22', time: '09:15:00', timezoneOffset: 2, latitude: 48.85, longitude: 2.35 },
      }),
    });
    const { data: result } = await r.json();

    console.log(`Score: ${result.compatibility.score}/100`);
    console.log(`Label: ${result.compatibility.label}`);
    ```
  </TabItem>
  <TabItem label="Python">
    ```python

    r = requests.post(
        'https://api.astroway.info/v1/synastry',
        headers={'X-Api-Key': os.environ['ASTROWAY_API_KEY'], 'Content-Type': 'application/json'},
        json={
            'chart1': {'date': '1990-07-14', 'time': '14:30:00', 'timezoneOffset': 3, 'latitude': 50.45, 'longitude': 30.52},
            'chart2': {'date': '1992-03-22', 'time': '09:15:00', 'timezoneOffset': 2, 'latitude': 48.85, 'longitude': 2.35},
        },
    )
    result = r.json()['data']
    print(f"Score: {result['compatibility']['score']}/100 ({result['compatibility']['label']})")
    ```
  </TabItem>
  <TabItem label="PHP">
    ```php
    <?php
    use GuzzleHttp\Client;

    $aw = new Client(['base_uri' => 'https://api.astroway.info/v1/']);
    $r = $aw->post('synastry', [
        'headers' => ['X-Api-Key' => getenv('ASTROWAY_API_KEY')],
        'json' => [
            'chart1' => ['date' => '1990-07-14', 'time' => '14:30:00', 'timezoneOffset' => 3, 'latitude' => 50.45, 'longitude' => 30.52],
            'chart2' => ['date' => '1992-03-22', 'time' => '09:15:00', 'timezoneOffset' => 2, 'latitude' => 48.85, 'longitude' => 2.35],
        ],
    ]);
    $result = json_decode($r->getBody(), true)['data'];
    echo "Score: {$result['compatibility']['score']}/100 ({$result['compatibility']['label']})\n";
    ```
  </TabItem>
</Tabs>

## Приклад відповіді (compatibility)

```json
{
  "compatibility": {
    "score": 72,
    "label": "harmonious",
    "harmony": 18.5,
    "tension": 7.2
  }
}
```

## Сценарії використання

### Дейтинг-застосунки

Виклик `/v1/synastry` при метчі — бал сумісності як додатковий фактор ранжування. Кешування результату на пару (незмінний вхід = незмінний вихід).

### Астрологічні застосунки

Повний аналіз: синастрія + композит + Давісон. Три запити — 150 кредитів, повна картина стосунків.

### Командні інструменти

`/v1/group-synastry` з 5 людьми — матриця 10 пар за один запит (100 кредитів замість 500 окремих).

## Вартість

Синастрія — **50 кредитів**. На Free тарифі — 200 синастрій на місяць безкоштовно.

<CardGrid>
  <LinkCard title="Детальний приклад →" href="/examples/synastry/" description="Параметри, відповідь, крос-аспекти" />
  <LinkCard title="Швидкий старт" href="/getting-started/" description="Перший запит за 5 хвилин" />
  <LinkCard title="Тарифи" href="/pricing/" description="Від безкоштовного до Enterprise" />
</CardGrid>
