Chargily.Pay
2.0.3
dotnet add package Chargily.Pay --version 2.0.3
NuGet\Install-Package Chargily.Pay -Version 2.0.3
<PackageReference Include="Chargily.Pay" Version="2.0.3" />
paket add Chargily.Pay --version 2.0.3
#r "nuget: Chargily.Pay, 2.0.3"
// Install Chargily.Pay as a Cake Addin #addin nuget:?package=Chargily.Pay&version=2.0.3 // Install Chargily.Pay as a Cake Tool #tool nuget:?package=Chargily.Pay&version=2.0.3
Welcome to C# Package Repository
for Chargily Pay™ Gateway - V2.
Thank you for your interest in C# Package of Chargily Pay™, an open source project by Chargily, a leading fintech company in Algeria specializing in payment solutions and e-commerce facilitating, this Package is providing the easiest and free way to integrate e-payment API through widespread payment methods in Algeria such as EDAHABIA (Algerie Post) and CIB (SATIM) into your C#/ASP.NET projects.
This package is developed by Ahmed Chakhoum (rainxh11) and is open to contributions from developers like you.
Nuget Pacakge | Downloads |
---|---|
Chargily.Pay: <br/> | |
Chargily.Pay.AspNet:<br/> |
Support with the various .NET Project-types:
Only .NET6.0
and newer versions are supported.
NOTE: Ability to receive checkout status with Webhook endpoint is only possible with project types that can host an HTTP Server.
Documentations Summary:
Installation:
Using DotNet CLI :
dotnet add Chargily.Pay
Getting Started:
- First create & configure a client:
using Chargily.Pay;
var chargilyClient = ChargilyPay.CreateResilientClient(config =>
{
// toggle live mode
config.IsLiveMode = false;
// your chargily dev account api-secret key
config.ApiSecretKey = "YOUR API SECRET";
});
- Create a Product:
var createProduct = new CreateProduct()
{
Name = "Product Name",
ImagesUrls = new List<Uri>()
{
new Uri("https://domain.com/image.png")
},
Description = "Product Description",
};
var product = await _chargilyPayClient.AddProduct(createProduct);
- Add Price for the Product:
var createPrice = new CreatePrice()
{
Amount = 3000,
Currency = Currency.DZD,
ProductId = product.Value.Id,
};
var productPrice = await chargilyClient.AddPrice(createPrice);
- Create a checkout:
var checkoutItems = new List<CheckoutPriceItem>()
{
new CheckoutPriceItem()
{
Quantity = 1,
PriceId = productPrice.Value.Id
}
};
var createCheckout = new Checkout(checkoutItems)
{
Description = "Checkout Description",
Language = LocaleType.Arabic,
PaymentMethod = PaymentMethod.EDAHABIA,
PassFeesToCustomer = true,
WebhookEndpointUrl = new Uri("https://domain.com/webhook/endpoint"),
OnFailureRedirectUrl = new Uri("https://webapp.com/checkout/fail"),
OnSuccessRedirectUrl = new Uri("https://webapp.com/checkout/success"),
CollectShippingAddress = false,
};
var checkout = await chargilyClient.CreateCheckout(createCheckout);
Create a checkout without Product & Price:
var createCheckout = new Checkout(amount: 3000, Currency.DZD)
{
Description = "Checkout Description",
Language = LocaleType.Arabic,
PaymentMethod = PaymentMethod.EDAHABIA,
PassFeesToCustomer = true,
WebhookEndpointUrl = new Uri("https://domain.com/webhook/endpoint"),
OnFailureRedirectUrl = new Uri("https://webapp.com/checkout/fail"),
OnSuccessRedirectUrl = new Uri("https://webapp.com/checkout/success"),
CollectShippingAddress = false,
};
var fastCheckout = await chargilyClient.CreateCheckout(createCheckout);
NOTE: Checkout can be created with list of prices or using an amount + currency.
Create a Payment Link for a product:
var createProduct = new CreateProduct()
{
/* ... */
};
var product = await _chargilyPayClient.AddProduct(createProduct);
var createPrice = new CreatePrice()
{
/* ... */
};
var productPrice = await chargilyClient.AddPrice(createPrice);
// above steps are similar to how to create a checkout
var paymentLinkItems = new List<PaymentLinkPriceItem>()
{
new PaymentLinkPriceItem()
{
AdjustableQuantity = true,
PriceId = productPrice.Value.Id,
Quantity = 2
}
};
var createPaymentLink = new CreatePaymentLink(paymentLinkItems)
{
Language = LocaleType.Arabic,
PassFeesToCustomer = true,
CollectShippingAddress = false,
Name = "Name",
CompletionMessage = "completion message",
IsActive = true
};
Create a Customer:
- Support for Customers also added in V2, and can be added to checkout also:
var createCustomer = new CreateCustomer()
{
Name = "Customer Name",
Address = new CustomerAddress()
{
Address = "Address",
Country = Country.Algeria,
State = "Alger"
},
Email = "user@email.com",
Phone = "+2130601010101"
};
var customer = await chargilyClient.AddCustomer(createCustomer);
var createCheckout = new Checkout(amount: 3000, Currency.DZD)
{
CustomerId = customer.Value.Id,
/* .... */
};
var fastCheckout = await chargilyClient.CreateCheckout(createCheckout);
Retrieve Balance Wallets:
- Balance Wallets are refreshed automatically, to check current balance:
foreach (var wallet in chargilyClient.Balance)
{
/* ... */
}
- Configuring how often balance wallets are refreshed:
using Chargily.Pay;
var chargilyClient = ChargilyPay.CreateResilientClient(config =>
{
/* ... */
// refresh balance every 30 seconds
config.BalanceRefreshInterval = TimeSpan.FromSeconds(30);
});
- Or get balance manually:
var balance = await chargilyClient.GetBalance();
How to Retrieve Data:
Products:
// by id
var byId = await chargilyClient.GetProduct("id");
// by page number & page size
var products = await chargilyClient.GetProducts(page: 1, pageSize: 50);
// or iterate through all items using `Async Enumerable async foreach`
await foreach(var product in chargilyClient.Products())
{
/* ... */
}
Delete Product:
await chargilyClient.DeleteProduct("01hrtc39vq463jhnemv0q33mcq");
Prices:
// by id
var byId = await chargilyClient.GetPrice("id");
// by page number & page size
var prices = await chargilyClient.GetPrices(page: 1, pageSize: 50);
// or iterate through all items using `IAsyncEnumerable async foreach`
await foreach(var price in chargilyClient.Prices())
{
/* ... */
}
Customers:
// by id
var byId = await chargilyClient.GetCustomer("id");
// by page number & page size
var customers = await chargilyClient.GetCustomers(page: 1, pageSize: 50);
// or iterate through all items using `IAsyncEnumerable async foreach`
await foreach(var customer in chargilyClient.Customers())
{
/* ... */
}
Delete Customer:
await chargilyClient.DeleteCustomer("01hrsfjgvfvv1007y54y8fph1v");
Checkouts:
// by id
var byId = await chargilyClient.GetCheckout("id");
// by page number & page size
var checkouts = await chargilyClient.GetCheckouts(page: 1, pageSize: 50);
// or iterate through all items using `IAsyncEnumerable async foreach`
await foreach(var checkout in chargilyClient.Checkouts())
{
/* ... */
}
Checkout Items:
var checkoutItems = await chargilyClient.GetCheckoutItems("checkoutId");
Payment Links:
// by id
var byId = await chargilyClient.GetPaymentLink("id");
// by page number & page size
var paymentLinks = await chargilyClient.GetPaymentLinks(page: 1, pageSize: 50);
// or iterate through all items using `IAsyncEnumerable async foreach`
await foreach(var paymentLink in chargilyClient.PaymentLinks())
{
/* ... */
}
Payment Links Items:
var paymentLinksItems = await chargilyClient.GetPaymentLinkItems("paymentLinkId");
Usage with ASP.NET WebApi:
Install Chargily.Pay.AspNet
Nuget Package:
dotnet add Chargily.Pay.AspNet
Example Usage:
using Chargily.Pay;
using Chargily.Pay.AspNet;
var builder = WebApplication.CreateBuilder(args);
builder.Services
// Register Chargily Pay Client
.AddGlobalChargilyPayClient(config =>
{
// toggle live mode
config.IsLiveMode = false;
// your chargily dev account api-secret key
config.ApiSecretKey = "YOUR API SECRET";
})
// Register Chargily Pay Webhook Signature Validator
.AddChargilyPayWebhookValidationMiddleware();
var app = builder.Build();
// User Chargily Pay Webhook Signature Validator Middleware
app.UseChargilyPayWebhookValidation();
// Map Webhook Endpoint to `both POST & GET /api/checkout-webhook`
app.MapChargilyPayWebhookEndpoint("/chargily/webhook", async (webhookContext) =>
{
// you can access the webhook body, http context, validation result
if (webhookContext.SignatureIsValid)
{
var body = webhookContext.Request;
/* do something with the webhook request body */
}
});
app.Run();
Webhook Signature Validation
In the above example, the Chargily.Pay.AspNet
provides built-in webhook signature validator middleware, you can register it with builder.Services.AddChargilyPayWebhookValidationMiddleware()
then use it with app.UseChargilyPayWebhookValidation()
.
It will validate any POST
request that have a header name: signature
. You can override the header name with app.UseChargilyPayWebhookValidation("another_name")
.
Also built-in a minimal-webapi endpoint that can be registered with app.MapChargilyPayWebhookEndpoint()
, and use it to access the webhook body without manually handling the validation.
About Chargily Pay™ packages
Chargily Pay™ packages/plugins are a collection of open source projects published by Chargily to facilitate the integration of our payment gateway into different programming languages and frameworks. Our goal is to empower developers and businesses by providing easy-to-use tools to seamlessly accept payments.
API Documentation
For detailed instructions on how to integrate with our API and utilize Chargily Pay™ in your projects, please refer to our API Documentation.
Developers Community
Join our developer community on Telegram to connect with fellow developers, ask questions, and stay updated on the latest news and developments related to Chargily Pay™ : Telegram Community
How to Contribute
We welcome contributions of all kinds, whether it's bug fixes, feature enhancements, documentation improvements, or new plugin/package developments. Here's how you can get started:
Fork the Repository: Click the "Fork" button in the top-right corner of this page to create your own copy of the repository.
Clone the Repository: Clone your forked repository to your local machine using the following command:
git clone https://github.com/Chargily/chargily-pay-csharp.git
Make Changes: Make your desired changes or additions to the codebase. Be sure to follow our coding standards and guidelines.
Test Your Changes: Test your changes thoroughly to ensure they work as expected.
Submit a Pull Request: Once you're satisfied with your changes, submit a pull request back to the main repository. Our team will review your contributions and provide feedback if needed.
Get in Touch
Have questions or need assistance? Join our developer community on Telegram and connect with fellow developers and our team.
We appreciate your interest in contributing to Chargily Pay™! Together, we can build something amazing.
Happy coding!
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. 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. |
-
net6.0
- AutoMapper (>= 13.0.1)
- FluentValidation (>= 11.11.0)
- FluentValidation.DependencyInjectionExtensions (>= 11.11.0)
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- Microsoft.Extensions.Caching.Memory (>= 8.0.1)
- Microsoft.Extensions.DependencyInjection (>= 8.0.1)
- Microsoft.Extensions.Logging (>= 8.0.1)
- Microsoft.Extensions.Logging.Debug (>= 8.0.1)
- Polly (>= 8.5.0)
- Refit (>= 8.0.0)
- Refit.HttpClientFactory (>= 8.0.0)
- System.Reactive (>= 6.0.1)
-
net8.0
- AutoMapper (>= 13.0.1)
- FluentValidation (>= 11.11.0)
- FluentValidation.DependencyInjectionExtensions (>= 11.11.0)
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- Microsoft.Extensions.Caching.Memory (>= 8.0.1)
- Microsoft.Extensions.DependencyInjection (>= 8.0.1)
- Microsoft.Extensions.Logging (>= 8.0.1)
- Microsoft.Extensions.Logging.Debug (>= 8.0.1)
- Polly (>= 8.5.0)
- Refit (>= 8.0.0)
- Refit.HttpClientFactory (>= 8.0.0)
- System.Reactive (>= 6.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Chargily.Pay:
Package | Downloads |
---|---|
Chargily.Pay.AspNet
AspNet WebApi Extension Library for C#.NET Library for Chargily Pay™ Gateway - V2 |
GitHub repositories
This package is not used by any popular GitHub repositories.