We recommend backing up your database with mysqldump before updating the app.
To update the app you just need to copy over the latest code. The app tracks the current version in a file called version.txt, if it notices a change it loads
/update to run the database migrations.
If you have trouble updating you can manually load /update to check for errors.
We recommend using this shell script to automate the update process, run it as a daily cron to automatically keep your app up to date.
If you’re moving servers make sure to copy over the .env file and the custom company logo(s) located in the public/logo directory.
You can manually run the update with the following commands. Once completed add
?clear_cache=true to the end of the URL to clear the application cache.
composer dump-autoload --optimize php artisan optimize --force php artisan migrate php artisan db:seed --class=UpdateSeeder
A common error with shared hosting is “open_basedir restriction in effect”, if you see this you’ll need to either temporarily modify your open_basedir settings or run the update from the command line.
If you’ve downloaded the code from GitHub you also need to run
You can see the detailed changes for each release on our GitHub release notes.
You may need to manually delete
The minimum PHP version is now 7.0.0
If you’re using a rijndael cipher run
php artisan ninja:update-key --legacy=true to change to AES-256-CBC.
An import folder has been adding to storage/, you may need to run
sudo chown -R www-data:www-data storage
The minimum PHP version is now 5.5.9
Copy .env.example to .env and set config settings
If unset, set the app cipher to
/path/to/ninja/storage has 755 permissions and is owned by the webserver user