Persilsoft.Culqi.Server 1.0.15

There is a newer version of this package available.
See the version list below for details.
dotnet add package Persilsoft.Culqi.Server --version 1.0.15                
NuGet\Install-Package Persilsoft.Culqi.Server -Version 1.0.15                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Persilsoft.Culqi.Server" Version="1.0.15" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Persilsoft.Culqi.Server --version 1.0.15                
#r "nuget: Persilsoft.Culqi.Server, 1.0.15"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Persilsoft.Culqi.Server as a Cake Addin
#addin nuget:?package=Persilsoft.Culqi.Server&version=1.0.15

// Install Persilsoft.Culqi.Server as a Cake Tool
#tool nuget:?package=Persilsoft.Culqi.Server&version=1.0.15                

Persilsoft.Recaptcha.Server

Expone algunos endpoints para interactuar con la API de Culqi durante el proceso de Checkout.


Ejemplo:

Primero, se necesitan registrar los servicios que requiere el Backend:

using Persilsoft.Culqi.Shared.Options;
using ServiceCollectionExtensions;

Action<CulqiOptions> CulqiOptionsConfigurator = options =>
builder.Configuration.GetSection(CulqiOptions.SectionKey).Bind(options);
builder.Services.AddCulqiServices(CulqiOptionsConfigurator);

En el archivo de configuración appsetting.json debe configurar la siguiente entrada:

"Culqi": {
    "PrivateKey": "xxxxxxxxxxxxx",
    "WebApiBaseAddress": "https://api.culqi.com",
    "CreateOrder": "/v2/orders",
    "CreateCharge": "/v2/charges"
}

Donde:
PrivateKey: Es la llave privada proporcionada por Culqi para interactuar con sus servicios.
WebApiBaseAddress: Es la Url base de los servicios de Culqi.
CreateOrder: Es el endpoint de Culqi para crear órdenes.
CreateCharge: Es el endpoint de Culqi para crear cargos.

Para mayor información, puede consultar la documentación de la Api de Culqi en https://apidocs.culqi.com/

Una vez registrados los servicios, necesitamos agregar a la canalización de AspNet Core los endpoints que van a interactuar con la Api de Culqi:

app.UseCulqiEndpoints(requireAuthorization: false);

Nota: Si requiere proteger dichos endpoints a través de un Middleware de autenticación, deberá asignar true al argumento requireAuthorization

Ahora, ya puede probar los Endpoints. Si su WebApi tiene instalado y configurado swagger, podrá visualizarlos: Sin titulo

Crear cargo

Para realizar un cobro a un número telefónico vinculado con Yape o a una tarjeta de débito/crédito, es necesario crear un cargo utilizando un token o una tarjeta. Si utilizas tu llave secreta de integración no se realizarán cargos reales, a diferencia del entorno de producción donde sí se enviará la petición a los bancos y marcas procesadoras.
El objeto Json tiene la siguiente forma:

{
  "amount": 3550,
  "currencyCode": "PEN",
  "email": "juan.perez@persilsoft.com",
  "sourceId": "ype_test_IOmSg3Mue8wtYXgp",
  "capture": true,
  "description": "Por consumo en Inca Pizzas Andinas",
  "installments": null,
  "metadata": {
    "dni": null,
    "celular": null
  },
  "antifraudDetails": {
    "firstName": null,
    "lastName": null,
    "phoneNumber": null,
    "address": null
  }
}

Donde:
amount: Monto del cargo. Sin punto decimal (requerido).
currencyCode: Código de moneda en formato ISO 4217, por ejemplo PEN (requerido).
email: Correo electrónico del cliente (requerido).
sourceId: ID del objeto token, objeto Yape u objeto tarjeta que se va a usar en la creación del cargo (requerido).
capture: Indica si se va a realizar la captura automática de la tarjeta (requerido).
description: Descripción del cargo a realizarse.
installments: Cantidad de cuotas que se van a aplicar al pago. Estas dependen de las cuotas aceptadas por el objeto token.
metadata: Información adicional que se quiere enviar del cargo.
antifraudDetails: Datos de la persona que realiza la compra, para detectar posibles fraudes.

Crear orden

Este proceso permite que se genere un objeto orden con los detalles de la posible venta, la cual se crea con un estado pendiente de pago. Además, al momento de la creación tu cliente recibe un correo con las instrucciones de cómo pagar la orden.
Si una orden es creada con el parámetro confirm en false, esta tendrá que ser confirmada inmediatamente con el método Confirm orden; de los contrario, la orden no podrá ser pagada por tu cliente. Se recomienda crearla sin incluir el parámetro "confirm" para que siga el flujo natural.
El objeto Json tiene la siguiente forma:

{
  "amount": 42500,
  "currencyCode": "PEN",
  "description": "Por consumo en Inca Tratoria",
  "orderNumber": "Orden-00000001",
  "expirationDate": "1713225279",
  "clientDetails": {
    "firstName": "Juan",
    "lastName": "Pérez",
    "email": "juan.perez@persilsoft.com",
    "phoneNumber": "999888777"
  },
  "confirm": true,
  "metadata": {
    "dni": "12345678"
  }
}

Donde:
amount: Monto de la orden. Sin punto decimal (requerido).
currencyCode: Código de moneda en formato ISO 4217, por ejemplo PEN (requerido).
description: Descripción de la orden (requerido).
orderNumber: Número que identifica a la orden. Debe ser único (requerido).
expirationDate: Fecha de expiración de la orden. Debe ser una fecha futura (requerido).
clientDetails: Datos de la persona que realiza la compra (requerido).
confirm: Indica si se debe confirmar la orden (requerido).
metadata: Informacion adicional que se requiera enviar al crear la orden. Ejemplo: "{dni":"12345678"}.

Si ocurre un error al crear un cargo o una orden se lanzará una excepción CreateCulqiChargeException o una excepción CreateCulqiOrderException según sea el caso.
Usted puede implementar un manejador de excepciones personalizado para manejar estas excepciones y formatear la respuesta de manera apropiada o puede registrar los manejadores de excepciones incluidos en este paquete. Adicionalmente, puede agregar el manejador para atrapar cualquier otra excepción no controlada.

builder.Services
    .AddCulquiExceptionHandlers()
    .AddUnhandledExceptionHandler();

builder.Services.Configure<RequestLocalizationOptions>(options =>
{
    var SupportedCultures = new[] { "es-PE", "en-US" };
    var NeutralCulture = SupportedCultures[0];

    options.SetDefaultCulture(NeutralCulture)
    .AddSupportedCultures(SupportedCultures)
    .AddSupportedUICultures(SupportedCultures)
    .ApplyCurrentCultureToResponseHeaders = true;
});

Luego, incluirlos a la canalización de su aplicación AspNet Core.

app.UseRequestLocalization();
app.UseExceptionHandler(builder => { });

Tenga en cuenta que si decide utilizar los manejadores de excepción proporcionados por el paquete, será necesario configurar el middleware de localización. Observe que el middleware de localización se agrega antes que el middleware para manejo de excepciones.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.16 21 1/14/2025
1.0.15 35 1/13/2025
1.0.14 116 10/16/2024
1.0.13 123 7/20/2024
1.0.12 128 5/25/2024
1.0.11 108 5/22/2024
1.0.10 120 5/21/2024
1.0.9 118 5/21/2024
1.0.8 136 5/9/2024
1.0.7 135 5/4/2024
1.0.6 117 4/28/2024
1.0.5 125 4/27/2024
1.0.4 139 4/27/2024
1.0.3 124 4/24/2024
1.0.2 117 4/21/2024
1.0.1 132 4/20/2024
1.0.0 119 4/16/2024