first commit
This commit is contained in:
		
							
								
								
									
										76
									
								
								app/Scopes/Company.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								app/Scopes/Company.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,76 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
namespace App\Scopes;
 | 
			
		||||
 | 
			
		||||
use App;
 | 
			
		||||
use Illuminate\Database\Eloquent\Scope;
 | 
			
		||||
use Illuminate\Database\Eloquent\Model;
 | 
			
		||||
use Illuminate\Database\Eloquent\Builder;
 | 
			
		||||
 | 
			
		||||
class Company implements Scope
 | 
			
		||||
{
 | 
			
		||||
    /**
 | 
			
		||||
     * Apply the scope to a given Eloquent query builder.
 | 
			
		||||
     *
 | 
			
		||||
     * @param  \Illuminate\Database\Eloquent\Builder  $builder
 | 
			
		||||
     * @param  \Illuminate\Database\Eloquent\Model  $model
 | 
			
		||||
     * @return void
 | 
			
		||||
     */
 | 
			
		||||
    public function apply(Builder $builder, Model $model)
 | 
			
		||||
    {
 | 
			
		||||
        // Session not available in console
 | 
			
		||||
        if (App::runningInConsole()) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $table = $model->getTable();
 | 
			
		||||
 | 
			
		||||
        // Skip for specific tables
 | 
			
		||||
        $skip_tables = ['companies', 'jobs', 'migrations', 'notifications', 'permissions', 'role_user', 'roles', 'sessions', 'users'];
 | 
			
		||||
        if (in_array($table, $skip_tables)) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // Skip if already exists
 | 
			
		||||
        if ($this->exists($builder, 'company_id')) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // Apply company scope
 | 
			
		||||
        $company_id = session('company_id');
 | 
			
		||||
 | 
			
		||||
        $builder->where($table . '.company_id', '=', $company_id);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Check if scope exists.
 | 
			
		||||
     *
 | 
			
		||||
     * @param  \Illuminate\Database\Eloquent\Builder  $builder
 | 
			
		||||
     * @param  $column
 | 
			
		||||
     * @return boolean
 | 
			
		||||
     */
 | 
			
		||||
    protected function exists($builder, $column)
 | 
			
		||||
    {
 | 
			
		||||
        $query = $builder->getQuery();
 | 
			
		||||
 | 
			
		||||
        foreach ((array) $query->wheres as $key => $where) {
 | 
			
		||||
            if (empty($where) || empty($where['column'])) {
 | 
			
		||||
                continue;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if (strstr($where['column'], '.')) {
 | 
			
		||||
                $whr = explode('.', $where['column']);
 | 
			
		||||
 | 
			
		||||
                $where['column'] = $whr[1];
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if ($where['column'] != $column) {
 | 
			
		||||
                continue;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            return true;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user