3neti/emi-core 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

3neti/emi-core

最新稳定版本:v1.0.4

Composer 安装命令:

composer require 3neti/emi-core

包简介

Provider-agnostic EMI domain: contracts, enums, models, DTOs, events

README 文档

README

Provider-agnostic EMI (Electronic Money Issuer) domain package for Laravel. Defines the shared contracts, enums, models, and events that any EMI provider adapter can implement.

Requirements

  • PHP 8.3+
  • Laravel 12 or 13

Installation

composer require lbhurtado/emi-core

The package auto-discovers its service provider. Publish the config if needed:

php artisan vendor:publish --tag=emi-core-config

What's Included

Contracts

Provider adapters must implement these interfaces:

  • WalletProvider — wallet CRUD (add merchant/customer, get details/balance, edit)
  • TransferProvider — staged transfers (pre-transfer, settle, cancel)
  • CashInProvider — inbound funding
  • CashOutProvider — outbound disbursement + OTP verification
  • SignsProviderPayloads — request signature generation
  • VerifiesProviderPostbacks — webhook/postback signature verification

Enums

  • ProviderCode — registered EMI providers (currently: paynamics_constellation)
  • WalletType — merchant, customer, phantom
  • WalletStatus — active, locked, suspended, closed
  • ComplianceLevel — KYC levels (-1 through 4)
  • VerificationStatus — PENDING, FOR REVIEW, REJECTED, APPROVED, RECAPTURE
  • TransactionType — cash_in, cash_out, transfer, airtime_load, bills_payment
  • TransactionStatus — 12 states from initiated through reconciling
  • TransactionDirection — inbound, outbound, internal

Models

All models use enum casts and proper Eloquent relationships:

Model Purpose
ProviderAccount API credentials per provider/tenant
Wallet Local mirror of provider wallet
WalletProfile Personal/business identity fields
WalletLimitSnapshot Captured limit fields at a point in time
Transaction Master transaction mirror (indexed by request_id)
Transfer Pre-transfer/settle/cancel lifecycle detail
CashIn Cash-in detail (payment method, channel, sender)
CashOut Cash-out detail (bank account, OTP status)
BankAccount Linked settlement/disbursement bank accounts
OtpChallenge OTP verification trail for cash-out
WebhookReceipt Raw postback payload + signature verification
ReconciliationEntry Local vs provider status drift detection

Key Design Decisions

  • request_id as first-class key — all transactions are uniquely indexed by request_id for idempotency and reconciliation
  • Enum casts everywhere — wallet type, status, compliance level, transaction status all use PHP 8.1 backed enums
  • Provider-agnostic models — models don't depend on any specific provider; the provider_code field identifies which adapter created them
  • Async-first mindsetTransactionStatus includes states like awaiting_provider, otp_required, and reconciling for asynchronous provider flows

Testing

# From the monorepo host
composer test:emi-core

License

Proprietary — Lester Hurtado

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: proprietary
  • 更新时间: 2026-03-30

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固