---
title: "Идентификация пользователей в Capacitor SDK"
description: "Быстрый старт по настройке Adapty для управления встроенными подписками в Capacitor."
---

То, как вы управляете покупками пользователей, зависит от модели аутентификации в вашем приложении:
- Если приложение не использует бэкенд-аутентификацию и не хранит данные пользователей, см. [раздел об анонимных пользователях](#anonymous-users).
- Если в приложении есть (или будет) бэкенд-аутентификация, см. [раздел об идентифицированных пользователях](#identified-users).

:::tip
**Ключевые понятия**:
- **Профили** — сущности, необходимые для работы SDK. Adapty создаёт их автоматически. Они могут быть анонимными (без customer user ID) или идентифицированными (с customer user ID).
- **Customer user ID** — необязательные идентификаторы, которые **создаёте вы сами**, чтобы Adapty мог связать ваших пользователей с их профилями.
:::

Вот в чём разница между анонимными и идентифицированными пользователями:

|                              | Анонимные пользователи                                          | Идентифицированные пользователи                                                            |
|------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| **Управление покупками**     | Восстановление покупок на уровне стора                          | История покупок сохраняется на всех устройствах через customer user ID                     |
| **Управление профилями**     | Новый профиль при каждой переустановке                          | Один и тот же профиль во всех сессиях и на всех устройствах                                |
| **Сохранность данных**       | Данные анонимного пользователя привязаны к устройству/установке | Данные идентифицированного пользователя сохраняются на всех устройствах и в сессиях        |

## Анонимные пользователи \{#anonymous-users\}

Если у вас нет бэкенд-аутентификации, **обрабатывать аутентификацию в коде приложения не нужно**:

1. При активации SDK на первом запуске приложения Adapty **создаёт новый профиль для пользователя**.
2. Когда пользователь совершает покупку в приложении, она **связывается с его профилем Adapty и аккаунтом в сторе**.
3. При **переустановке** приложения или установке на **новое устройство** Adapty **создаёт новый пустой профиль при активации**.
4. Если пользователь ранее совершал покупки в вашем приложении, по умолчанию они автоматически синхронизируются из App Store при активации SDK.

:::note
Восстановление из резервной копии работает иначе, чем переустановка. По умолчанию при восстановлении из резервной копии SDK сохраняет кешированные данные и не создаёт новый профиль. Это поведение можно настроить с помощью параметра `clearDataOnBackup`. [Подробнее](sdk-installation-capacitor#clear-data-on-backup-restore).
:::

## Идентифицированные пользователи \{#identified-users\}

- Если у профиля ещё нет customer user ID (то есть **пользователь не вошёл в систему**), при передаче customer user ID он будет связан с этим профилем.
- При **переустановке, входе в систему или установке на новое устройство**, если customer user ID уже передавался ранее, новый профиль не создаётся — вместо этого происходит переключение на существующий профиль, связанный с этим customer user ID.

Есть два способа идентифицировать пользователей в приложении:

- [**Во время входа/регистрации:**](#during-loginsignup) Если пользователи входят в систему после запуска приложения, вызовите `identify()` с customer user ID при аутентификации.

- [**При активации SDK:**](#during-the-sdk-activation) Если customer user ID уже известен на момент запуска приложения, передайте его при вызове `activate()`.

:::important
По умолчанию, когда Adapty получает покупку от Customer User ID, который в данный момент связан с другим Customer User ID, уровень доступа предоставляется обоим профилям. Вы можете настроить это поведение так, чтобы платный доступ переносился с одного профиля на другой или чтобы совместный доступ был отключён полностью. Подробнее в [статье](general#6-sharing-paid-access-between-user-accounts).
:::

  <img src="/assets/shared/img/identify-diagram.webp"
  style={{
    border: '1px solid #727272', /* border width and color */
    width: '700px', /* image width */
    display: 'block', /* for alignment */
    margin: '0 auto' /* center alignment */
  }}
/>

### Во время входа/регистрации \{#during-loginsignup\}

Если вы идентифицируете пользователей после запуска приложения (например, после входа в аккаунт или регистрации), используйте метод `identify`, чтобы задать их customer user ID.

- Если вы **ещё не использовали этот customer user ID**, Adapty автоматически свяжет его с текущим профилем.
- Если вы **уже использовали этот customer user ID для идентификации пользователя ранее**, Adapty переключится на работу с профилем, связанным с этим customer user ID.

:::tip
При создании customer user ID сохраните его вместе с данными пользователя, чтобы передавать тот же ID при входе с новых устройств или переустановке приложения.
:::

```typescript showLineNumbers
try {
  await adapty.identify({ customerUserId: "YOUR_USER_ID" });
  // successfully identified
} catch (error) {
  // handle the error
}
```

### При активации SDK \{#during-the-sdk-activation\}

Если customer user ID уже известен на момент активации SDK, его можно передать прямо в методе `activate`, не вызывая `identify` отдельно.

Если customer user ID известен, но передаётся только после активации, это означает, что при активации Adapty создаст новый пустой профиль и переключится на существующий только после вызова `identify`.

Можно передать как существующий customer user ID (уже использованный ранее), так и новый. Если передать новый, созданный при активации профиль будет автоматически связан с этим customer user ID.

:::tip
Чтобы исключить созданные пустые профили из [аналитики](analytics-charts) дашборда, перейдите в **App settings** и настройте [**Installs definition for analytics**](general#4-installs-definition-for-analytics).
:::

```typescript showLineNumbers
await adapty.activate({
  apiKey: "YOUR_PUBLIC_SDK_KEY",
  params: {
    customerUserId: "YOUR_USER_ID"
  }
});
```

### Выход пользователей из системы \{#log-users-out\}

Если в приложении есть кнопка выхода, используйте метод `logout`. При этом для пользователя создаётся новый анонимный ID профиля.

```typescript showLineNumbers
try {
  await adapty.logout();
  // successful logout
} catch (error) {
  // handle the error
}
```

:::info
Для повторного входа пользователя в приложение используйте метод `identify`.
:::

### Разрешение покупок без входа в систему \{#allow-purchases-without-login\}

Если пользователи могут совершать покупки как до, так и после входа в приложение, никакой дополнительной настройки не требуется.

Вот как это работает:
1. Когда пользователь, не вошедший в систему, совершает покупку, Adapty привязывает её к его анонимному ID профиля.
2. Когда пользователь входит в свой аккаунт, Adapty переключается на работу с его идентифицированным профилем.
    - Если это существующий customer user ID (уже связанный с профилем), Adapty автоматически синхронизирует транзакции.
    - Если это новый customer user ID (например, покупка была сделана до регистрации), Adapty присваивает customer user ID текущему профилю, сохраняя всю историю покупок.