Moibe commited on
Commit
5cfc6de
·
1 Parent(s): 1babf99

Función Principal crear sesión

Browse files
Files changed (4) hide show
  1. autenticacion.py +2 -2
  2. bridges..py +1 -0
  3. funciones.py +59 -1
  4. requirements.txt +1 -1
autenticacion.py CHANGED
@@ -4,8 +4,8 @@ import socket
4
  def defineAmbiente():
5
  if local_check():
6
  print("Entorno Local...")
7
- import bridges
8
- llave = bridges.llave #Acceso a HF
9
  servidor = "moibe" #o Sosa Jhons, depende de donde deduciras el tiempo de gpu cuando pruebas en local.
10
  else:
11
  print("Entorno remoto listo...")
 
4
  def defineAmbiente():
5
  if local_check():
6
  print("Entorno Local...")
7
+ #import bridges
8
+ #llave = bridges.llave #Acceso a HF
9
  servidor = "moibe" #o Sosa Jhons, depende de donde deduciras el tiempo de gpu cuando pruebas en local.
10
  else:
11
  print("Entorno remoto listo...")
bridges..py ADDED
@@ -0,0 +1 @@
 
 
1
+ #Bridges
funciones.py CHANGED
@@ -11,4 +11,62 @@ def funcion_generica(platillo):
11
  print("Excepción: ", e)
12
  # Opción para regresar imagen genérica. (ya no porque se envía desde backend.)
13
  # return "default.png"
14
- return '{"Error 500": e}'
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
11
  print("Excepción: ", e)
12
  # Opción para regresar imagen genérica. (ya no porque se envía desde backend.)
13
  # return "default.png"
14
+ return '{"Error 500": e}'
15
+
16
+ def create_checkout_session(price_id, customer_email=None, customer_id=None):
17
+ """
18
+ Crea una nueva Checkout Session para un pago único.
19
+
20
+ Args:
21
+ price_id (str): El ID del precio en Stripe para el artículo que se va a comprar.
22
+ customer_email (str, opcional): Email para pre-rellenar o asociar con un cliente existente.
23
+ customer_id (str, opcional): ID de un cliente existente en Stripe para asociar la sesión.
24
+
25
+ Returns:
26
+ str: La URL de la Checkout Session, o None si hay un error.
27
+ """
28
+ print("Estoy en create checkout session y el customer ID es: ", customer_id)
29
+ try:
30
+ session_params = {
31
+ 'line_items': [{
32
+ 'price': price_id,
33
+ 'quantity': 1,
34
+ }],
35
+ 'mode': 'payment', # Para pagos únicos (one-time payment)
36
+ 'success_url': 'https://tudominio.com/gracias?session_id={CHECKOUT_SESSION_ID}',
37
+ 'cancel_url': 'https://tudominio.com/cancelar',
38
+ 'locale': 'es', # Establece el idioma del checkout a español
39
+ 'client_reference_id': 'Moibe'
40
+ }
41
+
42
+ # Opciones para el cliente
43
+ if customer_id:
44
+ session_params['customer'] = customer_id
45
+ elif customer_email:
46
+ session_params['customer_email'] = customer_email
47
+ else:
48
+ # Si no se provee ni customer_id ni customer_email, Stripe puede crear uno si es necesario
49
+ # O podrías pedir el email en el formulario de Checkout.
50
+ pass
51
+
52
+ # Opcional: Agregar información de envío si aplica (para productos físicos)
53
+ # session_params['shipping_address_collection'] = {'allowed_countries': ['US', 'CA', 'MX']}
54
+
55
+ # Opcional: Permitir códigos promocionales
56
+ # session_params['allow_promotion_codes'] = True
57
+
58
+ # Opcional: Agregar metadata a la sesión (no al pago final directamente, pero útil para webhooks)
59
+ # session_params['metadata'] = {'order_id': 'ORD12345', 'user_id': 'user_abc'}
60
+
61
+ session = stripe.checkout.Session.create(**session_params)
62
+
63
+ print(f"Checkout Session creada exitosamente. ID: {session.id}")
64
+ print(f"URL de redirección: {session.url}")
65
+ return session.url
66
+
67
+ except stripe.error.StripeError as e:
68
+ print(f"Error de Stripe al crear la Checkout Session: {e}")
69
+ return None
70
+ except Exception as e:
71
+ print(f"Ocurrió un error inesperado al crear la Checkout Session: {e}")
72
+ return None
requirements.txt CHANGED
@@ -1,6 +1,6 @@
1
  fastapi
2
  fastapi[standard]
3
  gradio_client
4
- Pillow
5
  firebase_admin
6
  pytz
 
1
  fastapi
2
  fastapi[standard]
3
  gradio_client
4
+ stripe
5
  firebase_admin
6
  pytz