Pedido de ingressos
Neste exemplo, demonstramos como solicitar ingressos para um evento usando a API OneEntry.
✅ Propósito do cenário:
- O usuário faz login com suas credenciais
- Seleciona o tipo de ingresso, data e hora da programação
- Paga pelo pedido e recebe um ingresso por e-mail
✅ O que você precisa:
- Um PROJECT_URL e APP_TOKEN válidos para autenticação com a API OneEntry.
- Usuário registrado para autenticação
- Formulário com marcador "tickets_form" e campos "schedule" e "tickets"
- Armazenamento de pedidos configurado com marcador "tickets"
📌 Importante:
- Esses exemplos não incluem tratamento de erros.
- Você pode gerenciar erros usando um bloco try-catch ou empregando uma construção como await Promise.catch((error) => error).
Cenário
1. Importar defineOneEntry do SDK e definir url e token
Exemplo:
import { defineOneEntry } from 'oneentry';
const PROJECT_URL = 'your-project-url';
const APP_TOKEN = 'your-app-token';
2. Criando um cliente API com a função defineOneEntry()
Exemplo:
const { AuthProvider, Forms, Orders, Payments } = defineOneEntry(PROJECT_URL, {
token: APP_TOKEN,
});
3. Autorização do usuário com AuthProvider.auth()
Dados:
[
{
"marker": "email_reg",
"value": "your-user@email.com"
},
{
"marker": "password_reg",
"value": "123456"
}
]
Exemplo:
const authResponse = await AuthProvider.auth('email', {
authData,
});
Resultado:
{
"userIdentifier": "your-user@email.com",
"authProviderIdentifier": "email",
"accessToken": "eyJhbGciOiJIUzI1NiIsInR...pZCI6MTYsImF1dGhQ"
"refreshToken": "1745494429101-...-2834edf8"
}
4. Recebemos os dados do formulário da Plataforma OneEntry com Forms.getFormByMarker() para gerar um formulário no frontend
Exemplo:
const formData = await Forms.getFormByMarker('tickets_form');
Resultado:
{
"id": 9,
"attributeSetId": 12,
"type": "order",
"localizeInfos": {
"title": "Ingressos",
"titleForSite": "Ingressos",
"successMessage": "",
"unsuccessMessage": "",
"urlAddress": "",
"database": "0",
"script": "0"
},
"version": 6,
"position": 1,
"identifier": "tickets_form",
"processingType": "script",
"templateId": null,
"attributes": [
{
"type": "timeInterval",
"marker": "schedule",
"isLogin": null,
"isSignUp": null,
"position": 1,
"settings": {},
"isVisible": true,
"listTitles": [],
"validators": {},
"localizeInfos": {
"title": "Programação",
"intervals": [
{
"id": "ef9cf848-7373-4b81-98bd-7ad33aa951e2",
"range": [
"2025-04-26T21:00:00.000Z",
"2025-04-26T21:00:00.000Z"
],
"external": [],
"intervals": [
{
"id": "f2042e47-c650-4fc6-ae1c-efdb109b450f",
"end": {
"hours": 21,
"minutes": 30
},
"start": {
"hours": 16,
"minutes": 30
},
"period": 90
}
],
"inEveryWeek": true,
"inEveryMonth": true
}
]
},
"additionalFields": [],
"isNotificationEmail": null,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
},
{
"type": "entity",
"marker": "tickets",
"isLogin": null,
"isSignUp": null,
"position": 2,
"settings": {},
"isVisible": true,
"listTitles": [
{
"id": 8,
"depth": 0,
"title": "Ingressos",
"parentId": null,
"position": "0|hzzzz3:"
},
{
"id": "p-8-10",
"depth": 1,
"title": "Bronze",
"parentId": 8,
"position": 1,
"selected": true
},
{
"id": "p-8-11",
"depth": 1,
"title": "Prata",
"parentId": 8,
"position": 2,
"selected": true
},
{
"id": "p-8-12",
"depth": 1,
"title": "Ouro",
"parentId": 8,
"position": 3,
"selected": true
}
],
"validators": {
"requiredValidator": {
"strict": true
}
},
"localizeInfos": {
"title": "Ingressos"
},
"additionalFields": [],
"isNotificationEmail": null,
"isNotificationPhoneSMS": null,
"isNotificationPhonePush": null
}
],
"moduleFormConfigs": []
}
5. Criação de um pedido no armazenamento de pedidos com Orders.createOrder()
Dados:
{
"formIdentifier": "tickets_form",
"paymentAccountIdentifier": "cash",
"formData": {
"en_US": [
{
"type": "entity",
"marker": "tickets",
"value": [
"p-8-10"
]
}
]
},
"products": [
{
"productId": 10,
"quantity": 1
}
]
}