11
									
								
								.htaccess
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								.htaccess
									
									
									
									
									
								
							| @@ -3,8 +3,19 @@ | |||||||
|         Options -MultiViews |         Options -MultiViews | ||||||
|     </IfModule> |     </IfModule> | ||||||
|  |  | ||||||
|  |     Options +FollowSymlinks | ||||||
|  |  | ||||||
|  |     # Prevent Directory listing | ||||||
|  |     Options -Indexes | ||||||
|  |  | ||||||
|     RewriteEngine On |     RewriteEngine On | ||||||
|  |  | ||||||
|  |     # Prevent Direct Access To Protected Folders | ||||||
|  |     RewriteRule ^(app|bootstrap|config|database|resources|routes|storage|tests)/(.*) / [L,R=301] | ||||||
|  |  | ||||||
|  |     # Prevent Direct Access To modules/vendor Folders Except Assets | ||||||
|  |     RewriteRule ^(modules|vendor)/(.*)\.((?!ico|gif|jpg|jpeg|png|js|css|less|sass|font|woff|woff2|eot|ttf|svg).)*$ / [L,R=301] | ||||||
|  |  | ||||||
|     # Redirect Trailing Slashes If Not A Folder... |     # Redirect Trailing Slashes If Not A Folder... | ||||||
|     RewriteCond %{REQUEST_FILENAME} !-d |     RewriteCond %{REQUEST_FILENAME} !-d | ||||||
|     RewriteRule ^(.*)/$ /$1 [L,R=301] |     RewriteRule ^(.*)/$ /$1 [L,R=301] | ||||||
|   | |||||||
| @@ -106,7 +106,7 @@ class Users extends Controller | |||||||
|         // Upload picture |         // Upload picture | ||||||
|         $picture = $request->file('picture'); |         $picture = $request->file('picture'); | ||||||
|         if ($picture && $picture->isValid()) { |         if ($picture && $picture->isValid()) { | ||||||
|             $request['picture'] = $picture->store('uploads/users'); |             $request['picture'] = $picture->store('users'); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Do not reset password if not entered/changed |         // Do not reset password if not entered/changed | ||||||
|   | |||||||
							
								
								
									
										68
									
								
								app/Http/Controllers/Common/Uploads.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								app/Http/Controllers/Common/Uploads.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace App\Http\Controllers\Common; | ||||||
|  |  | ||||||
|  | use App\Http\Controllers\Controller; | ||||||
|  | use Storage; | ||||||
|  |  | ||||||
|  | class Uploads extends Controller | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Get the specified resource. | ||||||
|  |      * | ||||||
|  |      * @param  $folder | ||||||
|  |      * @param  $file | ||||||
|  |      * @return boolean|Response | ||||||
|  |      */ | ||||||
|  |     public function get($folder, $file) | ||||||
|  |     { | ||||||
|  |         // Get file path | ||||||
|  |         if (!$path = $this->getPath($folder, $file)) { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return response()->file($path); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Download the specified resource. | ||||||
|  |      * | ||||||
|  |      * @param  $folder | ||||||
|  |      * @param  $file | ||||||
|  |      * @return boolean|Response | ||||||
|  |      */ | ||||||
|  |     public function download($folder, $file) | ||||||
|  |     { | ||||||
|  |         // Get file path | ||||||
|  |         if (!$path = $this->getPath($folder, $file)) { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return response()->download($path); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the full path of resource. | ||||||
|  |      * | ||||||
|  |      * @param  $folder | ||||||
|  |      * @param  $file | ||||||
|  |      * @return boolean|string | ||||||
|  |      */ | ||||||
|  |     protected function getPath($folder, $file) | ||||||
|  |     { | ||||||
|  |         // Add company id | ||||||
|  |         if ($folder != 'users') { | ||||||
|  |             $folder = session('company_id') . '/' . $folder; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $path = $folder . '/' . $file; | ||||||
|  |  | ||||||
|  |         if (!Storage::exists($path)) { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $full_path = Storage::path($path); | ||||||
|  |  | ||||||
|  |         return $full_path; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -79,24 +79,21 @@ class User extends Authenticatable | |||||||
|      */ |      */ | ||||||
|     public function getPictureAttribute($value) |     public function getPictureAttribute($value) | ||||||
|     { |     { | ||||||
|         $pic = ''; |         // Check if we should use gravatar | ||||||
|  |         if (setting('general.use_gravatar', '0') == '1') { | ||||||
|         if (is_file(base_path($value))) { |  | ||||||
|             $pic = $value; |  | ||||||
|         } elseif (setting('general.use_gravatar', '0') == '1') { |  | ||||||
|             // Check for gravatar |             // Check for gravatar | ||||||
|             $url = 'https://www.gravatar.com/avatar/' . md5(strtolower($this->getAttribute('email'))).'?size=90&d=404'; |             $url = 'https://www.gravatar.com/avatar/' . md5(strtolower($this->getAttribute('email'))).'?size=90&d=404'; | ||||||
|  |  | ||||||
|             $client = new \GuzzleHttp\Client(['verify' => false]); |             $client = new \GuzzleHttp\Client(['verify' => false]); | ||||||
|  |  | ||||||
|             try { |             try { | ||||||
|                 $pic = $client->request('GET', $url)->getBody()->getContents(); |                 $value = $client->request('GET', $url)->getBody()->getContents(); | ||||||
|             } catch (RequestException $e) { |             } catch (RequestException $e) { | ||||||
|                 // 404 Not Found |                 // 404 Not Found | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return $pic; |         return $value; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -19,7 +19,11 @@ trait Uploads | |||||||
|  |  | ||||||
|         $file_name = $file->getClientOriginalName(); |         $file_name = $file->getClientOriginalName(); | ||||||
|  |  | ||||||
|         $path = 'storage/app/' . $file->storeAs('uploads/' . $company_id . '/' . $folder, $file_name); |         // Upload file | ||||||
|  |         $file->storeAs($company_id . '/' . $folder, $file_name); | ||||||
|  |  | ||||||
|  |         // Prepare db path | ||||||
|  |         $path = $folder . '/' . $file_name; | ||||||
|  |  | ||||||
|         return $path; |         return $path; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ return [ | |||||||
|     | |     | | ||||||
|     */ |     */ | ||||||
|  |  | ||||||
|     'default' => 'local', |     'default' => 'uploads', | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|     |-------------------------------------------------------------------------- |     |-------------------------------------------------------------------------- | ||||||
| @@ -55,6 +55,13 @@ return [ | |||||||
|             'visibility' => 'public', |             'visibility' => 'public', | ||||||
|         ], |         ], | ||||||
|  |  | ||||||
|  |         'uploads' => [ | ||||||
|  |             'driver' => 'local', | ||||||
|  |             'root' => storage_path('app/uploads'), | ||||||
|  |             'url' => env('APP_URL').'/uploads', | ||||||
|  |             'visibility' => 'private', | ||||||
|  |         ], | ||||||
|  |  | ||||||
|         's3' => [ |         's3' => [ | ||||||
|             'driver' => 's3', |             'driver' => 's3', | ||||||
|             'key' => env('AWS_KEY'), |             'key' => env('AWS_KEY'), | ||||||
|   | |||||||
| @@ -40,7 +40,7 @@ | |||||||
|                 <tbody> |                 <tbody> | ||||||
|                 @foreach($users as $item) |                 @foreach($users as $item) | ||||||
|                     <tr> |                     <tr> | ||||||
|                         <td><a href="{{ url('auth/users/' . $item->id . '/edit') }}"><img src="{{ asset($item->picture) }}" class="users-image" alt="{{ $item->name }}" title="{{ $item->name }}"> {{ $item->name }}</a></td> |                         <td><a href="{{ url('auth/users/' . $item->id . '/edit') }}"><img src="{{ Storage::url($item->picture) }}" class="users-image" alt="{{ $item->name }}" title="{{ $item->name }}"> {{ $item->name }}</a></td> | ||||||
|                         <td>{{ $item->email }}</td> |                         <td>{{ $item->email }}</td> | ||||||
|                         <td style="vertical-align: middle;"> |                         <td style="vertical-align: middle;"> | ||||||
|                             @foreach($item->roles as $role) |                             @foreach($item->roles as $role) | ||||||
|   | |||||||
| @@ -45,7 +45,7 @@ | |||||||
|                 <tbody> |                 <tbody> | ||||||
|                 @foreach($items as $item) |                 @foreach($items as $item) | ||||||
|                     <tr> |                     <tr> | ||||||
|                         <td><img src="{{ asset($item->picture) }}" class="img-thumbnail" width="50" alt="{{ $item->name }}"></td> |                         <td><img src="{{ Storage::url($item->picture) }}" class="img-thumbnail" width="50" alt="{{ $item->name }}"></td> | ||||||
|                         <td><a href="{{ url('items/items/' . $item->id . '/edit') }}">{{ $item->name }}</a></td> |                         <td><a href="{{ url('items/items/' . $item->id . '/edit') }}">{{ $item->name }}</a></td> | ||||||
|                         <td>{{ $item->category ? $item->category->name : trans('general.na') }}</td> |                         <td>{{ $item->category ? $item->category->name : trans('general.na') }}</td> | ||||||
|                         <td>{{ $item->quantity }}</td> |                         <td>{{ $item->quantity }}</td> | ||||||
|   | |||||||
| @@ -153,7 +153,7 @@ | |||||||
|                 <li class="dropdown user user-menu"> |                 <li class="dropdown user user-menu"> | ||||||
|                     <a href="#" class="dropdown-toggle" data-toggle="dropdown"> |                     <a href="#" class="dropdown-toggle" data-toggle="dropdown"> | ||||||
|                         @if ($user->picture) |                         @if ($user->picture) | ||||||
|                             <img src="{{ asset($user->picture) }}" class="user-image" alt="User Image"> |                             <img src="{{ Storage::url($user->picture) }}" class="user-image" alt="User Image"> | ||||||
|                         @else |                         @else | ||||||
|                             <i class="fa fa-user-o"></i> |                             <i class="fa fa-user-o"></i> | ||||||
|                         @endif |                         @endif | ||||||
| @@ -165,7 +165,7 @@ | |||||||
|                         <!-- User image --> |                         <!-- User image --> | ||||||
|                         <li class="user-header"> |                         <li class="user-header"> | ||||||
|                             @if ($user->picture) |                             @if ($user->picture) | ||||||
|                             <img src="{{ asset($user->picture) }}" class="img-circle" alt="User Image"> |                             <img src="{{ Storage::url($user->picture) }}" class="img-circle" alt="User Image"> | ||||||
|                             @else |                             @else | ||||||
|                                 <i class="fa fa-4 fa-user-o" style="color: #fff; font-size: 7em;"></i> |                                 <i class="fa fa-4 fa-user-o" style="color: #fff; font-size: 7em;"></i> | ||||||
|                             @endif |                             @endif | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|         <!-- Sidebar user panel --> |         <!-- Sidebar user panel --> | ||||||
|         <div class="user-panel"> |         <div class="user-panel"> | ||||||
|             <div class="pull-left image"> |             <div class="pull-left image"> | ||||||
|                 <img src="{{ asset(setting('general.company_logo', 'public/img/company.png')) }}" class="img-circle" alt="@setting('general.company_name')"> |                 <img src="{{ setting('general.company_logo') ? Storage::url(setting('general.company_logo')) : asset('public/img/company.png') }}" class="img-circle" alt="@setting('general.company_name')"> | ||||||
|             </div> |             </div> | ||||||
|             <div class="pull-left info"> |             <div class="pull-left info"> | ||||||
|                 <p>{{ str_limit(setting('general.company_name'), 22) }}</p> |                 <p>{{ str_limit(setting('general.company_name'), 22) }}</p> | ||||||
|   | |||||||
| @@ -9,6 +9,11 @@ | |||||||
| Route::group(['middleware' => ['auth', 'language', 'adminmenu', 'permission:read-admin-panel']], function () { | Route::group(['middleware' => ['auth', 'language', 'adminmenu', 'permission:read-admin-panel']], function () { | ||||||
|     Route::get('/', 'Dashboard\Dashboard@index'); |     Route::get('/', 'Dashboard\Dashboard@index'); | ||||||
|  |  | ||||||
|  |     Route::group(['prefix' => 'uploads'], function () { | ||||||
|  |         Route::get('{folder}/{file}', 'Common\Uploads@get'); | ||||||
|  |         Route::get('{folder}/{file}/download', 'Common\Uploads@download'); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|     Route::group(['prefix' => 'search'], function () { |     Route::group(['prefix' => 'search'], function () { | ||||||
|         Route::get('search/search', 'Search\Search@search'); |         Route::get('search/search', 'Search\Search@search'); | ||||||
|         Route::resource('search', 'Search\Search'); |         Route::resource('search', 'Search\Search'); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user