installer refactoring
This commit is contained in:
278
app/Utilities/Installer.php
Normal file
278
app/Utilities/Installer.php
Normal file
@ -0,0 +1,278 @@
|
||||
<?php
|
||||
|
||||
namespace App\Utilities;
|
||||
|
||||
use App\Models\Auth\User;
|
||||
use App\Models\Company\Company;
|
||||
use Artisan;
|
||||
use Config;
|
||||
use DB;
|
||||
use File;
|
||||
|
||||
/**
|
||||
* Class Installer
|
||||
*
|
||||
* Contains all of the Business logic to install the app. Either through the CLI or the `/install` web UI.
|
||||
*
|
||||
* @package App\Utilities
|
||||
*/
|
||||
class Installer
|
||||
{
|
||||
|
||||
public static function checkServerRequirements()
|
||||
{
|
||||
$requirements = array();
|
||||
|
||||
if (ini_get('safe_mode')) {
|
||||
$requirements[] = trans('install.requirements.disabled', ['feature' => 'Safe Mode']);
|
||||
}
|
||||
|
||||
if (ini_get('register_globals')) {
|
||||
$requirements[] = trans('install.requirements.disabled', ['feature' => 'Register Globals']);
|
||||
}
|
||||
|
||||
if (ini_get('magic_quotes_gpc')) {
|
||||
$requirements[] = trans('install.requirements.disabled', ['feature' => 'Magic Quotes']);
|
||||
}
|
||||
|
||||
if (!ini_get('file_uploads')) {
|
||||
$requirements[] = trans('install.requirements.enabled', ['feature' => 'File Uploads']);
|
||||
}
|
||||
|
||||
if (!class_exists('PDO')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'MySQL PDO']);
|
||||
}
|
||||
|
||||
if (!extension_loaded('openssl')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'OpenSSL']);
|
||||
}
|
||||
|
||||
if (!extension_loaded('tokenizer')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'Tokenizer']);
|
||||
}
|
||||
|
||||
if (!extension_loaded('mbstring')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'mbstring']);
|
||||
}
|
||||
|
||||
if (!extension_loaded('curl')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'cURL']);
|
||||
}
|
||||
|
||||
if (!extension_loaded('xml')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'XML']);
|
||||
}
|
||||
|
||||
if (!extension_loaded('zip')) {
|
||||
$requirements[] = trans('install.requirements.extension', ['extension' => 'ZIP']);
|
||||
}
|
||||
|
||||
if (!is_writable(base_path('storage/app'))) {
|
||||
$requirements[] = trans('install.requirements.directory', ['directory' => 'storage/app']);
|
||||
}
|
||||
|
||||
if (!is_writable(base_path('storage/app/uploads'))) {
|
||||
$requirements[] = trans('install.requirements.directory', ['directory' => 'storage/app/uploads']);
|
||||
}
|
||||
|
||||
if (!is_writable(base_path('storage/framework'))) {
|
||||
$requirements[] = trans('install.requirements.directory', ['directory' => 'storage/framework']);
|
||||
}
|
||||
|
||||
if (!is_writable(base_path('storage/logs'))) {
|
||||
$requirements[] = trans('install.requirements.directory', ['directory' => 'storage/logs']);
|
||||
}
|
||||
|
||||
return $requirements;
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a default .env file.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function createDefaultEnvFile()
|
||||
{
|
||||
// Rename file
|
||||
if (is_file(base_path('.env.example'))) {
|
||||
File::move(base_path('.env.example'), base_path('.env'));
|
||||
}
|
||||
|
||||
// Update .env file
|
||||
static::updateEnv([
|
||||
'APP_KEY' => 'base64:'.base64_encode(random_bytes(32)),
|
||||
'APP_URL' => url('/'),
|
||||
]);
|
||||
}
|
||||
|
||||
public static function createDbTables($host, $port, $database, $username, $password)
|
||||
{
|
||||
if (!static::isDbValid($host, $port, $database, $username, $password)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
// Set database details
|
||||
static::saveDbVariables($host, $port, $database, $username, $password);
|
||||
|
||||
// Try to increase the maximum execution time
|
||||
set_time_limit(300); // 5 minutes
|
||||
|
||||
// Create tables
|
||||
Artisan::call('migrate', ['--force' => true]);
|
||||
|
||||
// Create Roles
|
||||
Artisan::call('db:seed', ['--class' => 'Database\Seeds\Roles', '--force' => true]);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the database exists and is accessible.
|
||||
*
|
||||
* @param $host
|
||||
* @param $port
|
||||
* @param $database
|
||||
* @param $host
|
||||
* @param $database
|
||||
* @param $username
|
||||
* @param $password
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public static function isDbValid($host, $port, $database, $username, $password)
|
||||
{
|
||||
Config::set('database.connections.install_test', [
|
||||
'host' => $host,
|
||||
'port' => $port,
|
||||
'database' => $database,
|
||||
'username' => $username,
|
||||
'password' => $password,
|
||||
'driver' => env('DB_CONNECTION', 'mysql'),
|
||||
'charset' => env('DB_CHARSET', 'utf8mb4'),
|
||||
]);
|
||||
|
||||
try {
|
||||
DB::connection('install_test')->getPdo();
|
||||
} catch (\Exception $e) {;
|
||||
return false;
|
||||
}
|
||||
|
||||
// Purge test connection
|
||||
DB::purge('install_test');
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public static function saveDbVariables($host, $port, $database, $username, $password)
|
||||
{
|
||||
$prefix = strtolower(str_random(3) . '_');
|
||||
|
||||
// Update .env file
|
||||
static::updateEnv([
|
||||
'DB_HOST' => $host,
|
||||
'DB_PORT' => $port,
|
||||
'DB_DATABASE' => $database,
|
||||
'DB_USERNAME' => $username,
|
||||
'DB_PASSWORD' => $password,
|
||||
'DB_PREFIX' => $prefix,
|
||||
]);
|
||||
|
||||
$con = env('DB_CONNECTION', 'mysql');
|
||||
|
||||
// Change current connection
|
||||
$db = Config::get('database.connections.' . $con);
|
||||
|
||||
$db['host'] = $host;
|
||||
$db['database'] = $database;
|
||||
$db['username'] = $username;
|
||||
$db['password'] = $password;
|
||||
$db['prefix'] = $prefix;
|
||||
|
||||
Config::set('database.connections.' . $con, $db);
|
||||
|
||||
DB::purge($con);
|
||||
DB::reconnect($con);
|
||||
}
|
||||
|
||||
public static function createCompany($name, $email, $locale)
|
||||
{
|
||||
// Create company
|
||||
$company = Company::create([
|
||||
'domain' => '',
|
||||
]);
|
||||
|
||||
// Set settings
|
||||
setting()->set([
|
||||
'general.company_name' => $name,
|
||||
'general.company_email' => $email,
|
||||
'general.default_currency' => 'USD',
|
||||
'general.default_locale' => $locale,
|
||||
]);
|
||||
setting()->setExtraColumns(['company_id' => $company->id]);
|
||||
setting()->save();
|
||||
}
|
||||
|
||||
public static function createUser($email, $password, $locale)
|
||||
{
|
||||
// Create the user
|
||||
$user = User::create([
|
||||
'name' => '',
|
||||
'email' => $email,
|
||||
'password' => $password,
|
||||
'locale' => $locale,
|
||||
]);
|
||||
|
||||
// Attach admin role
|
||||
$user->roles()->attach('1');
|
||||
|
||||
// Attach company
|
||||
$user->companies()->attach('1');
|
||||
}
|
||||
|
||||
public static function finalTouches()
|
||||
{
|
||||
// Update .env file
|
||||
static::updateEnv([
|
||||
'APP_LOCALE' => session('locale'),
|
||||
'APP_INSTALLED' => 'true',
|
||||
'APP_DEBUG' => 'false',
|
||||
]);
|
||||
|
||||
// Rename the robots.txt file
|
||||
try {
|
||||
File::move(base_path('robots.txt.dist'), base_path('robots.txt'));
|
||||
} catch (\Exception $e) {
|
||||
// nothing to do
|
||||
}
|
||||
}
|
||||
|
||||
public static function updateEnv($data)
|
||||
{
|
||||
if (empty($data) || !is_array($data) || !is_file(base_path('.env'))) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$env = file_get_contents(base_path('.env'));
|
||||
|
||||
$env = explode("\n", $env);
|
||||
|
||||
foreach ($data as $data_key => $data_value) {
|
||||
foreach ($env as $env_key => $env_value) {
|
||||
$entry = explode('=', $env_value, 2);
|
||||
|
||||
// Check if new or old key
|
||||
if ($entry[0] == $data_key) {
|
||||
$env[$env_key] = $data_key . '=' . $data_value;
|
||||
} else {
|
||||
$env[$env_key] = $env_value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$env = implode("\n", $env);
|
||||
|
||||
file_put_contents(base_path('.env'), $env);
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user