Weave Code
Code Weaver
Helps Laravel developers discover, compare, and choose open-source packages. See popularity, security, maintainers, and scores at a glance to make better decisions.
Feedback
Share your thoughts, report bugs, or suggest improvements.
Subject
Message

Ignorable Observers Laravel Package

zachflower/ignorable-observers

View on GitHub
Deep Wiki
Context7

Ignorable Observers

Code Climate build Packagist

Dynamically disable/enable Laravel's Eloquent model observers. This library provides the ability to temporarily disable observable events for Eloquent models. For example, temporarily disable observers that kick off emails, push notifications, or queued calculations when performing a large number of database inserts or updates.

Installation

Install using composer:

composer require zachflower/ignorable-observers

Usage

To give an Eloquent model the ability to temporarily ignore observers, simply add the IgnorableObservers trait:

<?php namespace App;

use Illuminate\Database\Eloquent\Model;
use IgnorableObservers\IgnorableObservers;

class ExampleModel extends Model {
  use IgnorableObservers;
}

Then, call the ignoreObservableEvents() static method to ignore all observers for that model:

ExampleModel::ignoreObservableEvents();

The ignoreObservableEvents() method also accepts an array of observers to be ignored. For example, the following line would ignore only the saved and created observers:

ExampleModel::ignoreObservableEvents(['saved', 'created']);

To stop ignoring a model's observers, call the unignoreObservableEvents() static method:

ExampleModel::unignoreObservableEvents();

The unignoreObservableEvents() method also accepts an array of observers to unignore, giving you total control over which observers to enable and disable:

ExampleModel::unignoreObservableEvents(['saved']);

Example

The following example ignores any saved and created observers for the ExampleModel, inserts 100 rows into the database, and then "unignores" those observers when the operation is completed:

ExampleModel::ignoreObservableEvents('saved', 'created');

for ( $i = 0; $i <= 100; $i++ ) {
  ExampleModel::create([
    'data' => $i
  ]);
}

ExampleModel::unignoreObservableEvents();

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

License

Ignorable Observers is an open-sourced library licensed under the MIT license.

Weaver

How can I help you explore Laravel packages today?

Conversation history is not saved when not logged in.
Prompt
Add packages to context
No packages found.
milito/query-filter
apiboxsym/user-bundle
apiboxsym/health-check-bundle
jayeshmepani/jpl-moshier-ephemeris-php
elnasnato/laraliveui
labrodev/rest-sdk
sampaui/sampaui
babelqueue/php-sdk
facebook/capi-param-builder-php
babelqueue/symfony
hamzi/corewatch
minionfactory/raw-hydrator
hexters/coinpayment
rjcodes/rjcms
act-training/laravel-permissions-manager
alimarchal/laravel-chart-of-accounts
babenkoivan/elastic-scout-driver
mkwebdesign/filament-watchdog-v5
renatomarinho/laravel-page-speed
zedmagdy/filament-business-hours