All Projects → sobirjonovs → automated-p2p-transactions

sobirjonovs / automated-p2p-transactions

Licence: MIT license
Payme orqali p2p to'lovlarni avtomatlashtirish

Programming Languages

PHP
23972 projects - #3 most used programming language

Projects that are alternatives of or similar to automated-p2p-transactions

Builder
Prepare your Laravel apps incredibly fast, with various commands, services, facades and boilerplates.
Stars: ✭ 1,009 (+3379.31%)
Mutual labels:  billing
Invoiceplane
A self-hosted open source application for managing your invoices, clients and payments.
Stars: ✭ 1,936 (+6575.86%)
Mutual labels:  billing
Invoiceneko
An Open Sourced Invoice System developed for anyone who needs to generate out an invoice and manage clients
Stars: ✭ 204 (+603.45%)
Mutual labels:  billing
Jetstream Cashier Billing Portal
Jetstream Cashier Billing Portal is a simple scaffolding billing portal to manage subscriptions, invoices and payment methods, built on top of Jetstream & Cashier Register.
Stars: ✭ 45 (+55.17%)
Mutual labels:  billing
Flutter iap
Flutter iap plugin
Stars: ✭ 101 (+248.28%)
Mutual labels:  billing
Commerce billing
A payment processing library for Elixir
Stars: ✭ 170 (+486.21%)
Mutual labels:  billing
Android Checkout
Library for Android In-App Billing (Version 3+)
Stars: ✭ 986 (+3300%)
Mutual labels:  billing
recurly
A Recurly API client written in golang. Actively maintained and unit tested. No external dependencies.
Stars: ✭ 40 (+37.93%)
Mutual labels:  billing
Invoicenet
Deep neural network to extract intelligent information from invoice documents.
Stars: ✭ 1,886 (+6403.45%)
Mutual labels:  billing
Killbill
Open-Source Subscription Billing & Payments Platform
Stars: ✭ 2,396 (+8162.07%)
Mutual labels:  billing
Azure Functions Billing
Azure Functions v2 with .NET Core - billing in serverless architecture.
Stars: ✭ 49 (+68.97%)
Mutual labels:  billing
Paysuper Billing Server
A core monolith-like service with all payment processing business logic in PaySuper.
Stars: ✭ 95 (+227.59%)
Mutual labels:  billing
Node Sales Tax
💰 International sales tax calculator for Node (offline, but provides optional online VAT number fraud check). Tax rates are kept up-to-date.
Stars: ✭ 182 (+527.59%)
Mutual labels:  billing
Dj Stripe
Django + Stripe Made Easy
Stars: ✭ 1,022 (+3424.14%)
Mutual labels:  billing
Ledgersmb
Repository for the LedgerSMB project -- web app for accounting & ERP
Stars: ✭ 222 (+665.52%)
Mutual labels:  billing
Billing Android
RxJava wrapper for Android Play Billing Library
Stars: ✭ 40 (+37.93%)
Mutual labels:  billing
Premiumer
Premiumer makes removing ads with a single in-app purchase on Android as easy as pie.
Stars: ✭ 153 (+427.59%)
Mutual labels:  billing
killbill-stripe-plugin
Kill Bill plugin for Stripe
Stars: ✭ 16 (-44.83%)
Mutual labels:  billing
Smartvpn Billing
Billing and auth system for VPN provider
Stars: ✭ 250 (+762.07%)
Mutual labels:  billing
Stripe Billing Typographic
⚡️Typographic is a webfont service (and demo) built with Stripe Billing.
Stars: ✭ 186 (+541.38%)
Mutual labels:  billing

[Telegram] tutorialsgroup [Telegram] sobirjonovs

Bu qanaqa dastur?

p2p to'lovlarni avtomatlashtirish uchun dastur. Dastur Payme apidan foydalanadi.

1. Dastur ishlashi uchun talablar

  • >= PHP v7.4
  • >= Composer v1.10.1

2. O'rnatish

Dasturdan to'liq foydalanish uchun composer ni o'rnatishingiz kerak.

$ composer install

3. Payme'ga ulanish

Payme'ga ulanish uchun biz App\Payme\Api\Api sinfidan foydalanamiz. Ushbu sinf orqali barcha Payme bilan bog'liq amaliyotlarni bajarishimiz mumkin. Keling, birinchi Payme kabinetimizga ushbu sinf orqali kiramiz:

<?php
$payme = new Api();  
$payme->setCredentials(['login' => 'paymega ulangan telefon raqam', 'password' => 'paymedagi parol']);  
$payme->login()->sendActivationCode();

DIQQAT! Kabinetga faqat bir marta, "MUHIM" ma'lumotlarni olish uchun kiramiz. Undan so'ng kirish shart bo'lmaydi. Qaysi "MUHIM" ma'lumotlar nazarda tutilayotgani pastda keltirilgan. Diqqat bilan o'qing.

setCredentials([]) metodi orqali Payme akkauntimizning login parollarini belgilashimiz mumkin. Bu metodga massiv yuborish kerak. Massivda login va parol kalitlari bo'lishi shart. Login - bu sizning Paymedagi nomeringiz, nomer 901234564 formatda yozilishi kerak. Parol esa o'z holicha yoziladi. Ushbu ma'lumotlarni to'g'ri kiritganingizdan so'ng, sizga Paymedan telefon raqamingizga kod keladi. Ushbu kodni activate metodi orqali kiritasiz:

<?php
$payme = new Api();  
$payme->activate('telefonga kelgan kod')->registerDevice();  
$payme->setCredentials(['login' => 'paymega ulangan telefon raqam', 'password' => 'paymedagi parol']);  
$device_id = $payme->getDevice(); // !!! MA'LUMOTLAR BAZAGA TEGISHLI TARTIBDA SAQLANSIN  
$cards = $payme->getMyCards(); // !!! MA'LUMOTLAR BAZAGA TEGISHLI TARTIBDA SAQLANSIN | ID raqam massivning "_id" indeksida bo'ladi

Telefoningizga Paymedan "Payme API qurilmasi ulandi" degan SMS kelsa, demak hammasi muvaffaqiyatli bo'lgan. Shundan so'ng, kerakli ma'lumotlarni saqlab olishga navbat keladi.

Muhim ma'lumotlar

  1. Device ID
  2. Card ID

Paymega API orqali kirilganda sessiya 15 daqiqa davom etadi va undan keyin API klyuch yangilanadi. Bu holatda yana qaytadan login qilmaslik uchun biz device id raqamini saqlab olishimiz kerak. Device id orqali aktiv sessiya klyuchni olishimiz mumkin (buni siz qilmaysiz, sessiya klyuchni dasturni o'zi topadi). Cheklarni olayotganda, kartalarni olayotganda birinchi credentials'ni va device idni kiritish zarur. Device id setDevice metodi orqali kiritiladi.

<?php
$payme = new Api();
$payme->setCredentials(['login' => 'paymega ulangan telefon raqam (Telefon raqam 901234565 formatda bo`lishi kerak)', 'password' => 'paymedagi parol']);
$payme->setDevice('device id string');

Shundan so'ng bemalol amaliyotlarni kuzatish mumkin.

Payme'dagi barcha tranzaksiyalarni ko'rish

Barcha tranzaksiyalarni ko'rish uchun getAllCheques yoki cheques metodlari ishlatiladi. Bu metodlar bir xil vazifa bajaradi faqat farqi getAllCheques chainable emas.

<?php
$payme = new Api();  
$payme->setCredentials(['login' => 'paymega ulangan telefon raqam (Telefon raqam 901234565 formatda bo`lishi kerak)', 'password' => 'paymedagi parol']); 
$payme->setDevice('device id string'); 
$cheques = $payme->getAllCheques(); 
// yoki
$cheques = $payme->cheques();

Tranzaksiyalar orasidan tegishli izohli to'lovni topish

Agar siz P2P to'lovni avtomatlashtirmoqchi bo'lsangiz, sizga bu juda asqatadi. Izohli to'lovni tekshirish uchun findByComment metodi ham qo'shiladi. Namuna:

<?php
$payme = new Api();  
$payme->setCredentials(['login' => 'paymega ulangan telefon raqam (Telefon raqam 901234565 formatda bo`lishi kerak)', 'password' => 'paymedagi parol']);  
$payme->setDevice('device id string'); 

// Bitta kartadagi tranzaksiyalar orasidan izoh orqali qidirish  
$payme->selectCard('karta id raqami')->findByComment('izoh', 0); // 0 ni o'rniga kerakli summa yozilsin  
  
// Barcha kartalardagi tranzaksiyalar orasidan izoh orqali qidirish  
$payme->cheques()->findByComment('izoh', 0);

Tranzaksiyalarni saralash

Tranzaksiyalarni saralash uchun getAllCheques yoki cheques metodlaridan biriga saralash parametrlaridan iborat massivni uzatishingiz kerak. Saralash parametrlari quyidagilardan iborat:

  1. from Bu parametr 3 ta elementli massiv qabul qiladi. Elementlari day, month, year lar hisoblanadi. month ga qiymat berganda berilgan oydan -1 ayirish kerak. Ya'ni, 7-oydagi ma'lumotni topish uchun 6-oy deb yozishingiz kerak (g'alati, paymeda shunaqa ekan).
  2. count Bu parametr integer qabul qiladi. Buning vazifasi nechta tranzaksiyani olib berishni hal qilish.
  3. card Bu parametr karta raqamning ID sini qabul qiladi. Buning vazifasi ko'rsatilgan karta raqamdagi tranzaksiyalarni olib berish.
  4. to Bu parametr ham from bilan bir xil. Faqat bu ko'rsatilgan sanagacha bo'lgan tranzaksiyalarni olib berishni hal qiladi.
  5. group Defolt qiymati time
  6. offset Defolt qiymati 0

Namunalar

API dan foydalanish namunalar index.php faylida ham yozilgan.

Eslatma!

Dastur va dastur uchun qo'llanma Sanjarbek Sobirjonov (telegram @sobirjonovs) tomonidan yozildi. Agar dasturda yoki qo'llanmada qandaydir xatolik topsangiz, pull request yoki murojaat qilishingizdan mamnun bo'lamiz.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].