Fix: Pass user email to subscription function

The AI corrected the `Assinatura` page to pass the user's email and ID in the request body when calling the `mercado-pago-subscribe` Supabase function, resolving the "E-mail ou ID do usuário não fornecido" error.
This commit is contained in:
gpt-engineer-app[bot] 2025-06-22 02:41:51 +00:00
parent 490404d22b
commit a9ab6d566f
2 changed files with 42 additions and 16 deletions

View File

@ -1,3 +1,4 @@
import { useState } from "react";
import { Button } from "@/components/ui/button";
import { ArrowLeft, Check } from "lucide-react";
@ -29,37 +30,46 @@ const Assinatura = () => {
console.log('🔄 [ASSINATURA] Iniciando processo de assinatura...');
// Verificar sessão do usuário
const { data: { user }, error: userError } = await supabase.auth.getUser();
const { data: { session }, error: sessionError } = await supabase.auth.getSession();
if (userError) {
console.error('❌ [ASSINATURA] Erro de autenticação:', userError);
if (sessionError) {
console.error('❌ [ASSINATURA] Erro ao obter sessão:', sessionError);
toast.error("Erro de autenticação. Faça login novamente.");
return;
}
if (!user || !user.id || !user.email) {
console.error('❌ [ASSINATURA] Usuário não autenticado');
if (!session || !session.user || !session.user.id || !session.user.email) {
console.error('❌ [ASSINATURA] Usuário não autenticado ou dados incompletos');
toast.error("Sessão inválida. Por favor, faça login novamente.");
return;
}
const { user } = session;
console.log('✅ [ASSINATURA] Usuário autenticado:', { id: user.id, email: user.email });
// Preparar dados para envio
const requestData = {
email: user.email,
userId: user.id
};
console.log('📦 [ASSINATURA] Dados a serem enviados:', requestData);
// Chamar a função do MercadoPago
console.log('📞 [ASSINATURA] Chamando função mercado-pago-subscribe...');
const { data, error } = await supabase.functions.invoke('mercado-pago-subscribe', {
body: {
email: user.email,
userId: user.id
},
body: requestData,
method: 'POST'
});
console.log('📨 [ASSINATURA] Resposta da função:', { data, error });
if (error) {
console.error('❌ [ASSINATURA] Erro na função:', error);
// Tratar diferentes tipos de erro
if (error.message?.includes('FunctionsHttpError')) {
toast.error("Erro de comunicação. Verifique sua conexão e tente novamente.");
toast.error("Erro de comunicação com o servidor. Tente novamente.");
} else if (error.message?.includes('FunctionsRelayError')) {
toast.error("Serviço temporariamente indisponível. Tente novamente em alguns instantes.");
} else if (error.message?.includes('fetch')) {

View File

@ -15,32 +15,48 @@ serve(async (req) => {
try {
console.log('🚀 Iniciando processamento da assinatura MercadoPago');
console.log('📋 Método da requisição:', req.method);
console.log('📋 Headers da requisição:', Object.fromEntries(req.headers.entries()));
// Verificar se há dados no corpo da requisição
let requestBody;
try {
const text = await req.text();
requestBody = text ? JSON.parse(text) : {};
console.log('📦 Corpo da requisição:', requestBody);
console.log('📦 Texto bruto recebido:', text);
if (!text || text.trim() === '') {
console.error('❌ Corpo da requisição está vazio');
return new Response(JSON.stringify({ error: 'Dados da requisição não fornecidos.' }), {
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
status: 400,
});
}
requestBody = JSON.parse(text);
console.log('📦 Corpo da requisição parseado:', requestBody);
} catch (parseError) {
console.error('❌ Erro ao fazer parse do JSON:', parseError);
return new Response(JSON.stringify({ error: 'Dados da requisição inválidos.' }), {
return new Response(JSON.stringify({ error: 'Formato de dados inválido.' }), {
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
status: 400,
});
}
// Extrair email e userId do corpo da requisição
const { email, userId } = requestBody;
console.log('📧 Dados extraídos:', { email, userId });
if (!email || !userId) {
console.error('❌ Email ou ID do usuário não fornecido');
console.error('❌ Dados recebidos:', { email, userId });
return new Response(JSON.stringify({ error: 'E-mail ou ID do usuário não fornecido.' }), {
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
status: 400,
});
}
console.log('📧 Dados recebidos:', { email, userId });
console.log('📧 Dados validados com sucesso:', { email, userId });
// Cria um cliente Supabase com a service_role_key para verificar o usuário
const supabaseAdmin = createClient(
@ -59,7 +75,7 @@ serve(async (req) => {
if (userError) {
console.error('❌ Erro ao buscar usuário:', userError);
return new Response(JSON.stringify({ error: 'Usuário não encontrado.' }), {
return new Response(JSON.stringify({ error: 'Usuário não encontrado no sistema.' }), {
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
status: 404,
});
@ -67,7 +83,7 @@ serve(async (req) => {
if (!userData) {
console.error('❌ Usuário não encontrado no banco');
return new Response(JSON.stringify({ error: 'Usuário não encontrado.' }), {
return new Response(JSON.stringify({ error: 'Usuário não encontrado no sistema.' }), {
headers: { ...corsHeaders, 'Content-Type': 'application/json' },
status: 404,
});