در قسمت قبل، با تنظیمات پَرباد آشنا شدیم. در این مقاله قصد داریم سایر امکانات قابل استفاده را آموزش دهیم.
آنچه شما در این مقاله یاد خواهید گرفت:
- ایجاد صورت حساب پرداخت با استفاده از InvoiceBuilder
- درگاه مجازی
- استفاده از پروکسی
- توکن پرداخت
- تزریق وابستگی
- Logging
ایجاد صورت حساب با استفاده از InvoiceBuilder
InvoiceBuilder به شما کمک میکند تا یک صورت حساب را جهت پرداخت آماده کنید.
مثال زیر را در نظر بگیرید:
var result = _onlinePayment.Request(Gateways.Mellat, 123, 25000, "http://www.mywebsite.com/foo/bar/");
اما همین دستور را با کمک InvoiceBuilder نیز میتوان ایجاد کرد.
نمونه مثال بالا با استفاده از InvoiceBuilder
var result = _onlinePayment.Request(invoice => { invoice .SetTrackingNumber(123) .SetAmount(25000) .SetCallbackUrl("http://www.mywebsite.com/foo/bar/") .UseGateway(Gateways.Mellat); });
در زیر نمونههایی از کارایی آن را بررسی میکنیم.
- تولید اتوماتیک کد رهگیری به صورت افزایشی
- تولید اتوماتیک کد رهگیری به صورت تصادفی
- ایجاد یک تولید کننده کد رهگیری توسط شما
- صورت حساب سفارشی برای امکانات اختصاصی درگاههای بانکی
تولید اتوماتیک کد رهگیری به صورت افزایشی
در این روش، کد رهگیری (TrackingNumber) که مورد نیاز درگاههای بانکی است، به صورت اتوماتیک در هنگام ایجاد درخواست پرداخت، توسط پَرباد تولید میشود.
var result = _onlinePayment.Request(invoice => { invoice .UseAutoIncrementTrackingNumber() .SetAmount(25000) .SetCallbackUrl("http://www.mywebsite.com/foo/bar/") .UseGateway(Gateways.Mellat); });
کد تولید شده، به صورت افزایشی است. در واقع در هر درخواست پرداخت جدید، یک
کد رهگیری تولید میشود که یک واحد از کد تولید شدهی قبلی بیشتر است.
شما همچنین میتوانید مقدار اولیه این عدد را جهت شروع تولید، در پارامتر متد تعیین کنید. این مقدار همچنین در قسمت تنظیمات پَرباد نیز توسط متد ConfigureAutoTrackingNumber قابل تنظیم است.
در این روش کد رهگیری، به صورت تصادفی در محدوده Int64 توسط پَرباد تولید خواهد شد. کدهای تولید شده در این روش تقریبا ٪۹۹.۹ غیر تکراری هستند. اما اگر به تمیز بودن کدهای تولید شده اهمیت میدهید، بهتر است از روش AutoIncrement که بالاتر توضیح داده شد، استفاده کنید.
نکته ۱: شما همچنین میتوانید در منبع خود، از تزریق وابستگیها نیز استفاده کنید. بدیهی است سرویسی را که تزریق میکنید، باید از قبل توسط سیستم تزریق وابستگیهای اپلیکیشن شما، ثبت شده باشد.
همانطور که میبینید، متدهای مختلفی جهت استفاده از منبع مورد نظر شما موجود است.
در مثال بالا، درگاه مجازی توسط آدرس داده شده در دسترس خواهد بود. توجه داشته باشید که این آدرس حتما باید با یک ( / ) آغاز شده باشد.
ASP.NET WebForms, ASP.NET MVC (Startup.cs)
در مثال بالا، درگاه بانک ملت (صرفا جهت مثال) با یک پروکسی تنظیم شده است. برای سایر درگاههای بانکی، فرمت تنظیمات، کاملا مشابه مثال بالا است.
ServiceLifetime، تایین کننده طول عمر سرویس شما است.
تولید اتوماتیک کد رهگیری به صورت تصادفی
var result = _onlinePayment.Request(invoice => { invoice .UseAutoRandomTrackingNumber() .SetAmount(25000) .SetCallbackUrl("http://www.mywebsite.com/foo/bar/") .UseGateway(Gateways.Mellat); });
ایجاد یک تولید کننده کد رهگیری توسط شما
اگر بنا به دلایلی قصد دارید خودتان نیز یک منبع تولید کد رهگیری را ایجاد کنید، میتوانید به روش زیر عمل کنید.
public class MyTrackingNumberProvider : ITrackingNumberProvider { public Task<long> ProvideAsync(CancellationToken cancellationToken = new CancellationToken()) { // تولید و برگشت کد در اینجا } }
نکته ۲؛ شما همچنین میتوانید بدون ایجاد هیچ منبعی، به راحتی از متد SetTrackingNumber در InvoiceBuilder (که بالاتر توضیح داده شده) استفاده کنید.
سپس در هنگام ایجاد درخواست پرداخت به روش زیر از منبع خود استفاده کنید:
var result = _onlinePayment.Request(invoice => { invoice .UseTrackingNumberProvider<MyTrackingNumberProvider>() // یا .UseTrackingNumberProvider(new MyTrackingNumberProvider()) // یا .UseTrackingNumberProvider(services => new MyTrackingNumberProvider()) });
صورت حساب سفارشی برای امکانات اختصاصی درگاههای بانکی
درگاههای بانکی علاوه بر سرویسهای پرداخت عادی، امکانات مختلفی دیگری را نیز ارائه میکنند. برای مثال بانک ملت دارای سرویسی به نام "باشگاه مشتریان بانک ملت" است که امکان واریز مبلغ را از حساب مشتری، به چندین حساب مختلف میدهد.
نکته مهم: همانطور که میدانید قبل از استفاده از این گونه سرویسها، کلیه شماره حسابهایی که قصد واریز مبلغ به آنها را دارید، باید از قبل (در هنگام عقد قرارداد با بانک) به بانک مورد نظر داده شده باشد. در غیر اینصورت امکان استفاده از این گونه سرویسها را ندارید.
نکته: در هنگام نوشتار این مقاله، این سرویس هنوز در پَرباد آماده نیست و در حال توسعه است.
درگاه مجازی
درگاه مجازی پَرباد، یک درگاه بانکی شبیه سازی شده و بسیار ساده است که از آن جهت تست اپلیکیشن خود و عملیات پرداخت میتوانید استفاده کنید. به عبارت دیگر، برای تست اپلیکیشن خود، نیازی به داشتن یک حساب واقعی در یک درگاه بانکی ندارید و میتوانید از این درگاه مجازی استفاده کنید.
ابتدا در قسمت تنظیمات پَرباد، آدرس مورد نظر برای درگاه مجازی را مانند کد زیر مشخص میکنیم:
services.AddParbad() .ConfigureGateways(gateways => { gateways .AddParbadVirtual() .WithOptions(options => options.GatewayPath = "/MyVirtualGateway"); });
سپس درگاه مجازی را در اپلیکیشن خود ثبت میکنید:
ASP.NET CORE (Startup.cs)
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); }); // ثبت درگاه مجازی app.UseParbadVirtualGateway(); }
public void Configuration(IAppBuilder app) { var parbad = ParbadBuilder.CreateDefaultBuilder() .ConfigureGateways(gateways => { gateways .AddParbadVirtual() .WithOptions(options => options.GatewayPath = "/MyVirtualGateway"); }) .Build(); app.UseParbadVirtualGateway(parbad.Services); }
تنظیمات درگاه مجازی تا اینجا به پایان رسیده و فقط در هنگام ایجاد درخواست پرداخت، از میان درگاهها، درگاه مجازی پَرباد را انتخاب کنید.
var result = _onlinePayment.Request(Gateways.ParbadVirtualGateway, 123, 25000, "http://www.mywebsite.com/foo/bar/");
و در نهایت به درگاه مجازی هدایت خواهید شد:
نمونه پروژههای کامل را در انتهای مقاله میتوانید مشاهده کنید.
استفاده از پروکسی
با توجه به تغییرات اخیر در بانکداری کشور، احتمال آن وجود دارد که در آینده، بعضی از درگاههای بانکی فقط به IPهای داخل کشور سرویس دهی کنند. اگر وب سایت شما بنا به دلایلی در سروری خارج از کشور میزبانی میشود، شما جهت استفاده از درگاههای بانکی، نیاز به یک سرور در داخل کشور دارید که نقش پروکسی را برای شما بازی کند. پَرباد این امکان را برای شما محیا کرده و کافیست اطلاعات پروکسی سرور خود را به شکل زیر برای درگاه بانکی مورد نظر ثبت کنید.
services.AddParbad() .ConfigureGateways(gateways => { gateways .AddMellat() .WithOptions(options => { options.TerminalId = 123; options.UserName = "abc"; options.UserPassword = "xyz; ) .WithProxy(new Uri("Proxy Server URL"), "UserName", "Password"); });
توکن پرداخت
پَرباد جهت شناسایی و تبادل اطلاعات پرداخت با خارج از سیستم خود و بانکها، از یک توکن به ازاء هر پرداخت استفاده میکند. به عبارت دیگر، به ازاء هر درخواست پرداخت یک توکن تولید میشود. به این صورت، درخواستهای پرداخت، غیر قابل دستکاری و غیر قابل حدس زدن توسط کاربران میشود.
نکته: پَرباد از یک تولید کننده پیش فرض توکن استفاده میکند و شما نیازی به انجام هیچگونه تنظیماتی ندارید. تولید کننده پیش فرض، از یک GUID در Query String استفاده میکند.
اگر قصد دارید روش مورد نظر خود را برای تولید توکن جهت شناسایی یک پرداخت پیادهسازی کنید، میتوانید به روش زیر عمل کنید:
ابتدا تولید کننده توکن را تعریف کنید.
public class MyTokenProvider : IPaymentTokenProvider { public Task<string> ProvideTokenAsync(Invoice invoice, CancellationToken cancellationToken = new CancellationToken()) { // تولید و برگرداندن توکن در اینجا } public Task<string> RetrieveTokenAsync(CancellationToken cancellationToken = new CancellationToken()) { // خواندن و برگرداندن توکن در اینجا } }
نکته: شما همچنین میتوانید از تزریق وابستگیها نیز استفاده کنید. بدیهی است که در اینصورت باید سرویسی که تزریق میکنید، از قبل در سیستم تزریق وابستگیهای اپلیکیشن شما ثبت شده باشد.
سپس تولید کننده توکن خود را در تنظیمات به پَرباد معرفی کنید:
services.AddParbad() .ConfigurePaymentToken(builder => builder.AddPaymentTokenProvider<MyTokenProvider>(ServiceLifetime.Transient));
به این صورت پَرباد، شناسایی و ردیابی یک صورت حساب را با استفاده از تولید کننده توکن شما انجام خواهد داد.
تزریق وابستگی
همانطور که قبلا در مقاله آموزش تنظیمات نیز گفته شد، پَرباد به صورت توکار، از تزریق وابستگی استاندارد مایکروسافت استفاده میکند. بنابراین اگر اپلیکیشن شما نیز از تزریق وابستگی مشابهی استفاده میکند، نیازی به خواندن و یاد گرفتن این بخش ندارید و به راحتی میتوانید از اینترفیس IOnlinePayment در هر کجا که نیاز داشتید جهت عملیات پرداخت استفاده کنید.
اما در صورتیکه در اپلیکیشن خود از تزریق وابستگی دیگری ( مانند Autofac ) استفاده میکنید، باید این دو سیستم را با یکدیگر هماهنگ کنید. خوشبختانه تمام کتابخانههای معروف تزریق وابستگی ( مانند Autofac ) از قبل این کار را برای شما محیا کردهاند و شما فقط نیاز به افزودن چند خط کد به اپلیکیشن فعلی خود را دارید.
جهت فهم بهتر و آموزش عملی، یک اپلیکیشن کامل ASP.NET MVC برای شما تهیه شده که از Autofac جهت تزریق وابستگی استفاده میکند. در این پروژه خواهید دید چگونه به راحتی پَرباد و Autofac را با یکدیگر هماهنگ کرده و هچنین اینترفیس IOnlinePayment را درون کنترلر تزریق میکنیم.
لینک پروژهها در انتهای همین مقاله قابل مشاهده هستند.
Logging
لاگ کردن در پَرباد توسط سیستم استاندارد مایکروسافت انجام میشود. این بدان معنی است که شما امکان استفاده از کتابخانههای Logging بسیار زیادی را دارید. نحوه استفاده و تنظیم کتابخانههای معروف Logging در وب سایت آنها آورده شده و به راحتی میتوانید آنها را با لاگ مایکروسافت تطابق دهید.
نمونه پروژهها
مقالههای مرتبط