inmanturbo / futomaki
Fat sushi rolls
Installs: 1 068
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 1
Requires
- php: ^8.2
- calebporzio/sushi: ^2.5.2
- envor/laravel-datastore: ^1.2.10
- envor/laravel-schema-macros: ^1.1.4
- illuminate/contracts: ^11.0
- spatie/laravel-package-tools: ^1.16.2
- spatie/simple-excel: ^3.4
Requires (Dev)
- larastan/larastan: *
- laravel/octane: ^2.3
- laravel/pint: *
- livewire/volt: ^1.6
- nunomaduro/collision: *
- orchestra/testbench: ^9.0
- pestphp/pest: ^2.33
- pestphp/pest-plugin-arch: ^2.7
- pestphp/pest-plugin-laravel: ^2.2
- spatie/docker: ^1.12
README
A set of features for eloquent built on top of calebporzio/sushi.
Installation
You can install the package via composer:
composer require inmanturbo/futomaki
Usage
Eloquent CSV Driver
<?php use Illuminate\Database\Eloquent\Model; use Inmanturbo\Futomaki\HasCsv; class Post extends Model { use HasCsv; protected $schema = [ 'id' => 'id', 'title' => 'string', 'content' => 'text', ]; protected function csvFileName() { return 'posts.csv'; } protected function csvDirectory() { return storage_path('csv'); } }
HasCsv uses sushi (array driver) under the hood, and supports defining a $rows property as well. A csv file will automatically be created using the defined $rows.
use Illuminate\Database\Eloquent\Model; use Inmanturbo\Futomaki\HasCsv; class PostWithCsv extends Model { use HasCsv; protected $guarded = []; protected $schema = [ 'id' => 'id', 'title' => 'string', 'content' => 'text', ]; protected $rows = [ [ 'id' => 1, 'title' => 'Post 1', 'content' => 'Content 1', ], [ 'id' => 2, 'title' => 'Post 2', 'content' => 'Content 2', ], ]; }
Using ->getCsvRows()
Implementing your own getCsvRows()
method is supported as well.
use Illuminate\Database\Eloquent\Model; use Inmanturbo\Futomaki\HasCsv; class PostWithCsv extends Model { use HasCsv; protected $guarded = []; protected $schema = [ 'id' => 'id', 'title' => 'string', 'content' => 'text', ]; public function getCsvRows() { return [ ['id' => 1,'title' => 'Post 1', 'content' => 'Content 1'], ['id' => 2,'title' => 'Post 2','content' => 'Content 2'], ]; } }
HasFutumakiWrites
HasFutomakiWrites is a trait which leverages eloquent's saving()
and deleting()
hooks to support writing sushi's changes out to another database, or api, etc.
Example Below.
use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Facades\DB; use Inmanturbo\Futomaki\Futomaki; use Inmanturbo\Futomaki\HasFutomakiWrites; class PostWithFutomakiWrites extends Model { use Futomaki; use HasFutomakiWrites; public $timestamps = true; public $guarded = []; protected $schema = [ 'id' => 'id', 'title' => 'string', 'content' => 'text', ]; public function getRows() { return DB::connection('remote_posts')->table('posts')->get()->map(fn ($remoteItem) => [ 'id' => $remoteItem->id, 'title' => $remoteItem->title, 'content' => $remoteItem->body, ])->toArray(); } public function futomakiSaving() { $values = [ 'id' => $this->id, 'title' => $this->title, 'body' => $this->content, ]; DB::connection('remote_posts')->transaction(function () { DB::connection('remote_posts')->table('posts')->upsert($values, $this->getKeyName()); }); } public function futomakiDeleting() { DB::connection('remote_posts') ->table('posts') ->where($this->getKeyName(), $this->getKey()) ->delete(); } }
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.