Pular para o conteúdo principal

Inscreva-se para o conteúdo

✅ Propósito do cenário:

  • Apenas usuários com uma assinatura têm acesso ao conteúdo
  • A verificação é baseada em Pedidos, Usuário.
  • Aqueles que não estão autorizados ou não compraram receberão uma oferta para se inscrever.

✅ O que você precisa:

  • Uma PROJECT_URL e APP_TOKEN válidos para autenticação com a API OneEntry.

📌 Importante:

  • Não tratamos erros nesses exemplos.
  • Você pode tratar erros em trycatch ou em uma construção como "await Promise.catch((error) => error)"

Cenário

1. Importe oneEntry e defina a url e o token

Exemplo:

import { defineOneEntry } from 'oneentry';

const PROJECT_URL = 'sua-url-do-projeto';
const APP_TOKEN = 'seu-token-do-app';

2. Criando um cliente API com a função defineOneEntry()

Exemplo:

const { Users, Orders, Pages, Payments, AuthProvider, Forms } = defineOneEntry(PROJECT_URL, {
token: APP_TOKEN,
});

3. Preparando dados para autorização do usuário

Exemplo:

[
{
"marker": "email_reg",
"value": "seu-usuario@email.com"
},
{
"marker": "password_reg",
"value": "123456"
}
]

4. Autorização e obtenção de dados do usuário AuthProvider.auth()

Exemplo:

const authResponse = await AuthProvider.auth('email', {
authData,
});
Resultado:
{
"userIdentifier": "seu-usuario@email.com",
"authProviderIdentifier": "email",
"accessToken": "eyJhbGciOiJIUzI1NiIsInR...pZCI6MTYsImF1dGhQ"
"refreshToken": "1745494429101-...-2834edf8"
}

5. Obtemos uma lista de pedidos do usuário com Orders.getAllOrdersByMarker()

Exemplo:

const orders = await Orders.getAllOrdersByMarker('subscriptions');
Resultado:
{
"items": [
{
"id": 91,
"storageId": 2,
"createdDate": "2025-04-30T21:48:40.628Z",
"statusIdentifier": "active",
"formIdentifier": "subscription",
"formData": [
{
"type": "date",
"marker": "expired_date",
"value": {
"fullDate": "2025-05-07T00:00:00.000Z",
"formattedValue": "07-05-2025 00:00",
"formatString": "DD-MM-YYYY HH:mm"
}
},
{
"type": "list",
"marker": "subscription_time",
"value": [
{
"title": "1 mês",
"value": "1",
"extended": {
"type": "real",
"value": "100"
}
}
]
}
],
"attributeSetIdentifier": "subscriptions",
"totalSum": "100.00",
"currency": "",
"paymentAccountIdentifier": "cash",
"paymentAccountLocalizeInfos": {
"title": "Dinheiro"
},
"products": [
{
"id": 3,
"title": "1 mês",
"sku": "",
"previewImage": null,
"price": 100,
"quantity": 1
}
],
"isCompleted": false
}
],
"total": 1
}

6. Verificando se há uma assinatura ativa

Exemplo:

const now = new Date();
const hasActiveSubscription = orders.items?.some(
(order: any) =>
new Date(
order.formData.find(
(d: { marker: string }) => d.marker === 'expired_date',
).value.fullDate,
) > now,
);
Resultado:
true

7. Se a assinatura estiver ativa, fornecemos acesso, caso contrário, criamos um pedido e geramos o pagamento

Exemplo:

let content = null;
if (hasActiveSubscription) {
// ✅ Assinatura ativa → mostrar conteúdo
content = await Pages.getPageByUrl('premium_page');
console.log('🎉 Acesso aberto:', content);
} else {
// ❌ Sem assinatura → criar um pedido e gerar pagamento
const body = {
formIdentifier: 'subscription',
paymentAccountIdentifier: 'cash',
formData: [
{
type: 'date',
marker: 'expired_date',
value: {
fullDate: '2025-05-07T00:00:00.000Z',
formattedValue: '07-05-2025 00:00',
formatString: 'DD-MM-YYYY HH:mm',
},
},
{
type: 'list',
marker: 'subscription_time',
value: [
{
title: '1 mês',
value: '1',
extended: {
type: 'real',
value: '100',
},
},
],
},
],
products: [
{
productId: 3,
quantity: 1,
},
],
};
const order = await Orders.createOrder('subscriptions', body);
const payment = await Payments.createSession(order.id, 'session', false);
// console.log('💸 Prossiga para pagar sua assinatura:', payment)
}
Resultado:
{
"id": 7,
"parentId": null,
"pageUrl": "premium_page",
"depth": 0,
"localizeInfos": {
"title": "Página Premium",
"menuTitle": "Página Premium",
"htmlContent": "",
"plainContent": ""
},
"isVisible": true,
"forms": [],
"blocks": [],
"type": "common_page",
"templateIdentifier": null,
"attributeSetIdentifier": null,
"attributeValues": {},
"isSync": false
}

Exemplo final

// 1. Importe oneEntry e defina PROJECT_URL e APP_TOKEN
import { defineOneEntry } from 'oneentry';

const PROJECT_URL = 'sua-url-do-projeto';
const APP_TOKEN = 'seu-token-do-app';

// 2. Criando um cliente API
const { Users, Orders, Pages, Payments, AuthProvider, Forms } =
defineOneEntry(PROJECT_URL, {
token: APP_TOKEN,
});

// 3. Preparando dados para autorização do usuário
// const form = await Forms.getFormByMarker('subscription');
// expired_date - Data
// subscription_time - lista

const authData = [
{
marker: 'email_reg',
value: 'seu-usuario@email.com',
},
{
marker: 'password_reg',
value: '123456',
},
];

// 4. Autorização e obtenção de dados do usuário
const authResponse = await AuthProvider.auth('email', {
authData,
});
const user = await Users.getUser();

// 5. Obtemos uma lista de pedidos do usuário
const orders = await Orders.getAllOrdersByMarker('subscriptions');

// 6. Verificando se há uma assinatura ativa
const now = new Date();
const hasActiveSubscription = orders.items?.some(
(order: any) =>
new Date(
order.formData.find(
(d: { marker: string }) => d.marker === 'expired_date',
).value.fullDate,
) > now,
);

// 7. Se a assinatura estiver ativa, fornecemos acesso, caso contrário, criamos um pedido e geramos o pagamento
let content = null;
if (hasActiveSubscription) {
// ✅ Assinatura ativa → mostrar conteúdo
content = await Pages.getPageByUrl('premium_page');
console.log('🎉 Acesso aberto:', content);
} else {
// ❌ Sem assinatura → criar um pedido e gerar pagamento
const body = {
formIdentifier: 'subscription',
paymentAccountIdentifier: 'cash',
formData: [
{
type: 'date',
marker: 'expired_date',
value: {
fullDate: '2025-05-07T00:00:00.000Z',
formattedValue: '07-05-2025 00:00',
formatString: 'DD-MM-YYYY HH:mm',
},
},
{
type: 'list',
marker: 'subscription_time',
value: [
{
title: '1 mês',
value: '1',
extended: {
type: 'real',
value: '100',
},
},
],
},
],
products: [
{
productId: 3,
quantity: 1,
},
],
};
const order = await Orders.createOrder('subscriptions', body);
const payment = await Payments.createSession(order.id, 'session', false);
console.log('💸 Prossiga para pagar sua assinatura:', payment);
}