Persilsoft.Culqi.Server
1.0.15
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
<PackageReference Include="Persilsoft.Culqi.Server" Version="1.0.15" />
paket add Persilsoft.Culqi.Server --version 1.0.15
#r "nuget: Persilsoft.Culqi.Server, 1.0.15"
// 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:
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 | Versions 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. |
-
net8.0
- Persilsoft.Culqi.Shared (= 1.0.3)
- Persilsoft.Exceptions (= 1.0.14)
- Persilsoft.OperationResult (= 1.0.4)
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 |