承接 aliziodev/payid 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

aliziodev/payid

最新稳定版本:v0.1.1

Composer 安装命令:

composer require aliziodev/payid

包简介

Unified Laravel Payment Orchestrator for Indonesian Payment Gateways

README 文档

README

Unified Laravel Payment Orchestrator for Indonesian Payment Gateways

PayID adalah package Laravel yang menyatukan berbagai payment gateway Indonesia dalam satu API yang konsisten dan extensible. Integrasikan sekali, gunakan provider mana saja melalui model driver.

Tujuan, Cakupan, dan Batasan

Tujuan

  • Menyediakan API pembayaran yang konsisten lintas provider untuk use case umum aplikasi.
  • Mengurangi vendor lock-in dengan pendekatan driver dan capability-based contracts.
  • Menstandarkan lifecycle pembayaran (charge, status, webhook, dsb.) agar mudah diuji dan dipelihara.

Cakupan

  • Orkestrasi pembayaran pada layer aplikasi Laravel melalui facade/manager PayID.
  • Standardisasi DTO, enum status, dan webhook normalization lintas driver.
  • Ekstensi provider-specific melalui package driver terpisah (mis. Midtrans, Xendit, iPaymu, Nicepay).
  • Integrasi opsional dengan stack transaksi/ledger lewat package pendamping.

Batasan

  • PayID bukan payment gateway; eksekusi transaksi tetap dilakukan oleh provider masing-masing.
  • Fitur provider-specific yang sangat khusus tidak selalu tersedia di API generic manager, dan diakses via extension method pada driver.
  • Compliance, legal, settlement, rekonsiliasi bank, dan dispute handling tetap menjadi tanggung jawab aplikasi/operasional bisnis.
  • Konfigurasi kredensial, endpoint, serta kebijakan retry/queue production harus ditetapkan di aplikasi host sesuai kebutuhan domain.

Requirements

  • PHP 8.2+
  • Laravel 11.x, 12.x, atau 13.x

Instalasi

Install PayID core:

composer require aliziodev/payid

Install driver provider yang diinginkan:

composer require aliziodev/payid-midtrans
composer require aliziodev/payid-xendit

Publish konfigurasi:

php artisan vendor:publish --tag=payid-config

Opsional, gunakan installer interaktif:

php artisan payid:install

Installer akan memandu:

  • pemilihan driver gateway
  • pemilihan transaction stack: payid-transactions atau manual

Konfigurasi

Tambahkan ke .env:

PAYID_DEFAULT_DRIVER=midtrans

MIDTRANS_ENV=sandbox
MIDTRANS_SERVER_KEY=SB-Mid-server-xxxx
MIDTRANS_CLIENT_KEY=SB-Mid-client-xxxx

Penggunaan Dasar

Membuat Transaksi

use Aliziodev\PayId\DTO\ChargeRequest;
use Aliziodev\PayId\Enums\PaymentChannel;
use Illuminate\Support\Facades\PayId;

$response = PayId::charge(ChargeRequest::make([
    'merchant_order_id' => 'ORDER-001',
    'amount'            => 150000,
    'currency'          => 'IDR',
    'channel'           => PaymentChannel::Qris,
    'customer'          => [
        'name'  => 'Alizio',
        'email' => 'budi@example.com',
    ],
]));

return redirect($response->paymentUrl);

Cek Status Transaksi

$status = PayId::status('ORDER-001');

if ($status->status->isSuccessful()) {
    // Tandai order sebagai dibayar
}

Ganti Driver Saat Runtime

$response = PayId::driver('xendit')->charge($request);

Operasi Lain yang Tersedia

PayID manager/facade juga menyediakan:

  • directCharge(ChargeRequest $request)
  • refund(RefundRequest $request)
  • cancel(string $merchantOrderId)
  • expire(string $merchantOrderId)
  • approve(string $merchantOrderId)
  • deny(string $merchantOrderId)
  • createSubscription(SubscriptionRequest $request)
  • getSubscription(string $providerSubscriptionId)
  • updateSubscription(UpdateSubscriptionRequest $request)
  • pauseSubscription(string $providerSubscriptionId)
  • resumeSubscription(string $providerSubscriptionId)
  • cancelSubscription(string $providerSubscriptionId)
  • supports(Capability $capability)

Menangani Webhook

Daftarkan URL webhook ke dashboard provider: https://yourdomain.com/payid/webhook/midtrans

Tangkap event di listener:

use Aliziodev\PayId\Events\WebhookReceived;
use Aliziodev\PayId\Enums\PaymentStatus;

Event::listen(WebhookReceived::class, function (WebhookReceived $event) {
    $webhook = $event->webhook;

    if ($webhook->status === PaymentStatus::Paid) {
        Order::markAsPaid($webhook->merchantOrderId);
    }
});

Testing

$fake = PayId::fake();

$fake->fakeCharge(ChargeResponse::make([
    'provider_name'           => 'midtrans',
    'provider_transaction_id' => 'TRX-001',
    'merchant_order_id'       => 'ORDER-001',
    'status'                  => PaymentStatus::Pending,
    'payment_url'             => 'https://example.com/pay',
    'raw_response'            => [],
]));

// Jalankan kode yang memanggil PayId::charge(...)

$fake->assertCharged();

Fake helper lain yang tersedia termasuk:

  • fakeDirectCharge, fakeStatus, fakeRefund, fakeCancel, fakeExpire
  • fakeApprove, fakeDeny, fakeSubscription
  • assertion seperti assertDirectCharged, assertStatusChecked, assertRefunded, assertNothingRecorded

Driver yang Tersedia

Driver Package Status
Midtrans aliziodev/payid-midtrans Stable
Xendit aliziodev/payid-xendit Stable
iPaymu aliziodev/payid-ipaymu Beta
Nicepay aliziodev/payid-nicepay Stable
DOKU aliziodev/payid-doku Coming Soon

Dokumentasi

Status Kesiapan

  • Test suite: passing
  • Static analysis (PHPStan): passing
  • Coverage report: butuh coverage driver (Xdebug/PCOV/phpdbg-compatible) di environment

Known Limitations

  • Coverage report belum dapat dijalankan jika environment belum memuat driver coverage.
  • Driver iPaymu sudah tersedia pada level beta dan dapat dipakai untuk flow charge/status/webhook.
  • Driver Nicepay sudah final dan berstatus stable, mencakup fitur SNAP + V2 melalui extension method.
  • Fitur queue processing webhook disiapkan pada konfigurasi, tetapi implementasi orchestration async tetap perlu ditangani di aplikasi host.

Kontribusi

Lihat CONTRIBUTING.md untuk panduan berkontribusi.

Security

Untuk pelaporan vulnerability, lihat SECURITY.md.

Upgrade

Panduan upgrade antar versi tersedia di UPGRADE.md.

Changelog

Riwayat perubahan tersedia di CHANGELOG.md.

Lisensi

MIT License.

统计信息

  • 总下载量: 26
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-13

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固