mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-31 03:37:31 -04:00 
			
		
		
		
	Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions. You may customize the code style applied by adding a [PHP CS Fixer][1] or [PHP CodeSniffer][2] ruleset to your project root. Feel free to use [Shift's Laravel ruleset][3] to help you get started. For more information on customizing the code style applied by Shift, [watch this short video][4]. [1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer [2]: https://github.com/squizlabs/PHP_CodeSniffer [3]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200 [4]: https://laravelshift.com/videos/shift-code-style
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Invoice Ninja (https://invoiceninja.com).
 | |
|  *
 | |
|  * @link https://github.com/invoiceninja/invoiceninja source repository
 | |
|  *
 | |
|  * @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com)
 | |
|  *
 | |
|  * @license https://www.elastic.co/licensing/elastic-license
 | |
|  */
 | |
| 
 | |
| namespace App\Utils\Traits;
 | |
| 
 | |
| use App\Libraries\MultiDB;
 | |
| use Hashids\Hashids;
 | |
| use Illuminate\Support\Str;
 | |
| 
 | |
| /**
 | |
|  * Class MakesHash.
 | |
|  */
 | |
| trait MakesHash
 | |
| {
 | |
|     /**
 | |
|      * Creates a simple alphanumeric Hash.
 | |
|      * @return string - asd89f7as89df6asf78as6fds
 | |
|      */
 | |
|     public function createHash() : string
 | |
|     {
 | |
|         return Str::random(config('ninja.key_length'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creates a simple alphanumeric Hash which is prepended with a encoded database prefix.
 | |
|      *
 | |
|      * @param $db - Full database name
 | |
|      * @return string 01-asfas8df76a78f6a78dfsdf
 | |
|      */
 | |
|     public function createDbHash($db) : string
 | |
|     {
 | |
|         if (config('ninja.db.multi_db_enabled')) {
 | |
|             return  $this->getDbCode($db).'-'.Str::random(config('ninja.key_length'));
 | |
|         }
 | |
| 
 | |
|         return Str::random(config('ninja.key_length'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param $db - Full database name
 | |
|      * @return string - hashed and encoded int 01,02,03,04
 | |
|      */
 | |
|     public function getDbCode($db) : string
 | |
|     {
 | |
|         $hashids = new Hashids(config('ninja.hash_salt'), 10);
 | |
| 
 | |
|         return $hashids->encode(str_replace(MultiDB::DB_PREFIX, '', $db));
 | |
|     }
 | |
| 
 | |
|     public function encodePrimaryKey($value) : string
 | |
|     {
 | |
|         $hashids = new Hashids(config('ninja.hash_salt'), 10);
 | |
| 
 | |
|         return $hashids->encode($value);
 | |
|     }
 | |
| 
 | |
|     public function decodePrimaryKey($value) : string
 | |
|     {
 | |
|         try {
 | |
|             $hashids = new Hashids(config('ninja.hash_salt'), 10);
 | |
| 
 | |
|             $decoded_array = $hashids->decode($value);
 | |
| 
 | |
|             if (! is_array($decoded_array)) {
 | |
|                 throw new \Exception('Invalid Primary Key');
 | |
|                 //response()->json(['error'=>'Invalid primary key'], 400);
 | |
|             }
 | |
| 
 | |
|             return $decoded_array[0];
 | |
|         } catch (\Exception $e) {
 | |
|             return response()->json(['error'=>'Invalid primary key'], 400);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function transformKeys($keys)
 | |
|     {
 | |
|         if (is_array($keys)) {
 | |
|             foreach ($keys as &$value) {
 | |
|                 $value = $this->decodePrimaryKey($value);
 | |
|             }
 | |
| 
 | |
|             return $keys;
 | |
|         } else {
 | |
|             return $this->decodePrimaryKey($keys);
 | |
|         }
 | |
|     }
 | |
| }
 |