PHPackages                             meita/wps - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. meita/wps

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

meita/wps
=========

Saudi WPS payroll protection file generator with multi-bank support (Al Rajhi, Riyad, AlAhli, Alinma, ANB) for any PHP or Laravel project.

1.0.1(5mo ago)00MITPHPPHP &gt;=8.1

Since Dec 15Pushed 5mo agoCompare

[ Source](https://github.com/EngMEita/wps)[ Packagist](https://packagist.org/packages/meita/wps)[ RSS](/packages/meita-wps/feed)WikiDiscussions main Synced 1mo ago

READMEChangelogDependencies (1)Versions (3)Used By (0)

Meita WPS
=========

[](#meita-wps)

PHP/Laravel package that generates Saudi WPS payroll files with multi-bank support (Al Rajhi, Riyad, SNB AlAhli, Alinma, ANB). All classes live under the `Meita\Wps` namespace.

Requirements
------------

[](#requirements)

- PHP 8.1+
- Works in any PHP app or Laravel project.

Installation
------------

[](#installation)

```
composer require meita/wps
```

Quick start (PHP)
-----------------

[](#quick-start-php)

```
use Meita\Wps\Adapters\{AlRajhiAdapter, RiyadAdapter, AlAhliAdapter, AlinmaAdapter, ArabNationalBankAdapter};
use Meita\Wps\BankAdapterRegistry;
use Meita\Wps\PayrollProtectionManager;
use Meita\Wps\DTO\{Payment, PaymentBatch};

$registry = new BankAdapterRegistry([
    'alrajhi' => new AlRajhiAdapter(),
    'riyad' => new RiyadAdapter(),
    'alahli' => new AlAhliAdapter(),
    'alinma' => new AlinmaAdapter(),
    'anb' => new ArabNationalBankAdapter(),
]);

$batch = new PaymentBatch(
    companyId: '1234567890',
    companyName: 'Meita LLC',
    payrollMonth: '2024-05',
    payments: [
        new Payment('EMP-1', 'Ali Saleh', '1010101010', 'SA123...', 5500.75),
        new Payment('EMP-2', 'Sara Ahmed', '2020202020', 'SA456...', 4300.00, notes: 'Commission included'),
    ],
    reference: 'MAY-24',
    contactEmail: 'payroll@meita.sa'
);

$manager = new PayrollProtectionManager($registry);
$file = $manager->generate('alrajhi', $batch);
file_put_contents($file->filename, $file->content);
```

Laravel usage
-------------

[](#laravel-usage)

- The service provider auto-registers the default adapters and binds `PayrollProtectionManager`.
- Example:

```
use Meita\Wps\PayrollProtectionManager;
use Meita\Wps\DTO\{Payment, PaymentBatch};

$batch = /* build your PaymentBatch */;
$file = app(PayrollProtectionManager::class)->generate('riyad', $batch);
Storage::put(\"wps/{$file->filename}\", $file->content);
```

- To override or add adapters, bind your own `BankAdapterRegistry` in a service provider before resolving `PayrollProtectionManager`.

Adding a custom bank adapter
----------------------------

[](#adding-a-custom-bank-adapter)

1. Extend `Meita\Wps\Adapters\AbstractDelimitedAdapter`.
2. Implement `key()`, `bankName()`, `header()` (optional), and `fields()` to shape each row.
3. Register the adapter in `BankAdapterRegistry` (either manually or via a Laravel service provider).

Supported adapters
------------------

[](#supported-adapters)

- `alrajhi`
- `riyad`
- `alahli` (SNB)
- `alinma`
- `anb`

###  Health Score

32

—

LowBetter than 72% of packages

Maintenance73

Regular maintenance activity

Popularity0

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity44

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

2

Last Release

154d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/5915383ac10e7c148c23e142195199c8e7909acc2cda2003c26e688090956014?d=identicon)[EngMEita](/maintainers/EngMEita)

---

Top Contributors

[![EngMEita](https://avatars.githubusercontent.com/u/11925529?v=4)](https://github.com/EngMEita "EngMEita (2 commits)")

---

Tags

phplaravelBankpayrollwpssaudialrajhiriyadalahlialinmaanb

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/meita-wps/health.svg)

```
[![Health](https://phpackages.com/badges/meita-wps/health.svg)](https://phpackages.com/packages/meita-wps)
```

###  Alternatives

[amranidev/laracombee

Recommendation system for laravel

11636.7k1](/packages/amranidev-laracombee)[salmanzafar/laravel-geocode

A Laravel Library to find Lat and Long of a given Specific Address

153.9k](/packages/salmanzafar-laravel-geocode)[wujunze/money-wrapper

MoneyPHP Wrapper

113.8k](/packages/wujunze-money-wrapper)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
