#!/bin/bash # This should allow Blueprint to run in docker. Please note that changing the $FOLDER variable after running # the Blueprint installation script will not change anything in any files besides blueprint.sh. FOLDER="pterodactyl" if [[ -f ".dockerenv" ]]; then DOCKER="y"; FOLDER="html" fi; # If the fallback version below does not match your downloaded version, please let us know. VER_FALLBACK="alpha-T0R"; # This will be automatically replaced by some marketplaces, if not, $VER_FALLBACK will be used as fallback. PM_VERSION="([(pterodactylmarket_version)])"; if [[ -d "/var/www/$FOLDER/blueprint" ]]; then mv /var/www/$FOLDER/blueprint /var/www/$FOLDER/.blueprint; fi; # BUILT_FROM_SOURCE="y"; # If you downloaded Blueprint from a release instead of building it, this should be "n". # if [[ $BUILT_FROM_SOURCE == "y" ]]; then if [[ ! -f "/var/www/$FOLDER/.blueprint/.storage/versionschemefix.flag" ]]; then sed -E -i "s*&bp.version&*source*g" app/Services/Helpers/BlueprintPlaceholderService.php;touch /var/www/$FOLDER/.blueprint/.storage/versionschemefix.flag;fi;VERSION="source"; if [[ $PM_VERSION == "([(pterodactylmarket""_version)])" ]]; then # This runs when the placeholder has not changed, indicating an issue with PterodactylMarket # or Blueprint being installed from other sources. if [[ ! -f "/var/www/$FOLDER/.blueprint/.storage/versionschemefix.flag" ]]; then sed -E -i "s*&bp.version&*$VER_FALLBACK*g" app/Services/Helpers/BlueprintPlaceholderService.php; sed -E -i "s*@version*$VER_FALLBACK*g" public/extensions/blueprint/index.html; touch /var/www/$FOLDER/.blueprint/.storage/versionschemefix.flag; fi; VERSION=$VER_FALLBACK; elif [[ $PM_VERSION != "([(pterodactylmarket""_version)])" ]]; then # This runs in case it is possible to use the PterodactylMarket placeholder instead of the # fallback version. if [[ ! -f "/var/www/$FOLDER/.blueprint/.storage/versionschemefix.flag" ]]; then sed -E -i "s*&bp.version&*$PM_VERSION*g" app/Services/Helpers/BlueprintPlaceholderService.php; sed -E -i "s*@version*$PM_VERSION*g" public/extensions/blueprint/index.html; touch /var/www/$FOLDER/.blueprint/.storage/versionschemefix.flag; fi; VERSION=$PM_VERSION; fi; # Fix for Blueprint's bash database to work with docker and custom folder installations. sed -i "s!&bp.folder&!$FOLDER!g" /var/www/$FOLDER/.blueprint/lib/db.sh; cd /var/www/$FOLDER; source .blueprint/lib/bash_colors.sh; source .blueprint/lib/parse_yaml.sh; source .blueprint/lib/db.sh; if [[ "$@" == *"-php"* ]]; then exit 1; fi; quit_red() { log_red "${1}"; exit 1; }; touch /usr/local/bin/blueprint > /dev/null; echo -e "#!/bin/bash\nbash /var/www/$FOLDER/blueprint.sh -bash \$@;" > /usr/local/bin/blueprint; chmod u+x /var/www/$FOLDER/blueprint.sh > /dev/null; chmod u+x /usr/local/bin/blueprint > /dev/null; if [[ $1 != "-bash" ]]; then if dbValidate "blueprint.setupFinished"; then log_yellow "[WARNING] This command only works if you have yet to install Blueprint. You can run 'blueprint (cmd) [arg]' instead."; exit 1; else if [[ $1 != "--post-upgrade" ]]; then log " ██\n██ ██\n ████\n"; if [[ $DOCKER == "y" ]]; then log_yellow "[WARNING] Running Blueprint with Docker may result in issues."; fi; fi; sed -i "s!&bp.folder&!$FOLDER!g" /var/www/$FOLDER/app/Services/Helpers/BlueprintPlaceholderService.php; sed -i "s!&bp.folder&!$FOLDER!g" /var/www/$FOLDER/resources/views/layouts/admin.blade.php; log_bright "[INFO] php artisan down"; php artisan down; log_bright "[INFO] /var/www/$FOLDER/public/themes/pterodactyl/css/pterodactyl.css"; sed -i "s!@import 'checkbox.css';!@import 'checkbox.css';\n@import url(/assets/extensions/blueprint/blueprint.style.css);\n/* blueprint reserved line */!g" /var/www/$FOLDER/public/themes/pterodactyl/css/pterodactyl.css; log_bright "[INFO] php artisan view:clear"; php artisan view:clear; log_bright "[INFO] php artisan config:clear"; php artisan config:clear; if [[ $1 != "--post-upgrade" ]]; then log_bright "[INFO] php artisan migrate"; php artisan migrate; fi; log_bright "[INFO] chown -R www-data:www-data /var/www/$FOLDER/*"; chown -R www-data:www-data /var/www/$FOLDER/*; log_bright "[INFO] chown -R www-data:www-data /var/www/$FOLDER/.*"; chown -R www-data:www-data /var/www/$FOLDER/.*; log_bright "[INFO] rm .blueprint/.development/.hello.txt"; rm .blueprint/.development/.hello.txt; log_bright "[INFO] php artisan up"; php artisan up; if [[ $1 != "--post-upgrade" ]]; then log_green "\n\n[SUCCESS] Blueprint should now be installed. If something didn't work as expected, please let us know at discord.gg/CUwHwv6xRe."; fi; dbAdd "blueprint.setupFinished"; exit 1; fi; fi; if [[ ( $2 == "-i" ) || ( $2 == "-install" ) ]]; then log_bright "[INFO] Always make sure you place your extensions in the Pterodactyl directory, else Blueprint won't be able to find them!"; if [[ $(expr $# - 2) != 1 ]]; then quit_red "[FATAL] Expected 1 argument but got $(expr $# - 2).";fi; if [[ $3 == "test␀" ]]; then dev=true; n="dev"; mkdir .blueprint/.storage/tmp/dev; cp -R .blueprint/.development/* .blueprint/.storage/tmp/dev/; else dev=false; n=$3; FILE=$n".blueprint" if [[ ! -f "$FILE" ]]; then quit_red "[FATAL] $FILE could not be found.";fi; ZIP=$n".zip"; cp $FILE .blueprint/.storage/tmp/$ZIP; cd .blueprint/.storage/tmp; unzip $ZIP; rm $ZIP; if [[ ! -f "$n/*" ]]; then cd ..; rm -R tmp; mkdir tmp; cd tmp; mkdir ./$n; cp ../../../$FILE ./$n/$ZIP; cd $n; unzip $ZIP; rm $ZIP; cd ..; fi; fi; cd /var/www/$FOLDER; eval $(parse_yaml .blueprint/.storage/tmp/$n/conf.yml) if [[ $dev ]]; then mv .blueprint/.storage/tmp/$n .blueprint/.storage/tmp/$identifier; n=$identifier; fi; if [[ $flags != *"-placeholders.skip;"* ]]; then DIR=.blueprint/.storage/tmp/$n/*; if [[ $flags == *"-disable_az_placeholders;"* ]]; then SKIPAZPLACEHOLDERS=true; log_bright "[INFO] A-Z placeholders will be skipped due to the '-disable_az_placeholders;' flag."; else SKIPAZPLACEHOLDERS=false; fi; for f in $(find $DIR -type f -exec echo {} \;); do sed -i "s~\^#version#\^~$version~g" $f; sed -i "s~\^#author#\^~$author~g" $f; sed -i "s~\^#identifier#\^~$identifier~g" $f; sed -i "s~\^#path#\^~/var/www/$FOLDER~g" $f; sed -i "s~\^#datapath#\^~/var/www/$FOLDER/.blueprint/.storage/extensiondata/$identifier~g" $f; if [[ $SKIPAZPLACEHOLDERS != true ]]; then sed -i "s~bpversionreplace~$version~g" $f; sed -i "s~bpauthorreplace~$author~g" $f; sed -i "s~bpidentifierreplace~$identifier~g" $f; sed -i "s~bppathreplace~/var/www/$FOLDER~g" $f; sed -i "s~bpdatapathreplace~/var/www/$FOLDER/.blueprint/.storage/extensiondata/$identifier~g" $f; fi; log_bright "[INFO] Done placeholders in '$f'."; done; else log_bright "[INFO] Placeholders will be skipped due to the '-placeholders.skip;' flag."; fi; if [[ $name == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'name' is a required configuration option.";fi; if [[ $identifier == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'identifier' is a required configuration option.";fi; if [[ $description == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'description' is a required configuration option.";fi; if [[ $version == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'version' is a required configuration option.";fi; if [[ $target == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'target' is a required configuration option.";fi; if [[ $icon == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'icon' is a required configuration option.";fi; if [[ $datafolder_directory == "" ]]; then log_bright "[INFO] Datafolder field left blank, skipping..";fi; if [[ $controller_location == "" ]]; then log_bright "[INFO] Controller location field left blank, using default controller instead.."; controller_type="default";fi; if [[ $view_location == "" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] 'view_location' is a required configuration option.";fi; if [[ $target != $VERSION ]]; then log_yellow "[WARNING] This extension is built for version $target, but your version is $VERSION.";fi; if [[ $identifier != $n ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] The extension file name must be the same as your identifier. (example: identifier.blueprint)";fi; if [[ $identifier == "blueprint" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] Extensions can not have the identifier 'blueprint'.";fi; if [[ $identifier =~ [a-z] ]]; then log_bright "[INFO] Identifier a-z checks passed."; else rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] The extension identifier should be lowercase and only contain characters a-z.";fi; if [[ ! -f ".blueprint/.storage/tmp/$n/$icon" ]]; then rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] The 'icon' path points to a file that does not exist.";fi; if [[ $migrations_directory != "" ]]; then if [[ $migrations_enabled == "yes" ]]; then log_bright "[INFO] migrations_enabled yes/no checks passed."; cp -R .blueprint/.storage/tmp/$n/$migrations_directory/* database/migrations/ 2> /dev/null; elif [[ $migrations_enabled == "no" ]]; then log_bright "[INFO] migrations_enabled yes/no checks passed."; else rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] If defined, migrations_enabled should only be 'yes' or 'no'.";fi; fi; if [[ $css_location != "" ]]; then if [[ $css_enabled == "yes" ]]; then log_bright "[INFO] css_enabled yes/no checks passed.";INJECTCSS="y"; elif [[ $css_enabled == "no" ]]; then log_bright "[INFO] css_enabled yes/no checks passed."; else rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] If defined, css_enabled should only be 'yes' or 'no'.";fi; fi; if [[ $adminrequests_directory != "" ]]; then if [[ $adminrequests_enabled == "yes" ]]; then log_bright "[INFO] adminrequests_enabled yes/no checks passed."; mkdir app/Http/Requests/Admin/Extensions/$identifier; cp -R .blueprint/.storage/tmp/$n/$adminrequests_directory/* app/Http/Requests/Admin/Extensions/$identifier/ 2> /dev/null; elif [[ $adminrequests_enabled == "no" ]]; then logbright "[INFO] adminrequests_enabled yes/no checks passed."; else rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] If defined, adminrequests_enabled should only be 'yes' or 'no'.";fi; fi; if [[ $publicfiles_directory != "" ]]; then if [[ $publicfiles_enabled == "yes" ]]; then log_bright "[INFO] publicfiles_enabled yes/no checks passed."; mkdir public/extensions/$identifier; cp -R .blueprint/.storage/tmp/$n/$publicfiles_directory/* public/extensions/$identifier/ 2> /dev/null; elif [[ $publicfiles_enabled == "no" ]]; then log_bright "[INFO] publicfiles_enabled yes/no checks passed."; else rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] If defined, publicfiles_enabled should only be 'yes' or 'no'.";fi; fi; cp -R .blueprint/.storage/defaults/extensions/admin.default .blueprint/.storage/defaults/extensions/admin.default.bak 2> /dev/null; if [[ $controller_type != "" ]]; then if [[ $controller_type == "default" ]]; then log_bright "[INFO] controller_type default/custom checks passed."; cp -R .blueprint/.storage/defaults/extensions/controller.default .blueprint/.storage/defaults/extensions/controller.default.bak 2> /dev/null; elif [[ $controller_type == "custom" ]]; then log_bright "[INFO] controller_type default/custom checks passed."; else rm -R .blueprint/.storage/tmp/$n; quit_red "[FATAL] If defined, controller_type should only be 'default' or 'custom'.";fi; fi; cp -R .blueprint/.storage/defaults/extensions/route.default .blueprint/.storage/defaults/extensions/route.default.bak 2> /dev/null; cp -R .blueprint/.storage/defaults/extensions/button.default .blueprint/.storage/defaults/extensions/button.default.bak 2> /dev/null; mkdir .blueprint/.storage/extensiondata/$identifier; if [[ $datafolder_directory != "" ]]; then cp -R .blueprint/.storage/tmp/$n/$datafolder_directory/* .blueprint/.storage/extensiondata/$identifier/; fi; mkdir public/assets/extensions/$identifier; cp .blueprint/.storage/tmp/$n/$icon public/assets/extensions/$identifier/icon.jpg; ICON="/assets/extensions/$identifier/icon.jpg"; CONTENT=$(cat .blueprint/.storage/tmp/$n/$view_location); if [[ $INJECTCSS == "y" ]]; then sed -i "s!/* blueprint reserved line */!/* blueprint reserved line */\n@import url(/assets/extensions/$identifier/$identifier.style.css);!g" public/themes/pterodactyl/css/pterodactyl.css; cp -R .blueprint/.storage/tmp/$n/$css_location/* public/assets/extensions/$identifier/$identifier.style.css 2> /dev/null; fi; if [[ $name == *"~"* ]]; then log_yellow "[WARNING] 'name' contains '~' and may result in an error.";fi; if [[ $description == *"~"* ]]; then log_yellow "[WARNING] 'description' contains '~' and may result in an error.";fi; if [[ $version == *"~"* ]]; then log_yellow "[WARNING] 'version' contains '~' and may result in an error.";fi; if [[ $CONTENT == *"~"* ]]; then log_yellow "[WARNING] 'CONTENT' contains '~' and may result in an error.";fi; if [[ $ICON == *"~"* ]]; then log_yellow "[WARNING] 'ICON' contains '~' and may result in an error.";fi; if [[ $identifier == *"~"* ]]; then log_yellow "[WARNING] 'identifier' contains '~' and may result in an error.";fi; sed -i "s~␀title␀~$name~g" .blueprint/.storage/defaults/extensions/admin.default.bak; sed -i "s~␀name␀~$name~g" .blueprint/.storage/defaults/extensions/admin.default.bak; sed -i "s~␀breadcrumb␀~$name~g" .blueprint/.storage/defaults/extensions/admin.default.bak; sed -i "s~␀name␀~$name~g" .blueprint/.storage/defaults/extensions/button.default.bak; sed -i "s~␀description␀~$description~g" .blueprint/.storage/defaults/extensions/admin.default.bak; sed -i "s~␀version␀~$version~g" .blueprint/.storage/defaults/extensions/admin.default.bak; sed -i "s~␀version␀~$version~g" .blueprint/.storage/defaults/extensions/button.default.bak; sed -i "s~␀icon␀~$ICON~g" .blueprint/.storage/defaults/extensions/admin.default.bak; echo -e "$CONTENT\n@endsection" >> .blueprint/.storage/defaults/extensions/admin.default.bak; if [[ $controller_type != "custom" ]]; then sed -i "s~␀id␀~$identifier~g" .blueprint/.storage/defaults/extensions/controller.default.bak; fi; sed -i "s~␀id␀~$identifier~g" .blueprint/.storage/defaults/extensions/route.default.bak; sed -i "s~␀id␀~$identifier~g" .blueprint/.storage/defaults/extensions/button.default.bak; ADMINVIEW_RESULT=$(cat .blueprint/.storage/defaults/extensions/admin.default.bak); ADMINROUTE_RESULT=$(cat .blueprint/.storage/defaults/extensions/route.default.bak); ADMINBUTTON_RESULT=$(cat .blueprint/.storage/defaults/extensions/button.default.bak); if [[ $controller_type != "custom" ]]; then ADMINCONTROLLER_RESULT=$(cat .blueprint/.storage/defaults/extensions/controller.default.bak); fi; ADMINCONTROLLER_NAME=$identifier"ExtensionController.php"; mkdir resources/views/admin/extensions/$identifier; touch resources/views/admin/extensions/$identifier/index.blade.php; echo $ADMINVIEW_RESULT > resources/views/admin/extensions/$identifier/index.blade.php; mkdir app/Http/Controllers/Admin/Extensions/$identifier; touch app/Http/Controllers/Admin/Extensions/$identifier/$ADMINCONTROLLER_NAME; if [[ $controller_type != "custom" ]]; then echo $ADMINCONTROLLER_RESULT > app/Http/Controllers/Admin/Extensions/$identifier/$ADMINCONTROLLER_NAME; else cp .blueprint/.storage/tmp/$n/$controller_location app/Http/Controllers/Admin/Extensions/$identifier/$ADMINCONTROLLER_NAME; fi; if [[ $controller_type == "custom" ]]; then cp .blueprint/.storage/tmp/$n/$controller_location app/Http/Controllers/Admin/Extensions/$identifier/${identifier}ExtensionController.php; fi; echo $ADMINROUTE_RESULT >> routes/admin.php; sed -i "s~~$ADMINBUTTON_RESULT\n~g" resources/views/admin/extensions.blade.php; rm .blueprint/.storage/defaults/extensions/admin.default.bak; if [[ $controller_type != "custom" ]]; then rm .blueprint/.storage/defaults/extensions/controller.default.bak; fi; rm .blueprint/.storage/defaults/extensions/route.default.bak; rm .blueprint/.storage/defaults/extensions/button.default.bak; rm -R .blueprint/.storage/tmp/$n; if [[ $migrations_enabled == "yes" ]]; then log_bright "[INFO] This extension comes with migrations. If you get prompted, answer 'yes'.\n"; php artisan migrate; fi; chmod -R +x .blueprint/.storage/extensiondata/$identifier/*; if [[ $flags == *"-run.afterinstall;"* ]]; then log_yellow "[WARNING] This extension uses a custom installation script, proceed with caution." bash .blueprint/.storage/extensiondata/$identifier/install.sh; fi; log_green "\n\n[SUCCESS] $identifier should now be installed. If something didn't work as expected, please let us know at discord.gg/CUwHwv6xRe."; fi; if [[ ( $2 == "help" ) || ( $2 == "-help" ) || ( $2 == "--help" ) ]]; then echo -e " -install -i [name] install a blueprint extension"" " "-version -v get the current blueprint version"" " "-init initialize extension development files."" " "-build run an installation on your extension development files."" " "-export export your extension development files (experimental)"" " "-reinstall rerun the blueprint installation script"" " "-upgrade update/reset to a newer version (experimental)"; fi; if [[ ( $2 == "-v" ) || ( $2 == "-version" ) ]]; then echo -e $VERSION; fi; if [[ $2 == "-init" ]]; then echo "Name (Generic Extension):"; read ASKNAME; echo "Identifier (genericextension):"; read ASKIDENTIFIER; echo "Description (My awesome description):"; read ASKDESCRIPTION; echo "Version (indev):"; read ASKVERSION; echo "Author (prplwtf):"; read ASKAUTHOR; log_bright "[INFO] Running validation checks.."; if [[ $ASKIDENTIFIER =~ [a-z] ]]; then log_bright "[INFO] Identifier a-z checks passed." > /dev/null; else quit_red "[FATAL] Identifier should only contain a-z characters.";fi; log_bright "[INFO] Copying init defaults to tmp directory.."; mkdir .blueprint/.storage/tmp/init; cp -R .blueprint/.storage/defaults/init/* .blueprint/.storage/tmp/init/; log_bright "[INFO] Applying variables.." sed -i "s~␀name␀~$ASKNAME~g" .blueprint/.storage/tmp/init/conf.yml; #NAME sed -i "s~␀identifier␀~$ASKIDENTIFIER~g" .blueprint/.storage/tmp/init/conf.yml; #IDENTIFIER sed -i "s~␀description␀~$ASKDESCRIPTION~g" .blueprint/.storage/tmp/init/conf.yml; #DESCRIPTION sed -i "s~␀ver␀~$ASKVERSION~g" .blueprint/.storage/tmp/init/conf.yml; #VERSION sed -i "s~␀author␀~$ASKAUTHOR~g" .blueprint/.storage/tmp/init/conf.yml; #AUTHOR icnNUM=$(expr 1 + $RANDOM % 3); sed -i "s~␀num␀~$icnNUM~g" .blueprint/.storage/tmp/init/conf.yml; sed -i "s~␀version␀~$VERSION~g" .blueprint/.storage/tmp/init/conf.yml; # Return files to folder. log_bright "[INFO] Copying output to .development directory." cp -R .blueprint/.storage/tmp/init/* .blueprint/.development/; # Remove tmp files. log_bright "[INFO] Purging tmp files." rm -R .blueprint/.storage/tmp; mkdir .blueprint/.storage/tmp; log_green "[SUCCESS] Your extension files have been generated and exported to '.blueprint/.development'."; fi; if [[ ( $2 == "-build" ) || ( $2 == "-test" ) ]]; then if [[ $2 == "-test" ]]; then quit_red "[FATAL] -test has been removed in alpha-T0R and up, please use -build instead."; fi log_bright "[INFO] Installing development extension files.."; blueprint -i test␀; log_bright "[INFO] Extension installation ends here, if there are any errors during installation, fix them and try again."; fi; if [[ $2 == "-export" ]]; then log_yellow "[WARNING] This is an experimental feature, proceed with caution."; log_bright "[INFO] Exporting extension files located in '.blueprint/.development'."; cd .blueprint zip .storage/tmp/blueprint.zip .development/* mv .storage/tmp/blueprint.zip ../extension.blueprint; log_bright "[INFO] Extension files should be exported into your Pterodactyl directory now. Some versions of Blueprint may require your identifier to match the filename (excluding the .blueprint extension). You'll need to do this manually."; fi; if [[ $2 == "-reinstall" ]]; then dbRemove "blueprint.setupFinished"; cd /var/www/$FOLDER; bash blueprint.sh; fi; if [[ $2 == "-upgrade" ]]; then log_yellow "[WARNING] This is an experimental feature, proceed with caution.\n"; log_yellow "[WARNING] Upgrading will update Blueprint to an unstable work-in-progress preview of the next version. Continue? (y/N)"; read YN1; if [[ ( $YN1 != "y" ) && ( $YN1 != "Y" ) ]]; then log_bright "[INFO] Upgrade cancelled.";exit 1;fi; log_yellow "[WARNING] Upgrading will wipe your .blueprint folder and will overwrite your extensions. Continue? (y/N)"; read YN2; if [[ ( $YN2 != "y" ) && ( $YN2 != "Y" ) ]]; then log_bright "[INFO] Upgrade cancelled.";exit 1;fi; log_yellow "[WARNING] This is the last warning before upgrading/wiping Blueprint. Type 'continue' to continue, all other input will be taken as 'no'."; read YN3; if [[ $YN3 != "continue" ]]; then log_bright "[INFO] Upgrade cancelled.";exit 1;fi; log_bright "[INFO] Blueprint is upgrading.. Please do not turn off your machine."; bash tools/update.sh /var/www/$FOLDER; log_bright "[INFO] Files have been upgraded, running installation script.."; chmod +x blueprint.sh; bash blueprint.sh --post-upgrade; log_yellow "[WARNING] Database migrations are skipped when upgrading, run them anyways? (Y/n)"; read YN4; if [[ ( $YN4 == "y" ) || ( $YN4 == "Y" ) ]]; then log_bright "[INFO] Running database migrations.."; php artisan migrate; else log_bright "[INFO] Database migrations have been skipped."; fi; log_bright "[INFO] Running post-upgrade checks.."; score=0; if dbValidate "blueprint.setupFinished"; then score=$((score+1)); else log_yellow "[WARNING] 'blueprint.setupFinished' could not be found."; fi; if [[ $score == 1 ]]; then log_green "[SUCCESS] Blueprint has upgraded successfully."; elif [[ $score == 0 ]]; then log_red "[FATAL] Upgrading has failed." else log_yellow "[WARNING] Some post-upgrade checks have failed." fi; fi;