Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aurorawebsoftware/flymodel
FlyModel is a Laravel package that empowers you to create and manage models dynamically, on the fly
https://github.com/aurorawebsoftware/flymodel
database laravel model
Last synced: about 2 months ago
JSON representation
FlyModel is a Laravel package that empowers you to create and manage models dynamically, on the fly
- Host: GitHub
- URL: https://github.com/aurorawebsoftware/flymodel
- Owner: AuroraWebSoftware
- License: mit
- Created: 2024-09-14T11:34:39.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-10-09T11:29:43.000Z (3 months ago)
- Last Synced: 2024-10-14T08:40:59.510Z (3 months ago)
- Topics: database, laravel, model
- Language: PHP
- Homepage:
- Size: 40 KB
- Stars: 12
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
README
# FlyModel: Dynamic Laravel Models on the Fly
FlyModel is a Laravel package that empowers you to create and manage models dynamically, **on the fly !**.
It allows to define flexible and customizable models and model fields **without needing to change** the database schema.
This package streamlines your workflow by eliminating the need to define models explicitly in your codebase. Instead, you can generate and interact with models as needed, based on a unique "deck" identifier.
The package uses **FlexyField** Package as Dynamic Field Engine.
For More Info Visit: https://github.com/AuroraWebSoftware/FlexyField
## 🚀 Features
- **Dynamic Model Creation**: Instantiate models with a specified "deck" identifier without pre-defining them.
- **Dynamic Fields** : Define flexible and customizable fields on models **without needing to change** the database schema.
- **Automatic Scoping**: Models are automatically scoped according to the deck, ensuring data isolation.
- **Seamless Integration**: Works effortlessly with Laravel’s Eloquent ORM.## 📦 Installation
To get started with FlyModel, follow these steps:
### Install the Package
Add FlyModel to your project using Composer:
```bash
composer require aurorawebsoftware/flymodel
```### Run the Migration
Create the necessary database table for storing fly models:
```bash
php artisan migrate
```## 📘 Usage
### Creating and Using Fly Models
With FlyModel, you can dynamically create models and perform various operations. Here’s how:
Instantiate a Model with a Deck
```php
$building = FlyModel::of('building');
```Save the Model if not saved or created before
```php
$building->save();
```Perform Field Operations
```php
$building->flexy->name = 'Headquarter Building'
$building->flexy->address = 'Ali Pasha Ave. number 10';
$building->flexy->city = 'Ä°stanbul';
$building->flexy->floor = 7;
$building->flexy->area = 313;
$building->flexy->active = true;$building->save();
```Perform Eloquent Operations
```php
$buildings = FlyModel::of('building')->all();$istanbulBuildings = FlyModel::of('building')
->where('flexy_city', 'Ä°stanbul')
->get();$largeBuildings = FlyModel::of('building')
->where('flexy_area', '>' 500)
->orderBy('flexy_area')
->get();
$highBuildingsInIstanbul = FlyModel::of('building')
->where('flexy_floor', '>' 10)
->where('flexy_city', 'Ä°stanbul')
->get();
```## 🧪 Testing
FlyModel integrates with Laravel’s testing environment. Here’s an example of how to write tests for it:
## 💬 Contributing
We welcome contributions to improve FlyModel!
##