The upgrade notes only describe necessary changes that you might need to make to your setup in order to use a new role release. Refer to the :ref:`roundcube__ref_changelog` for more details about what has changed.
Due to changes in the role dependencies and some adjustments in the role's default values, your setup is likely to break if you simply execute the updated role. To avoid this, take care of the following issues:
If you are using a custom playbook, make sure to review the changes in the :ref:`roundcube__ref_example_playbook`.
The following variables were replaced and therefore are not defined anymore in the default variables:
roundcube__nginx_server
roundcube__nginx_upstream_php5
roundcube__php5_packages
roundcube__php5_pool
roundcube__extra_packages
In case your playbook is referencing one of them, make sure they are properly defined in your inventory or update your playbook. If you are using the example playbook but customized one of those variables in your Ansible inventory update the definition accordingly.
The default installation path defined in :envvar:`roundcube__www` changed. If you didn't customize its value the Roundcube installation will be under a new file system path after the installation.
Upgrade procedure
The following procedure is valid if you are using the role dependencies as defined in the example playbook.
Make sure you have the latest version of the DebOps roles.
$ debops-update
Make sure you have the lastest version of the debops-contrib.roundcube_ role. In your DebOps project directory run:
$ ansible-galaxy install --force --no-deps --roles-path=ansible/roles debops-contrib.roundcube
Review the :ref:`roundcube__ref_changelog` and make sure your Ansible inventory is adjusted to the variable changes (if necessary).
Remove the nginx virtual host and PHP definitions created by the debops.nginx_ role from the Roundcube server:
# rm /etc/nginx/{sites-available,sites-enabled}/roundcube.example.com.conf # rm /etc/nginx/conf.d/upstream_php5_roundcube.conf
Run the role (e. g. via example playbook):
$ debops ansible/roles/debops-contrib.roundcube/docs/playbooks/roundcube.yml
In case you are using the default configuration copy the Roundcube SQLite database containing the user settings to the new installation path.
$ cp /srv/www/roundcube/sites/roundcube.example.com/public/db/roundcube.db \ /srv/www/sites/roundcube.example.com/public/db
In case Roundcube was installed into a new directory but you didn't use the default :envvar:`roundcube__www` configuration before the update or you experience SQL schema issues, you need to manually run the upstream post update script on the Roundcube server.
# su roundcube -s /bin/bash \ -c "php /srv/www/sites/roundcube.example.com/public/bin/updatedb.sh \ --package=roundcube --dir=/srv/www/sites/roundcube.example.com/public/SQL"
If you manually installed some additional plugins you might need to reinstall or update them for the new Roundcube version.