PHPackages                             hema/mongo\_transaction - 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. [Database &amp; ORM](/categories/database)
4. /
5. hema/mongo\_transaction

ActiveLibrary[Database &amp; ORM](/categories/database)

hema/mongo\_transaction
=======================

adding transaction feature to jenssegers/mongodb

1.5(6y ago)41991[1 issues](https://github.com/ibrahimSmuhammad/mongo_transaction/issues)MITPHP

Since Dec 10Pushed 4y ago1 watchersCompare

[ Source](https://github.com/ibrahimSmuhammad/mongo_transaction)[ Packagist](https://packagist.org/packages/hema/mongo_transaction)[ RSS](/packages/hema-mongo-transaction/feed)WikiDiscussions master Synced 3d ago

READMEChangelog (1)Dependencies (1)Versions (7)Used By (0)

### Laravel Mongo Transaction

[](#laravel-mongo-transaction)

##### How to Install:

[](#how-to-install)

Assuming you have already installed `composer require jenssegers/mongodb` and configured it fully according to the documentation (), now run this to install mongo-transactions:

`composer require hema/mongo_transaction`

### In your Model Or BaseModel Use The Flowing Model :

[](#in-your-model-or-basemodel-use-the-flowing-model-)

```
use Hema\MongoTransaction\Transactions\Eloquent\Model
```

### Instead of Jenssegers Model

[](#instead-of-jenssegers-model)

```
use use Jenssegers\Mongodb\Eloquent\Model
```

### Note :

[](#note-)

- this package created for specific business needs. so, it's may not fit your needs 100%. but you still can fork it and extend or modify it.
- you've to enable replica set in [Mongo](https://docs.mongodb.com/manual/tutorial/deploy-replica-set/#procedure "Replica Set In Mongod").

```
~$ sudo mongod --replSet "rs0"
```

and then run mongo

```
~$ sudo mongo
```

#### now you can use transaction this way :

[](#now-you-can-use-transaction-this-way-)

```
use Hema\MongoTransaction\Transactions\Transaction
```

```
* Transaction::start();

// ........ A bunch of other db operations

* Transaction::commit();

// ........ commit when success

* Transaction::rollback();

// ........ Or rollback when error occure
```

### Now You Can Use These Methods with transaction

[](#now-you-can-use-these-methods-with-transaction)

```
* create();
* insert();
* update();
* delete();
* forceDelete();
* restore()
* increment();
* decrement();

* trash(); //custome method for soft-delete
* remove(); //custome method for hard-delete
```

#### Example :

[](#example-)

```
    Transaction::start();

  try {
 	User::insert($some_data);

  	Profile::insert($some_data);

        Transaction::commit();

        return 'done';

   } catch (\Exception $e) {

        Transaction::rollback();

  	return $e->getMessage();
   }
```

###  Health Score

28

—

LowBetter than 54% of packages

Maintenance15

Infrequent updates — may be unmaintained

Popularity16

Limited adoption so far

Community10

Small or concentrated contributor base

Maturity61

Established project with proven stability

 Bus Factor1

Top contributor holds 94.1% 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 ~4 days

Total

6

Last Release

2326d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/30d095d0a9e0b0469e50e6373dd6e85fe665ffc229aff561cdaad886fb9fc8d3?d=identicon)[ibrahim Samir Muhammad](/maintainers/ibrahim%20Samir%20Muhammad)

---

Top Contributors

[![ibrahimSmuhammad](https://avatars.githubusercontent.com/u/17378184?v=4)](https://github.com/ibrahimSmuhammad "ibrahimSmuhammad (16 commits)")[![QuangHung-5497](https://avatars.githubusercontent.com/u/53513754?v=4)](https://github.com/QuangHung-5497 "QuangHung-5497 (1 commits)")

---

Tags

laravellaravel-mongo-transactionlaravel-mongodbmongomongo-transactionmongodmongodbmongodb-replica-settransactiontransactions

### Embed Badge

![Health badge](/badges/hema-mongo-transaction/health.svg)

```
[![Health](https://phpackages.com/badges/hema-mongo-transaction/health.svg)](https://phpackages.com/packages/hema-mongo-transaction)
```

###  Alternatives

[mostafamaklad/laravel-permission-mongodb

Permission handling for Laravel 5.2 and up using mongodb

113220.0k2](/packages/mostafamaklad-laravel-permission-mongodb)[jenssegers/mongodb-session

A MongoDB session driver for Laravel 4, 5, 6, 7 and 8

76308.1k3](/packages/jenssegers-mongodb-session)[designmynight/laravel-mongodb-passport

A package to allow laravel/passport use with jenssegers/laravel-mongodb

68123.3k](/packages/designmynight-laravel-mongodb-passport)[jenssegers/mongodb-sentry

An extension for Laravel-MongoDB that lets you work with Sentry

5445.0k1](/packages/jenssegers-mongodb-sentry)[pimlie/laravel-datatables-mongodb

Laravel DataTables plugin to support Mongodb

1245.9k](/packages/pimlie-laravel-datatables-mongodb)

PHPackages © 2026

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