2016-09-21 12:10:37 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
2019-07-14 16:28:46 +01:00
|
|
|
use App\AlbumDefaultAnonymousPermission;
|
2016-09-21 12:10:37 +01:00
|
|
|
use App\Configuration;
|
2016-10-06 16:58:02 +01:00
|
|
|
use App\Facade\UserConfig;
|
2016-09-21 12:10:37 +01:00
|
|
|
use App\Helpers\MiscHelper;
|
2016-10-06 15:07:30 +01:00
|
|
|
use App\Http\Requests\StoreUserRequest;
|
2019-07-14 16:28:46 +01:00
|
|
|
use App\Permission;
|
2016-10-27 11:36:37 +01:00
|
|
|
use App\Storage;
|
2016-09-21 12:10:37 +01:00
|
|
|
use App\User;
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
use Illuminate\Support\Facades\Artisan;
|
|
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
|
|
|
|
class InstallController extends Controller
|
|
|
|
{
|
2016-10-06 15:07:30 +01:00
|
|
|
public function administrator(StoreUserRequest $request)
|
2016-09-21 12:10:37 +01:00
|
|
|
{
|
2016-10-01 14:45:48 +01:00
|
|
|
// Validate we're at the required stage
|
|
|
|
$stage = 3;
|
|
|
|
if (intval($request->session()->get('install_stage')) < $stage)
|
2016-09-21 12:10:37 +01:00
|
|
|
{
|
2016-10-01 14:45:48 +01:00
|
|
|
return redirect(route('install.check'));
|
2016-09-21 12:10:37 +01:00
|
|
|
}
|
|
|
|
|
2016-10-06 15:07:30 +01:00
|
|
|
// If we already have an admin account, this step can be skipped
|
|
|
|
$canSkip = User::where('is_admin', true)->count() > 0;
|
|
|
|
|
|
|
|
if ($canSkip && $request->has('skip'))
|
|
|
|
{
|
2016-10-27 11:36:37 +01:00
|
|
|
return $this->completeSetup();
|
2016-10-06 15:07:30 +01:00
|
|
|
}
|
|
|
|
|
2016-10-01 14:45:48 +01:00
|
|
|
if ($request->method() == 'POST')
|
2016-09-21 12:10:37 +01:00
|
|
|
{
|
|
|
|
$user = new User();
|
|
|
|
$user->name = $request->get('name');
|
|
|
|
$user->email = $request->get('email');
|
|
|
|
$user->password = bcrypt($request->get('password'));
|
|
|
|
$user->is_admin = true;
|
|
|
|
$user->is_activated = true;
|
2019-07-28 08:17:17 +01:00
|
|
|
$user->enable_profile_page = true;
|
2016-09-21 12:10:37 +01:00
|
|
|
$user->save();
|
|
|
|
|
2016-10-27 11:36:37 +01:00
|
|
|
return $this->completeSetup();
|
2016-10-01 14:45:48 +01:00
|
|
|
}
|
|
|
|
|
2016-10-06 15:07:30 +01:00
|
|
|
return view('install.administrator', [
|
|
|
|
'can_skip' => $canSkip
|
|
|
|
]);
|
2016-10-01 14:45:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function check(Request $request)
|
|
|
|
{
|
|
|
|
// This is the first installation step therefore it doesn't need to verify the stage
|
|
|
|
|
|
|
|
if ($request->getMethod() == 'POST')
|
|
|
|
{
|
2017-09-29 12:54:55 +01:00
|
|
|
$request->session()->put('install_stage', 2);
|
2016-10-01 14:45:48 +01:00
|
|
|
return redirect(route('install.database'));
|
|
|
|
}
|
2016-09-21 12:10:37 +01:00
|
|
|
|
2016-10-01 14:45:48 +01:00
|
|
|
$canContinue = true;
|
2018-07-16 03:51:59 +01:00
|
|
|
$runtimeMinimum = '7.0.0'; // this minimum is imposed by Laravel 5.5
|
2016-10-06 15:07:30 +01:00
|
|
|
$runtimeVersion = phpversion();
|
|
|
|
$phpIsValid = version_compare($runtimeVersion, $runtimeMinimum) >= 0;
|
|
|
|
|
|
|
|
if (!$phpIsValid)
|
|
|
|
{
|
|
|
|
$canContinue = false;
|
|
|
|
}
|
|
|
|
|
2016-10-01 14:45:48 +01:00
|
|
|
$requiredModules = [
|
2016-10-01 15:24:22 +01:00
|
|
|
'curl' => 'installer.php_modules.curl',
|
2016-10-01 14:45:48 +01:00
|
|
|
'pdo_mysql' => 'installer.php_modules.mysql',
|
|
|
|
'gd' => 'installer.php_modules.gd'
|
|
|
|
];
|
|
|
|
$availableModules = [];
|
|
|
|
|
|
|
|
foreach ($requiredModules as $key => $langString)
|
|
|
|
{
|
|
|
|
$availableModules[$key] = extension_loaded($key);
|
|
|
|
if (!$availableModules[$key])
|
|
|
|
{
|
|
|
|
$canContinue = false;
|
|
|
|
}
|
2016-09-21 12:10:37 +01:00
|
|
|
}
|
|
|
|
|
2016-10-01 14:45:48 +01:00
|
|
|
$uploadLimit = MiscHelper::convertToBytes(ini_get('upload_max_filesize'));
|
|
|
|
$postMaxSize = MiscHelper::convertToBytes(ini_get('post_max_size'));
|
|
|
|
|
|
|
|
$recommendedMinimum = 4 * 1024 * 1024;
|
|
|
|
|
|
|
|
return view('install.check', [
|
|
|
|
'available_modules' => $availableModules,
|
|
|
|
'can_continue' => $canContinue,
|
2016-10-06 15:07:30 +01:00
|
|
|
'php_is_valid' => $phpIsValid,
|
|
|
|
'php_version_current' => $runtimeVersion,
|
|
|
|
'php_version_required' => $runtimeMinimum,
|
2016-10-01 14:45:48 +01:00
|
|
|
'post_max_size' => ($postMaxSize / 1024 / 1024),
|
|
|
|
'post_max_size_warning' => $postMaxSize < $recommendedMinimum,
|
|
|
|
'recommended_minimum_upload' => ($recommendedMinimum / 1024 / 1024),
|
|
|
|
'upload_limit' => ($uploadLimit / 1024 / 1024),
|
|
|
|
'upload_limit_warning' => $uploadLimit < $recommendedMinimum,
|
|
|
|
'required_modules' => $requiredModules
|
|
|
|
]);
|
2016-09-21 12:10:37 +01:00
|
|
|
}
|
|
|
|
|
2016-10-01 14:45:48 +01:00
|
|
|
public function database(Request $request)
|
2016-09-21 12:10:37 +01:00
|
|
|
{
|
2016-10-01 14:45:48 +01:00
|
|
|
// Validate we're at the required stage
|
|
|
|
$stage = 2;
|
|
|
|
if (intval($request->session()->get('install_stage')) < $stage)
|
|
|
|
{
|
|
|
|
return redirect(route('install.check'));
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($request->method() == 'POST')
|
2016-09-21 12:10:37 +01:00
|
|
|
{
|
|
|
|
$baseDirectory = dirname(dirname(dirname(__DIR__)));
|
|
|
|
|
|
|
|
$data = [
|
2016-10-01 14:45:48 +01:00
|
|
|
sprintf('APP_KEY=%s', config('app.key')),
|
2016-09-21 12:10:37 +01:00
|
|
|
'DB_CONNECTION=mysql',
|
2016-10-01 14:45:48 +01:00
|
|
|
sprintf('DB_HOST=%s', $request->get('mysql-server')),
|
|
|
|
sprintf('DB_PORT=%s', intval($request->get('mysql-port'))),
|
|
|
|
sprintf('DB_DATABASE=%s', $request->get('mysql-database')),
|
|
|
|
sprintf('DB_USERNAME=%s', $request->get('mysql-username')),
|
|
|
|
sprintf('DB_PASSWORD=%s', $request->get('mysql-password'))
|
2016-09-21 12:10:37 +01:00
|
|
|
];
|
|
|
|
file_put_contents(sprintf('%s/.env', $baseDirectory), join(PHP_EOL, $data) . PHP_EOL);
|
|
|
|
|
|
|
|
// Update the in-memory configuration ready for Artisan :)
|
|
|
|
$configData = [
|
|
|
|
'connections' => [
|
|
|
|
'mysql' => [
|
|
|
|
'driver' => 'mysql',
|
|
|
|
'host' => $request->get('mysql-server'),
|
|
|
|
'port' => intval($request->get('mysql-port')),
|
|
|
|
'database' => $request->get('mysql-database'),
|
|
|
|
'username' => $request->get('mysql-username'),
|
|
|
|
'password' => $request->get('mysql-password')
|
|
|
|
]
|
|
|
|
]
|
|
|
|
];
|
|
|
|
config(['database' => array_replace_recursive(config('database'), $configData)]);
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
2016-09-22 07:34:18 +01:00
|
|
|
DB::reconnect();
|
|
|
|
|
2016-09-21 12:10:37 +01:00
|
|
|
Artisan::call('cache:clear');
|
|
|
|
Artisan::call('migrate', ['--force' => true]);
|
2017-09-29 12:53:49 +01:00
|
|
|
Artisan::call('db:seed', ['--force' => true]);
|
2016-09-21 12:10:37 +01:00
|
|
|
|
2016-10-06 16:58:02 +01:00
|
|
|
$versionNumber = UserConfig::getOrCreateModel('app_version');
|
|
|
|
$versionNumber->value = config('app.version');
|
|
|
|
$versionNumber->save();
|
2016-09-21 12:10:37 +01:00
|
|
|
|
2019-07-14 16:28:46 +01:00
|
|
|
// Default settings
|
|
|
|
$this->setConfigurationForNewSystems();
|
|
|
|
|
2017-09-29 12:54:55 +01:00
|
|
|
$request->session()->put('install_stage', 3);
|
2016-10-01 14:45:48 +01:00
|
|
|
return redirect(route('install.administrator'));
|
2016-09-21 12:10:37 +01:00
|
|
|
}
|
|
|
|
catch (\Exception $ex)
|
|
|
|
{
|
|
|
|
$request->session()->flash('database_error', $ex->getMessage());
|
2016-10-01 14:45:48 +01:00
|
|
|
return redirect(route('install.database'))
|
2016-09-21 12:10:37 +01:00
|
|
|
->withInput($request->input());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-01 14:45:48 +01:00
|
|
|
return view('install.database', [
|
2016-09-21 12:10:37 +01:00
|
|
|
'database_error' => $request->session()->get('database_error')
|
|
|
|
]);
|
|
|
|
}
|
2016-10-27 11:36:37 +01:00
|
|
|
|
|
|
|
private function completeSetup()
|
|
|
|
{
|
|
|
|
// Flag as installed
|
|
|
|
MiscHelper::setEnvironmentSetting('APP_INSTALLED', true);
|
|
|
|
|
|
|
|
// Switch to database sessions (more reliable)
|
|
|
|
MiscHelper::setEnvironmentSetting('SESSION_DRIVER', 'database');
|
|
|
|
|
|
|
|
// Add an internal storage if it doesn't already exist
|
|
|
|
$this->createInternalStorageLocationIfNotExist();
|
|
|
|
|
|
|
|
// Skip forward. If you go past Go, collect £200!
|
|
|
|
return redirect(route('home', ['install_completed' => true]));
|
|
|
|
}
|
|
|
|
|
|
|
|
private function createInternalStorageLocationIfNotExist()
|
|
|
|
{
|
|
|
|
$storage = Storage::where('is_internal', true)->first();
|
|
|
|
if (is_null($storage))
|
|
|
|
{
|
|
|
|
$location = sprintf('%s/storage/app/albums', dirname(dirname(dirname(__DIR__))));
|
|
|
|
|
|
|
|
$storage = new Storage();
|
|
|
|
$storage->name = trans('installer.default_storage_name');
|
|
|
|
$storage->is_active = true;
|
|
|
|
$storage->is_default = true;
|
|
|
|
$storage->is_internal = true;
|
|
|
|
$storage->location = $location;
|
|
|
|
$storage->source = 'LocalFilesystemSource';
|
|
|
|
$storage->save();
|
|
|
|
|
|
|
|
// Try and create the physical location
|
|
|
|
if (!file_exists($location))
|
|
|
|
{
|
|
|
|
@mkdir($location);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-07-14 16:28:46 +01:00
|
|
|
|
|
|
|
private function setDefaultAnonymousPermission($section, $permission)
|
|
|
|
{
|
|
|
|
$permission = Permission::where([
|
|
|
|
['section', $section],
|
|
|
|
['description', $permission]
|
|
|
|
])->first();
|
|
|
|
|
|
|
|
if (is_null($permission))
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$adap = new AlbumDefaultAnonymousPermission();
|
|
|
|
$adap->permission_id = $permission->id;
|
|
|
|
$adap->save();
|
|
|
|
}
|
|
|
|
|
|
|
|
private function setConfigurationForNewSystems()
|
|
|
|
{
|
|
|
|
/** @var Configuration $socialFeeds */
|
|
|
|
$socialFeeds = UserConfig::getOrCreateModel('social_user_feeds');
|
|
|
|
$socialFeeds->value = true;
|
|
|
|
$socialFeeds->save();
|
|
|
|
|
|
|
|
/** @var Configuration $socialProfiles */
|
|
|
|
$socialProfiles = UserConfig::getOrCreateModel('social_user_profiles');
|
|
|
|
$socialProfiles->value = true;
|
|
|
|
$socialProfiles->save();
|
|
|
|
|
|
|
|
/** @var Configuration $photoComments */
|
|
|
|
$photoComments = UserConfig::getOrCreateModel('allow_photo_comments');
|
|
|
|
$photoComments->value = true;
|
|
|
|
$photoComments->save();
|
|
|
|
|
|
|
|
$defaultPermissions = ['album.list', 'album.view', 'album.post-comment'];
|
|
|
|
foreach ($defaultPermissions as $defaultPermission)
|
|
|
|
{
|
|
|
|
$permissionParts = explode('.', $defaultPermission);
|
|
|
|
|
|
|
|
$this->setDefaultAnonymousPermission($permissionParts[0], $permissionParts[1]);
|
|
|
|
}
|
|
|
|
}
|
2016-09-21 12:10:37 +01:00
|
|
|
}
|