mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-12 06:17:28 -08:00
Merge remote-tracking branch 'origin/develop'
This commit is contained in:
commit
31d0b4a46c
|
@ -57,11 +57,11 @@
|
|||
</div>
|
||||
<div class="col-md-10">
|
||||
@if (config('app.lock_passwords')===true)
|
||||
{{ Form::text('slack_endpoint', Request::old('slack_endpoint', $setting->slack_endpoint), array('class' => 'form-control','disabled'=>'disabled','placeholder' => 'https://hooks.slack.com/services/XXXXXXXXXXXXXXXXXXXXX', 'id' => 'slack_endpoint')) }}
|
||||
{{ Form::text('slack_endpoint', old('slack_endpoint', $setting->slack_endpoint), array('class' => 'form-control','disabled'=>'disabled','placeholder' => 'https://hooks.slack.com/services/XXXXXXXXXXXXXXXXXXXXX', 'id' => 'slack_endpoint')) }}
|
||||
<p class="text-warning"><i class="fa fa-lock"></i> {{ trans('general.feature_disabled') }}</p>
|
||||
|
||||
@else
|
||||
{{ Form::text('slack_endpoint', Request::old('slack_endpoint', $setting->slack_endpoint), array('class' => 'form-control','placeholder' => 'https://hooks.slack.com/services/XXXXXXXXXXXXXXXXXXXXX', 'id' => 'slack_endpoint')) }}
|
||||
{{ Form::text('slack_endpoint', old('slack_endpoint', $setting->slack_endpoint), array('class' => 'form-control','placeholder' => 'https://hooks.slack.com/services/XXXXXXXXXXXXXXXXXXXXX', 'id' => 'slack_endpoint')) }}
|
||||
@endif
|
||||
{!! $errors->first('slack_endpoint', '<span class="alert-msg" aria-hidden="true">:message</span>') !!}
|
||||
</div>
|
||||
|
@ -74,11 +74,11 @@
|
|||
</div>
|
||||
<div class="col-md-10">
|
||||
@if (config('app.lock_passwords')===true)
|
||||
{{ Form::text('slack_channel', Request::old('slack_channel', $setting->slack_channel), array('class' => 'form-control','disabled'=>'disabled','placeholder' => '#IT-Ops')) }}
|
||||
{{ Form::text('slack_channel', old('slack_channel', $setting->slack_channel), array('class' => 'form-control','disabled'=>'disabled','placeholder' => '#IT-Ops')) }}
|
||||
<p class="text-warning"><i class="fa fa-lock"></i> {{ trans('general.feature_disabled') }}</p>
|
||||
|
||||
@else
|
||||
{{ Form::text('slack_channel', Request::old('slack_channel', $setting->slack_channel), array('class' => 'form-control','placeholder' => '#IT-Ops')) }}
|
||||
{{ Form::text('slack_channel', old('slack_channel', $setting->slack_channel), array('class' => 'form-control','placeholder' => '#IT-Ops')) }}
|
||||
@endif
|
||||
{!! $errors->first('slack_channel', '<span class="alert-msg" aria-hidden="true">:message</span>') !!}
|
||||
</div>
|
||||
|
@ -91,11 +91,11 @@
|
|||
</div>
|
||||
<div class="col-md-10">
|
||||
@if (config('app.lock_passwords')===true)
|
||||
{{ Form::text('slack_botname', Request::old('slack_botname', $setting->slack_botname), array('class' => 'form-control','disabled'=>'disabled','placeholder' => 'Snipe-Bot')) }}
|
||||
{{ Form::text('slack_botname', old('slack_botname', $setting->slack_botname), array('class' => 'form-control','disabled'=>'disabled','placeholder' => 'Snipe-Bot')) }}
|
||||
<p class="text-warning"><i class="fa fa-lock"></i> {{ trans('general.feature_disabled') }}</p>
|
||||
|
||||
@else
|
||||
{{ Form::text('slack_botname', Request::old('slack_botname', $setting->slack_botname), array('class' => 'form-control','placeholder' => 'Snipe-Bot')) }}
|
||||
{{ Form::text('slack_botname', old('slack_botname', $setting->slack_botname), array('class' => 'form-control','placeholder' => 'Snipe-Bot')) }}
|
||||
@endif
|
||||
{!! $errors->first('slack_botname', '<span class="alert-msg" aria-hidden="true">:message</span>') !!}
|
||||
</div>
|
||||
|
|
192
upgrade.php
192
upgrade.php
|
@ -19,33 +19,114 @@ if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
|
|||
// otherwise just use master
|
||||
(array_key_exists('1', $argv)) ? $branch = $argv[1] : $branch = 'master';
|
||||
|
||||
echo "Welcome to the Snipe-IT upgrader.\n\n";
|
||||
echo "Please note that this script will not download the latest Snipe-IT \n";
|
||||
echo "files for you unless you have git installed. \n";
|
||||
echo "It simply runs the standard composer and artisan \n";
|
||||
echo "commands needed to finalize the upgrade after. \n\n";
|
||||
|
||||
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! WARNING !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n";
|
||||
echo "!! If you have any encrypted custom fields, BE SURE TO run the recrypter if upgrading from v3 to v4. \n";
|
||||
echo "!! See the Snipe-IT documentation for help: \n";
|
||||
echo "!! https://snipe-it.readme.io/docs/upgrading-to-v4\n";
|
||||
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! WARNING !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n";
|
||||
echo "--------------------------------------------------------\n";
|
||||
echo "WELCOME TO THE SNIPE-IT UPGRADER! \n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
echo "This script will attempt to: \n\n";
|
||||
echo "- check your PHP version and extension requirements \n";
|
||||
echo "- do a git pull to bring you to the latest version \n";
|
||||
echo "- run composer install to get your vendors up to date \n";
|
||||
echo "- run migrations to get your schema up to date \n";
|
||||
echo "- clear out old cache settings\n\n";
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
echo "STEP 1: Checking PHP requirements: \n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
|
||||
echo "Current PHP version: " . PHP_VERSION . "\n\n";
|
||||
|
||||
if (version_compare(PHP_VERSION, $required_version, '<')) {
|
||||
echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! ERROR !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n";
|
||||
echo "This version of PHP is not compatible with Snipe-IT.\n";
|
||||
echo "This version of PHP (".PHP_VERSION.") is not compatible with Snipe-IT.\n";
|
||||
echo "Snipe-IT requires PHP version ".$required_version." or greater. Please upgrade \n";
|
||||
echo "your server's version of PHP (mod and cli) and try running this script again.\n\n\n";
|
||||
echo "your version of PHP (web/php-fcgi and cli) and try running this script again.\n\n\n";
|
||||
exit;
|
||||
|
||||
} else {
|
||||
echo "PHP version: " . PHP_VERSION . " is at least ".$required_version." - continuing... \n\n";
|
||||
echo "Current PHP version: (" . PHP_VERSION . ") is at least ".$required_version." - continuing... \n";
|
||||
echo sprintf("FYI: The php.ini used by this PHP is: %s\n\n", get_cfg_var('cfg_file_path'));
|
||||
}
|
||||
|
||||
|
||||
echo "Checking Required PHP extensions... \n\n";
|
||||
|
||||
// Get the list of installed extensions
|
||||
$loaded_exts_array = get_loaded_extensions();
|
||||
|
||||
// The PHP extensions PHP is *required* to have enabled in order to run
|
||||
$required_exts_array =
|
||||
[
|
||||
'bcmath',
|
||||
'curl',
|
||||
'fileinfo',
|
||||
'gd|imagick',
|
||||
'json',
|
||||
'ldap',
|
||||
'mbstring',
|
||||
'mysqli|pgsql',
|
||||
'openssl',
|
||||
'PDO',
|
||||
'tokenizer',
|
||||
'xml',
|
||||
'zip',
|
||||
];
|
||||
|
||||
$ext_missing = '';
|
||||
$ext_installed = '';
|
||||
|
||||
// Loop through the required extensions
|
||||
foreach ($required_exts_array as $required_ext) {
|
||||
|
||||
// If we don't find the string in the array....
|
||||
if (!in_array($required_ext, $loaded_exts_array)) {
|
||||
|
||||
// Let's check for any options with pipes in them - those mean you can have either or
|
||||
if (strpos($required_ext, '|')) {
|
||||
|
||||
// Split the either/ors by their pipe and put them into an array
|
||||
$require_either = explode("|", $required_ext);
|
||||
|
||||
// Now loop through the either/or array and see whether any of the options match
|
||||
foreach ($require_either as $require_either_value) {
|
||||
|
||||
if (in_array($require_either_value, $loaded_exts_array)) {
|
||||
$ext_installed .= '√ '.$require_either_value." is installed!\n";
|
||||
break;
|
||||
// If no match, add it to the string for errors
|
||||
} else {
|
||||
$ext_missing .= '✘ MISSING PHP EXTENSION: '.str_replace("|", " OR ", $required_ext)."\n";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// If this isn't an either/or option, just add it to the string of errors conventionally
|
||||
} else {
|
||||
$ext_missing .= '✘ MISSING PHP EXTENSION: '.$required_ext."\n";
|
||||
}
|
||||
|
||||
// The required extension string was found in the array of installed extensions - yay!
|
||||
} else {
|
||||
$ext_installed .= '√ '.$required_ext." is installed!\n";
|
||||
}
|
||||
}
|
||||
|
||||
// Print out a useful error message and abort the install
|
||||
if ($ext_missing!='') {
|
||||
echo "--------------------- !! ERROR !! ----------------------\n";
|
||||
echo $ext_missing;
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
echo "You have the following extensions installed: \n\n";
|
||||
|
||||
foreach ($loaded_exts_array as $loaded_ext) {
|
||||
echo "- ".$loaded_ext."\n";
|
||||
}
|
||||
|
||||
echo "------------------------- :( ---------------------------\n";
|
||||
echo "ABORTING THE INSTALLER \n";
|
||||
echo "Please install the extensions above and re-run this script.\n";
|
||||
echo "------------------------- :( ---------------------------\n";
|
||||
exit;
|
||||
} else {
|
||||
echo $ext_installed."\n";
|
||||
|
||||
}
|
||||
|
||||
$ext_check = '';
|
||||
|
@ -83,7 +164,7 @@ echo "--------------------------------------------------------\n";
|
|||
echo "STEP 3: Putting application into maintenance mode: \n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
$down = shell_exec('php artisan down');
|
||||
echo '-- '.$down."\n\n";
|
||||
echo '-- '.$down."\n";
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
|
@ -97,42 +178,42 @@ if ((strpos('git version', $git_version)) === false) {
|
|||
$git_checkout = shell_exec('git checkout '.$branch);
|
||||
$git_stash = shell_exec('git stash');
|
||||
$git_pull = shell_exec('git pull');
|
||||
echo '-- '.$git_fetch;
|
||||
echo $git_fetch;
|
||||
echo '-- '.$git_stash;
|
||||
echo '-- '.$git_checkout;
|
||||
echo '-- '.$git_pull;
|
||||
echo '-- '.$git_pull."\n";
|
||||
} else {
|
||||
echo "Git is NOT installed. You can still use this upgrade script to run common \n";
|
||||
echo "migration commands, but you will have to manually download the updated files. \n\n";
|
||||
}
|
||||
echo "Please note that this script will not download the latest Snipe-IT \n";
|
||||
echo "files for you unless you have git installed. \n";
|
||||
echo "It simply runs the standard composer, artisan, and migration \n";
|
||||
echo "commands needed to finalize the upgrade after. \n\n";
|
||||
|
||||
}
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
echo "Step 5: Cleaning up old cached files:\n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
|
||||
// Build an array of the files we generally want to delete because they
|
||||
// can cause issues with funky caching
|
||||
$unused_files = [
|
||||
"bootstrap/cache/compiled.php",
|
||||
"bootsrap/cache/services.php",
|
||||
"bootstrap/cache/config.php",
|
||||
];
|
||||
|
||||
if (file_exists('bootstrap/cache/compiled.php')) {
|
||||
echo "-- Deleting bootstrap/cache/compiled.php. It is no longer used.\n";
|
||||
@unlink('bootstrap/cache/compiled.php');
|
||||
} else {
|
||||
echo "-- No bootstrap/cache/compiled.php, so nothing to delete.\n";
|
||||
}
|
||||
|
||||
if (file_exists('bootstrap/cache/services.php')) {
|
||||
echo "-- Deleting bootstrap/cache/services.php. It it no longer used.\n";
|
||||
@unlink('bootstrap/cache/services.php');
|
||||
} else {
|
||||
echo "-- No bootstrap/cache/services.php, so nothing to delete.\n";
|
||||
}
|
||||
|
||||
if (file_exists('bootstrap/cache/config.php')) {
|
||||
echo "-- Deleting bootstrap/cache/config.php. It it no longer used.\n";
|
||||
@unlink('bootstrap/cache/config.php');
|
||||
} else {
|
||||
echo "-- No bootstrap/cache/config.php, so nothing to delete.\n";
|
||||
foreach ($unused_files as $unused_file) {
|
||||
if (file_exists($unused_file)) {
|
||||
echo "√ Deleting ".$unused_file.". It is no longer used.\n";
|
||||
@unlink($unused_file);
|
||||
} else {
|
||||
echo "√ No ".$unused_file.", so nothing to delete.\n";
|
||||
}
|
||||
}
|
||||
echo "\n";
|
||||
|
||||
$config_clear = shell_exec('php artisan config:clear');
|
||||
$cache_clear = shell_exec('php artisan cache:clear');
|
||||
|
@ -152,7 +233,7 @@ echo "--------------------------------------------------------\n\n";
|
|||
|
||||
// Composer install
|
||||
if (file_exists('composer.phar')) {
|
||||
echo "-- Local composer.phar detected, so we'll use that.\n\n";
|
||||
echo "√ Local composer.phar detected, so we'll use that.\n\n";
|
||||
echo "-- Updating local composer.phar\n\n";
|
||||
$composer_update = shell_exec('php composer.phar self-update');
|
||||
echo $composer_update."\n\n";
|
||||
|
@ -161,13 +242,13 @@ if (file_exists('composer.phar')) {
|
|||
$composer = shell_exec('php composer.phar install --no-dev --prefer-source');
|
||||
|
||||
} else {
|
||||
echo "-- We couldn't find a local composer.phar - trying globally.\n\n";
|
||||
echo "-- We couldn't find a local composer.phar. No worries, trying globally.\n\n";
|
||||
$composer_dump = shell_exec('composer dump');
|
||||
$composer = shell_exec('composer install --no-dev --prefer-source');
|
||||
}
|
||||
|
||||
echo $composer_dump."\n\n";
|
||||
echo $composer."\n\n";
|
||||
echo $composer_dump."\n";
|
||||
echo $composer;
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
|
@ -175,7 +256,7 @@ echo "Step 7: Migrating database:\n";
|
|||
echo "--------------------------------------------------------\n\n";
|
||||
|
||||
$migrations = shell_exec('php artisan migrate --force');
|
||||
echo '-- '.$migrations."\n\n";
|
||||
echo $migrations."\n";
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
|
@ -188,33 +269,22 @@ if ((!file_exists('storage/oauth-public.key')) || (!file_exists('storage/oauth-p
|
|||
$passport = shell_exec('php artisan passport:install');
|
||||
echo $passport;
|
||||
} else {
|
||||
echo "- OAuth keys detected. Skipping passport install.\n\n";
|
||||
echo "√ OAuth keys detected. Skipping passport install.\n\n";
|
||||
}
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
echo "Step 9: Caching routes and config:\n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
$config_cache = shell_exec('php artisan config:cache');
|
||||
$route_cache = shell_exec('php artisan route:cache');
|
||||
echo '-- '.$config_cache;
|
||||
echo '-- '.$route_cache;
|
||||
echo "\n";
|
||||
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
echo "Step 10: Taking application out of maintenance mode:\n";
|
||||
echo "Step 9: Taking application out of maintenance mode:\n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
|
||||
$up = shell_exec('php artisan up');
|
||||
echo '-- '.$up."\n\n";
|
||||
echo '-- '.$up."\n";
|
||||
|
||||
|
||||
|
||||
echo "--------------------------------------------------------\n";
|
||||
echo "FINISHED! Clear your browser cookies and re-login to use :\n";
|
||||
echo "your upgraded Snipe-IT.\n";
|
||||
echo "---------------------- FINISHED! -----------------------\n";
|
||||
echo "All done! Clear your browser cookies and re-login to use \n";
|
||||
echo "your upgraded Snipe-IT!\n";
|
||||
echo "--------------------------------------------------------\n\n";
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue