Page MenuHomePhabricator

Raise a setup warning when locked configuration has a configuration value stored in the database
ClosedPublic

Authored by epriestley on Feb 13 2019, 2:45 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, May 7, 6:09 AM
Unknown Object (File)
Fri, May 3, 3:47 AM
Unknown Object (File)
Mon, Apr 29, 3:51 PM
Unknown Object (File)
Wed, Apr 24, 11:47 PM
Unknown Object (File)
Apr 11 2024, 8:01 AM
Unknown Object (File)
Apr 5 2024, 11:25 AM
Unknown Object (File)
Apr 3 2024, 12:01 PM
Unknown Object (File)
Mar 25 2024, 8:39 AM
Subscribers
None

Details

Summary

Ref T13249. See https://discourse.phabricator-community.org/t/configuring-the-number-of-taskmaster-daemons/2394/.

Today, when a configuration value is "locked", we prevent writes to the database. However, we still perform reads. When you upgrade, we generally don't want a bunch of your configuration to change by surprise.

Some day, I'd like to stop reading locked configuration from the database. This would defuse an escalation where an attacker finds a way to write to locked configuration despite safeguards, e.g. through SQL injection or policy bypass. Today, they could write to cluster.mailers or similar and substantially escalate access. A better behavior would be to ignore database values for cluster.mailers and other locked config, so that these impermissible writes have no effect.

Doing this today would break a lot of installs, but we can warn them about it now and then make the change at a later date.

Test Plan
  • Forced a phd.taskmasters config value into the database.
  • Saw setup warning.
  • Used bin/config delete --database phd.taskmasters to clear the warning.
  • Reviewed documentation changes.
  • Reviewed phd.taskmasters documentation adjustment.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

amckinley added inline comments.
src/applications/config/check/PhabricatorExtraConfigSetupCheck.php
158

"configuration option"

This revision is now accepted and ready to land.Feb 13 2019, 6:45 PM
This revision was automatically updated to reflect the committed changes.
src/applications/config/check/PhabricatorExtraConfigSetupCheck.php
158

🕶