Download the PHP package offline-agency/laravel-mongo-auto-sync without Composer
On this page you can find all versions of the php package offline-agency/laravel-mongo-auto-sync. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download offline-agency/laravel-mongo-auto-sync
More information about offline-agency/laravel-mongo-auto-sync
Files in offline-agency/laravel-mongo-auto-sync
Package laravel-mongo-auto-sync
Short Description This package provides a better support for MongoDB relationships in Laravel Projects.
License MIT
Informations about the package laravel-mongo-auto-sync
Laravel MongoDB Relationships
This package provides a better support for MongoDB relationships in Laravel Projects. At low level all CRUD operations has been handled by jenssegers/laravel-mongodb
Installation
Prerequisites
Make sure you have the MongoDB PHP driver installed. You can find installation instructions at http://php.net/manual/en/mongodb.installation.php
Package version Compatibility
This package | Laravel | Laravel MongoDB |
---|---|---|
1.x | 5.8.x | 3.5.x |
1.x | 6.x | 3.6.x |
2.x | 5.8.x | 3.5.x |
2.x | 6.x | 3.6.x |
2.x | 7.x | 3.7.x |
2.x | 8.x | 3.8.x |
2.x | 9.x | 3.9.x |
3.x | 5.8.x | 3.5.x |
3.x | 6.x | 3.6.x |
3.x | 7.x | 3.7.x |
3.x | 8.x | 3.8.x |
3.x | 9.x | 3.9.x |
PHP Version Compatibility
- Version 1: PHP 7.1, 7.2, 7.3
- Version 2: PHP 7.4
- Version 3: PHP 7.4-8.1
Features
- Sync changes between collection with relationships after CRUD operations
- EmbedsOne & EmbedsMany
Example without our package
The sub document article has not been updated with the new article. So you will need some extra code to write in order to see the new article it in the category page. The number of sync depends on the number of the relationships and on the number of the entry in every single EmbedsMany relationships.
Total updates = ∑ (entry in all EmbedsMany relationships) + ∑ (EmbedsOne relationships)
As you can see the lines of extra code can rapidly increase, and you will write many redundant code.
Example with our package
The sub document article has been updated with the new article, with no need of extra code :tada:
You can see the new article on the category page because the package synchronizes the information for you by reading the Model Setup.
These example can be applied for all write operations on the database.
- Referenced sub documents [TO DO]
- Handle sub document as Model in order to exploit Laravel ORM support during write operation (without sync feature) [TO BE TEST]
- Handle referenced sub document as Model in order to exploit Laravel ORM support during write operation (without sync feature) [TO DO]
- Advance cast field support
Use cases
- Blog: see demo here
- Ecommerce
- API System for mobile application o for generated static site
- Any projects that require fast read operations and (slow) write operations that can be run on background
Documentation
You can find the documentation here
Testing
Run this command inside your project's route
Now run the tests with:
Roadmap :rocket:
- Refactor target synchronization to Observer pattern, so all this operation can be run on background using Laravel Queue System. This will also speed up all the operations in the collection that is primary involved in write operations.
- Command Analyse Database: This command will analyse the database in order to find some relationship error. Ex: An article with a category associated that is not present on the Category's sub document.
- Refactor save() method in order to handle CRUD operation on relationship also without sync.
- Support for referenced relationships.
- Better support for all field types.
- DestroyWithSync() without delete sub documents on other collections.
- Add more tests.
- Nested relationships.
- Benchmark MongoDB vs Mysql (write and read operation).
- Fix typo errors.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security-related issues, please email [email protected] instead of using the issue tracker.
Credits
About us
Offline Agency is a web design agency based in Padua, Italy. You'll find an overview of our projects on our website.
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-mongo-auto-sync with dependencies
ext-json Version *
ext-mongodb Version *
illuminate/support Version ^5.0|^6.0|^7.0|^8.0
illuminate/container Version ^5.0|^6.0|^7.0|^8.0
illuminate/database Version ^5.0|^6.0|^7.0|^8.0
illuminate/events Version ^5.0|^6.0|^7.0|^8.0
jenssegers/mongodb Version ^3.6|^3.7|^3.8