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
F13320559: D20159.diff
Fri, Jun 14, 5:28 AM
F13309436: D20159.diff
Mon, Jun 10, 10:12 AM
F13290883: D20159.diff
Tue, Jun 4, 8:26 PM
F13277374: D20159.diff
Fri, May 31, 10:26 AM
F13266523: D20159.diff
Tue, May 28, 2:53 PM
F13246436: D20159.id48146.diff
Thu, May 23, 10:19 AM
F13232119: D20159.diff
Tue, May 21, 1:02 AM
F13213323: D20159.diff
May 17 2024, 7:38 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

🕶