Регистрация пользователя
В этом примере мы демонстрируем, как зарегистрировать нового пользователя с помощью API OneEntry.
✅ Цель сценария:
- Мы получаем форму регистрации для генерации фронтенд-формы
- Пользователь вводит необходимые данные и регистрируется.
- После регистрации пользователь получает код актива ции по электронной почте/СМС
- Пользователь вводит код активации и активирует созданного пользователя.
✅ Что вам нужно:
- Действительный PROJECT_URL и APP_TOKEN для аутентификации с API OneEntry.
- Форма регистрации с маркером "reg"
- Поля формы (атрибуты) с маркерами "email_reg", "password_reg", "name_reg", "phone_reg"
- Действительный адрес электронной почты/номер телефона для получения кода активации
📌 Важно:
- Мы не обрабатываем ошибки в этих примерах.
- Вы можете обрабатывать ошибки в конструкции trycatch или в конструкции типа "await Promise.catch((error) => error)"
Сценарий
1. Импортируйте oneEntry и определите url и токен
Пример:
import { defineOneEntry } from 'oneentry';
const PROJECT_URL = 'your-project-url';
const APP_TOKEN = 'your-app-token';
2. Создание API-клиента с помощью функции defineOneEntry()
Пример:
const { Forms, FormData } = defineOneEntry(PROJECT_URL, {
token: APP_TOKEN,
});
3. Мы получаем форму регистрации с помощью Forms.getFormByMarker() для генерации фронтенд-формы
Пример:
const form = await Forms.getFormByMarker('reg');
Результат:
{
"id": 4,
"attributeSetId": 5,
"type": "sing_in_up",
"localizeInfos": {
"title": "Регистрация",
"titleForSite": "",
"successMessage": "",
"unsuccessMessage": "",
"urlAddress": "",
"database": "0",
"script": "0"
},
"version": 0,
"position": 1,
"identifier": "reg",
"processingType": "script",
"templateId": null,
"attributes": [
{
"type": "string",
"marker": "email_reg",
"isLogin": true,
"isSignUp": false,
"position": 1,
"settings": {},
"isVisible": true,
"listTitles": [],
"validators": {
"requiredValidator": {
"strict": true
},
"emailInspectionValidator": true
},
"localizeInfos": {
"title": "E-mail"
},
"additionalFields": [],
"isNotificationEmail": false,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
},
{
"type": "string",
"marker": "name_reg",
"isLogin": null,
"isSignUp": true,
"position": 2,
"settings": {},
"isVisible": true,
"listTitles": [],
"validators": {
"requiredValidator": {
"strict": true
}
},
"localizeInfos": {
"title": "Имя"
},
"additionalFields": [],
"isNotificationEmail": false,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
},
{
"type": "string",
"marker": "phone_reg",
"isLogin": null,
"isSignUp": true,
"position": 3,
"settings": {},
"isVisible": true,
"listTitles": [],
"validators": {
"requiredValidator": {
"strict": true
}
},
"localizeInfos": {
"title": "Телефон"
},
"additionalFields": [],
"isNotificationEmail": false,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
},
{
"type": "string",
"marker": "password_reg",
"isLogin": null,
"isSignUp": null,
"position": 4,
"settings": {},
"isVisible": true,
"listTitles": [],
"validators": {
"requiredValidator": {
"strict": true
},
"stringInspectionValidator": {
"stringMax": 0,
"stringMin": 0,
"stringLength": 0
}
},
"localizeInfos": {
"title": "Пароль"
},
"additionalFields": [],
"isNotificationEmail": false,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
},
{
"type": "string",
"marker": "email_notification_reg",
"isLogin": null,
"isSignUp": null,
"position": 5,
"settings": {},
"isVisible": true,
"listTitles": [],
"validators": {},
"localizeInfos": {
"title": "email для уведомления"
},
"additionalFields": [],
"isNotificationEmail": true,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
}
]
}