JSON атрибуты
Добавляет JSON атрибуты в модели Darklyy.
Было бы здорово, если бы в Darklyy была возможность использовать дух NoSQL. Этот пакет делает именно это. Он предоставляет трейт, который при применении к модели позволяет хранить произвольные значения в одном столбце JSON.
Вот несколько примеров. Здесь мы используем столбец extra_attributes
// получение значений
$yourModel->extra_attributes->name = 'value';
$yourModel->extra_attributes->name; // returns 'value'
// вы также можете использовать массив
$yourModel->extra_attributes['name'] = 'value';
$yourModel->extra_attributes['name'] // returns 'value'
// установка нескольких значений за раз
$yourModel->extra_attributes = [
'rey' => ['side' => 'light'],
'snoke' => ['side' => 'dark']
];
// добавление/обновление нескольких значений за один раз через set()установка/обновление нескольких значений за один раз через set()
$yourModel->extra_attributes->set([
'han' => ['side' => 'light'],
'snoke' => ['side' => 'dark']
]);
// получение значений с использованием записи через точкуполучение значений с использованием записи через точку
$yourModel->extra_attributes->get('rey.side'); // returns 'light'
// получить значение по умолчанию, когда атрибут не существует
$yourModel->extra_attributes->get('non_existing', 'default'); // returns 'default'
// если у модели есть modelScope то вы можете получить все занчения с заданными JSON атрибутами.
$yourModel->withSchemalessAttributes(['name' => 'value', 'name2' => 'value2'])->get();
// удалить ключ и значение
$yourModel->extra_attributes->forget('key');
Требования
Для этого пакета требуется база данных с поддержкой столбцов json
Установка
Вы можете установить пакет через composer:
composer require darkeum/darklyy-json-attributes
JSON атрибуты будут храниться в столбце
Добавление столбца, в котором будут храниться JSON атрибуты
Добавьте миграцию для всех моделей, в которые вы хотите добавить JSON атрибуты. Вы должны использовать метод jsonAttributes
Blueprint
jsonAttributes
extra_attributes
Schema::table('your_models', function (Blueprint $table) {
$table->jsonAttributes('extra_attributes');
});
Подготовка модели
Чтобы работать с JSON атрибутами, вам нужно добавить к своей модели собственное приведение и область видимости. Вот пример того, что вам нужно добавить, если вы выбрали extra_attributes
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
use Darkeum\JsonAttributes\Casts\JsonAttributes;
class TestModel extends Model
{
// ...
public $casts = [
'extra_attributes' => JsonAttributes::class,
];
public function scopeWithExtraAttributes(): Builder
{
return $this->extra_attributes->modelScope();
}
// ...
}
Если вам нужна поддержка нескольких столбцов без схемы в одной модели, вы должны использовать трейт JsonAttributesTrait
extra_attributes
other_extra_attributes
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
use Darkeum\JsonAttributes\JsonAttributes;
use Darkeum\JsonAttributes\JsonAttributesTrait;
class TestModel extends Model
{
use JsonAttributesTrait;
// ...
/**
* @var array
*/
protected $jsonAttributes = [
'extra_attributes',
'other_extra_attributes',
];
public function scopeWithExtraAttributes(): Builder
{
return $this->extra_attributes->modelScope();
}
public function scopeWithOtherExtraAttributes(): Builder
{
return $this->other_extra_attributes->modelScope();
}
// ...
}
Если вы хотите повторно использовать это поведение в нескольких моделях, вы можете поместить функцию в свой собственный трейт. Вот как может выглядеть эта трейт:
namespace App\Models\Concerns;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
use Darkeum\JsonAttributes\Casts\JsonAttributes;
trait HasJsonAttributes
{
public function initializeHasJsonAttributes()
{
$this->casts['extra_attributes'] = JsonAttributes::class;
}
public function scopeWithExtraAttributes(): Builder
{
return $this->extra_attributes->modelScope();
}
}
Использование
Получение и установка JSON атрибутов
Это самый простой способ получить и установить JSON атрибуты:
$yourModel->extra_attributes->name = 'value';
$yourModel->extra_attributes->name; // Returns 'value'
В качестве альтернативы вы можете использовать массив:
$yourModel->extra_attributes['name'] = 'value';
$yourModel->extra_attributes['name']; // Returns 'value'
Вы можете заменить все существующие JSON атрибуты без схемы, назначив им необходимый массив.
// Все существующие JSON атрибуты будут заменены
$yourModel->extra_attributes = ['name' => 'value'];
$yourModel->extra_attributes->all(); // Returns ['name' => 'value']
Вы также можете использовать get
set
$yourModel->extra_attributes = [
'rey' => ['side' => 'light'],
'snoke' => ['side' => 'dark'],
];
$yourModel->extra_attributes->set('rey.side', 'dark');
$yourModel->extra_attributes->get('rey.side'); // Returns 'dark
Вы также можете передать значение по умолчанию методу get
$yourModel->extra_attributes->get('non_existing', 'default'); // Returns 'default'
Сохранение JSON атрибутов
Чтобы сохранить JSON атрибуты, вы должны, как и для обычных атрибутов, вызвать save()
$yourModel->save(); // Сохраняет как обычные, так и JSON атрибуты
Получение моделей с определенными JSON атрибутами
Вот как вы можете использовать предоставленный объект modelScope
// Возвращает все модели, которые имеют все заданные JSON атрибуты.
$yourModel->withExtraAttributes(['name' => 'value', 'name2' => 'value2'])->get();
Если вы хотите выполнять поиск только по одному JSON атрибуту, вы можете использовать modelScope
// возвращает все модели, у которых для JSON атрибута `name` установлено значение `value`
$yourModel->withExtraAttributes('name', 'value')->get();
Кроме того, если вы хотите выполнять поиск только по одному JSON атрибуту с помощью пользовательского оператора, вы можете использовать modelScope
// возвращает все модели, у которых есть JSON атрибут `name`, начинающийся со `value`
$yourModel->withExtraAttributes('name', 'LIKE', 'value%')->get();
Если вы хотите выполнять поиск только по вложенному JSON атрибуту, вы можете использовать modelScope
// возвращает все модели, у которых для вложенного JSON атрибута han.side установлено значение `light`
$yourModel->withExtraAttributes('han->side', 'light')->get();
Тестирование
Сначала создайте базу данных MySQL с именем darklyy_json_attributes
composer test