mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 11:19:24 -04:00 
			
		
		
		
	Updates
This commit is contained in:
		
							parent
							
								
									74dbf8884b
								
							
						
					
					
						commit
						d0b09b5bd1
					
				| @ -8,7 +8,7 @@ APP_URL=http://localhost | |||||||
| DB_CONNECTION=mysql | DB_CONNECTION=mysql | ||||||
| MULTI_DB_ENABLED=false | MULTI_DB_ENABLED=false | ||||||
| 
 | 
 | ||||||
| DB_HOST=localhost | DB_HOST=127.0.0.1 | ||||||
| DB_DATABASE=ninja | DB_DATABASE=ninja | ||||||
| DB_USERNAME=ninja | DB_USERNAME=ninja | ||||||
| DB_PASSWORD=ninja | DB_PASSWORD=ninja | ||||||
|  | |||||||
| @ -130,8 +130,8 @@ class Kernel extends ConsoleKernel | |||||||
|      */ |      */ | ||||||
|     protected function commands() |     protected function commands() | ||||||
|     { |     { | ||||||
|         // $this->load(__DIR__.'/Commands');
 |         $this->load(__DIR__.'/Commands'); | ||||||
| 
 | 
 | ||||||
|         // require base_path('routes/console.php');
 |         require base_path('routes/console.php'); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -113,13 +113,6 @@ class AppServiceProvider extends ServiceProvider | |||||||
|             return $this; |             return $this; | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|         /* Extension for custom mailers */ |  | ||||||
| 
 |  | ||||||
|         /* Convenience helper for testing s*/ |  | ||||||
|         ParallelTesting::setUpTestDatabase(function ($database, $token) { |  | ||||||
|             Artisan::call('db:seed'); |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function register(): void |     public function register(): void | ||||||
|  | |||||||
| @ -1,277 +0,0 @@ | |||||||
| <?php |  | ||||||
| /** |  | ||||||
|  * Invoice Ninja (https://invoiceninja.com). |  | ||||||
|  * |  | ||||||
|  * @link https://github.com/invoiceninja/invoiceninja source repository |  | ||||||
|  * |  | ||||||
|  * @copyright Copyright (c) 2023. Invoice Ninja LLC (https://invoiceninja.com) |  | ||||||
|  * |  | ||||||
|  * @license https://www.elastic.co/licensing/elastic-license |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| namespace App\Providers; |  | ||||||
| 
 |  | ||||||
| use App\Libraries\MultiDB; |  | ||||||
| use Illuminate\Contracts\Auth\Authenticatable as UserContract; |  | ||||||
| use Illuminate\Contracts\Auth\UserProvider; |  | ||||||
| use Illuminate\Contracts\Hashing\Hasher as HasherContract; |  | ||||||
| use Illuminate\Contracts\Support\Arrayable; |  | ||||||
| use Illuminate\Database\Eloquent\Model; |  | ||||||
| use Illuminate\Support\Str; |  | ||||||
| 
 |  | ||||||
| class MultiDatabaseUserProvider implements UserProvider |  | ||||||
| { |  | ||||||
|     /** |  | ||||||
|      * The hasher implementation. |  | ||||||
|      * |  | ||||||
|      * @var HasherContract |  | ||||||
|      */ |  | ||||||
|     protected $hasher; |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * The Eloquent user model. |  | ||||||
|      * |  | ||||||
|      * @var string |  | ||||||
|      */ |  | ||||||
|     protected $model; |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Create a new database user provider. |  | ||||||
|      * |  | ||||||
|      * @param HasherContract $hasher |  | ||||||
|      * @param  string  $model |  | ||||||
|      * @return void |  | ||||||
|      */ |  | ||||||
|     public function __construct(HasherContract $hasher, $model) |  | ||||||
|     { |  | ||||||
|         $this->model = $model; |  | ||||||
|         $this->hasher = $hasher; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Retrieve a user by their unique identifier. |  | ||||||
|      * |  | ||||||
|      * @param  mixed  $identifier |  | ||||||
|      * @return UserContract|null |  | ||||||
|      */ |  | ||||||
|     public function retrieveById($identifier) |  | ||||||
|     { |  | ||||||
|         $this->setDefaultDatabase($identifier); |  | ||||||
| 
 |  | ||||||
|         $model = $this->createModel(); |  | ||||||
| 
 |  | ||||||
|         return $model->newQuery() |  | ||||||
|             ->where($model->getAuthIdentifierName(), $identifier) |  | ||||||
|             ->first(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Retrieve a user by their unique identifier and "remember me" token. |  | ||||||
|      * |  | ||||||
|      * @param  mixed  $identifier |  | ||||||
|      * @param  string  $token |  | ||||||
|      * @return UserContract|null |  | ||||||
|      */ |  | ||||||
|     public function retrieveByToken($identifier, $token) |  | ||||||
|     { |  | ||||||
|         $this->setDefaultDatabase($identifier, $token); |  | ||||||
| 
 |  | ||||||
|         $model = $this->createModel(); |  | ||||||
| 
 |  | ||||||
|         $model = $model->where($model->getAuthIdentifierName(), $identifier)->first(); |  | ||||||
| 
 |  | ||||||
|         if (! $model) { |  | ||||||
|             return null; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         $rememberToken = $model->getRememberToken(); |  | ||||||
| 
 |  | ||||||
|         return $rememberToken && hash_equals($rememberToken, $token) ? $model : null; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Update the "remember me" token for the given user in storage. |  | ||||||
|      * |  | ||||||
|      * @param UserContract|Model  $user |  | ||||||
|      * @param  string  $token |  | ||||||
|      * @return void |  | ||||||
|      */ |  | ||||||
|     public function updateRememberToken(UserContract $user, $token) |  | ||||||
|     { |  | ||||||
|         $user->setRememberToken($token); |  | ||||||
| 
 |  | ||||||
|         $timestamps = $user->timestamps; |  | ||||||
| 
 |  | ||||||
|         $user->timestamps = false; |  | ||||||
| 
 |  | ||||||
|         $user->save(); |  | ||||||
| 
 |  | ||||||
|         $user->timestamps = $timestamps; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Retrieve a user by the given credentials. |  | ||||||
|      * |  | ||||||
|      * @param  array  $credentials |  | ||||||
|      * @return UserContract|null |  | ||||||
|      */ |  | ||||||
|     public function retrieveByCredentials(array $credentials) |  | ||||||
|     { |  | ||||||
|         if (empty($credentials) || |  | ||||||
|            (count($credentials) === 1 && |  | ||||||
|             array_key_exists('password', $credentials))) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         $this->setDefaultDatabase(false, $credentials['email'], false); |  | ||||||
| 
 |  | ||||||
|         // First we will add each credential element to the query as a where clause.
 |  | ||||||
|         // Then we can execute the query and, if we found a user, return it in a
 |  | ||||||
|         // Eloquent User "model" that will be utilized by the Guard instances.
 |  | ||||||
|         $query = $this->createModel()->newQuery(); |  | ||||||
| 
 |  | ||||||
|         foreach ($credentials as $key => $value) { |  | ||||||
|             if (Str::contains($key, 'password')) { |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if (is_array($value) || $value instanceof Arrayable) { |  | ||||||
|                 $query->whereIn($key, $value); |  | ||||||
|             } else { |  | ||||||
|                 $query->where($key, $value); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         return $query->first(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Validate a user against the given credentials. |  | ||||||
|      * |  | ||||||
|      * @param UserContract $user |  | ||||||
|      * @param  array  $credentials |  | ||||||
|      * @return bool |  | ||||||
|      */ |  | ||||||
|     public function validateCredentials(UserContract $user, array $credentials) |  | ||||||
|     { |  | ||||||
|         $plain = $credentials['password']; |  | ||||||
| 
 |  | ||||||
|         return $this->hasher->check($plain, $user->getAuthPassword()); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Create a new instance of the model. |  | ||||||
|      * |  | ||||||
|      * @return Model |  | ||||||
|      */ |  | ||||||
|     public function createModel() |  | ||||||
|     { |  | ||||||
|         $class = '\\'.ltrim($this->model, '\\'); |  | ||||||
| 
 |  | ||||||
|         return new $class; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Gets the hasher implementation. |  | ||||||
|      * |  | ||||||
|      * @return HasherContract |  | ||||||
|      */ |  | ||||||
|     public function getHasher() |  | ||||||
|     { |  | ||||||
|         return $this->hasher; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Sets the hasher implementation. |  | ||||||
|      * |  | ||||||
|      * @param HasherContract $hasher |  | ||||||
|      * @return $this |  | ||||||
|      */ |  | ||||||
|     public function setHasher(HasherContract $hasher) |  | ||||||
|     { |  | ||||||
|         $this->hasher = $hasher; |  | ||||||
| 
 |  | ||||||
|         return $this; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Gets the name of the Eloquent user model. |  | ||||||
|      * |  | ||||||
|      * @return string |  | ||||||
|      */ |  | ||||||
|     public function getModel() |  | ||||||
|     { |  | ||||||
|         return $this->model; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Sets the name of the Eloquent user model. |  | ||||||
|      * |  | ||||||
|      * @param  string  $model |  | ||||||
|      * @return $this |  | ||||||
|      */ |  | ||||||
|     public function setModel($model) |  | ||||||
|     { |  | ||||||
|         $this->model = $model; |  | ||||||
| 
 |  | ||||||
|         return $this; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Sets correct database by variable. |  | ||||||
|      * @param bool $id |  | ||||||
|      * @param bool $email |  | ||||||
|      * @param bool $token |  | ||||||
|      */ |  | ||||||
|     private function setDefaultDatabase($id = false, $email = false, $token = false) : void |  | ||||||
|     { |  | ||||||
|         foreach (MultiDB::getDbs() as $database) { |  | ||||||
|             $this->setDB($database); |  | ||||||
| 
 |  | ||||||
|             /** Make sure we hook into the correct guard class */ |  | ||||||
|             $query = $this->conn->table((new $this->model)->getTable()); |  | ||||||
| 
 |  | ||||||
|             if ($id) { |  | ||||||
|                 $query->where('id', '=', $id); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if ($email) { |  | ||||||
|                 $query->where('email', '=', $email); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             $user = $query->get(); |  | ||||||
| 
 |  | ||||||
|             if (count($user) >= 1) { |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             $query = $this->conn->table('company_tokens'); |  | ||||||
| 
 |  | ||||||
|             if ($token) { |  | ||||||
|                 $query->whereRaw('BINARY `token`= ?', $token); |  | ||||||
| 
 |  | ||||||
|                 $token = $query->get(); |  | ||||||
| 
 |  | ||||||
|                 if (count($token) >= 1) { |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * Sets the database at runtime. |  | ||||||
|      * @param $database |  | ||||||
|      */ |  | ||||||
|     private function setDB($database) |  | ||||||
|     { |  | ||||||
|         /** Get the database name we want to switch to*/ |  | ||||||
|         $db_name = config('database.connections.'.$database.'.database'); |  | ||||||
| 
 |  | ||||||
|         /* This will set the default configuration for the request / session?*/ |  | ||||||
|         config(['database.default' => $database]); |  | ||||||
| 
 |  | ||||||
|         /* Set the connection to complete the user authentication */ |  | ||||||
|         $this->conn = app('db')->connection(config('database.connections.database.'.$database)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @ -20,7 +20,6 @@ use Illuminate\Cache\RateLimiting\Limit; | |||||||
| use Illuminate\Support\Facades\RateLimiter; | use Illuminate\Support\Facades\RateLimiter; | ||||||
| use App\Http\Middleware\ThrottleRequestsWithPredis; | use App\Http\Middleware\ThrottleRequestsWithPredis; | ||||||
| use Illuminate\Routing\Middleware\ThrottleRequests; | use Illuminate\Routing\Middleware\ThrottleRequests; | ||||||
| use Illuminate\Routing\Middleware\ThrottleRequestsWithRedis; |  | ||||||
| use Illuminate\Database\Eloquent\ModelNotFoundException as ModelNotFoundException; | use Illuminate\Database\Eloquent\ModelNotFoundException as ModelNotFoundException; | ||||||
| use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; | use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user