Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Special config files like reverse-proxy.config.php are not updated in existing installations when upgrading #1533

Closed
JuniorJPDJ opened this issue Jul 11, 2021 · 3 comments · Fixed by #2120

Comments

@JuniorJPDJ
Copy link

Config files included into docker image are not replacing config files inside volume.
This leads to bug fixes not being applied like here: #1411 (comment)

@joshtrichards joshtrichards changed the title Config files are not getting updated when changed Special config files like reverse-proxy.config.php are not updated in existing installations when upgrading to a new image Oct 23, 2023
@joshtrichards joshtrichards changed the title Special config files like reverse-proxy.config.php are not updated in existing installations when upgrading to a new image Special config files like reverse-proxy.config.php are not updated in existing installations when upgrading Oct 23, 2023
@joshtrichards
Copy link
Member

Underlying cause and some proposed solutions posted by @flortsch in #1837. I particularly like this one:

or maybe better, exclude /config/ but specifically include all the special config files used by this image, such as reverse-proxy.config.php, smtp.config.php, and so on.

Either of you feel up to coming up with a preliminary implementation and submitting it as a PR?

@joshtrichards
Copy link
Member

We could also, alternatively, not still not touch things but add a warning message (in the entrypoint when we detect mismatched config files). This would have the following pros versus cons:

Pros:

  • Informs people of the possible cause of mysterious issues
  • Has 100% backward compatibility (i.e. won't blindly overwrite local customizations people may have made to this "straggler" files )

Cons:

  • Requires manual remedy even though probably ~80% of users haven't customized those files

One thought is we:

  1. Add a warning now
  2. Document that those files are considered part of the image / not to be messed with (i.e. same as bits of Nextcloud Server) now
  3. Later on we consider introducing the more intrusive "auto fix" (if ever - but we'd always at least have the option of adding it later on)

Just having the warning would probably trigger a lot of "Oh that's why my Docker instance is never behaving like the docs say / doesn't seem to have current bug fixes / auto config doesn't really work but seems to work for other people" reactions from admins.

It's basically the closest we get to have the integrity check, but for the image itself (well, at least for the auto config parts). 😄

It would be a pretty big win on the user experience and support/issue optimization side of things (I think).

@flortsch
Copy link
Contributor

@joshtrichards I provided a PR in #2120 that implements your suggested check in the Docker entrypoint. It prints a warning for every special config file that is missing in the user config folder or differs from the original Docker image file. Please provide feedback. Hopefully, we can document and explain this behavior in a better way and provide a future auto-fix that always copies those files on every update.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants