Page MenuHomePhabricator

Fix failure to record `pullerPHID` in repository pull logs
ClosedPublic

Authored by epriestley on Jan 23 2018, 12:09 AM.
Tags
None
Referenced Files
F13061260: D18912.diff
Fri, Apr 19, 7:08 PM
Unknown Object (File)
Tue, Apr 16, 3:55 AM
Unknown Object (File)
Mon, Apr 15, 11:46 PM
Unknown Object (File)
Sun, Apr 7, 9:00 AM
Unknown Object (File)
Tue, Apr 2, 1:53 AM
Unknown Object (File)
Jan 19 2024, 3:00 AM
Unknown Object (File)
Jan 4 2024, 6:50 PM
Unknown Object (File)
Dec 30 2023, 4:32 PM
Subscribers
None

Details

Summary

See PHI305. Ref T13046.

The SSH workflows currently extend PhabricatorManagementWorkflow to benefit from sharing all the standard argument parsing code. Sharing the parsing code is good, but it also means they inherit a getViewer() method which returns the ommnipotent viewer.

This is appropriate for everything else which extends ManagementWorkflow (like bin/storage, bin/auth, etc.) but not appropriate for SSH workflows, which have a real user.

This caused a bug with the pull logs where pullerPHID was not recorded properly. We used $this->getViewer()->getPHID() but the correct code was $this->getUser()->getPHID().

To harden this against future mistakes:

  • Don't extend ManagementWorkflow. Extend PhutilArgumentWorkflow instead. We only want the argument parsing code.
  • Rename get/setUser() to get/setSSHUser() to make them explicit.

Then, fix the pull log bug by calling getSSHUser() instead of getViewer().

Test Plan
  • Pulled and pushed to a repository over SSH.
  • Grepped all the SSH stuff for the altered symbols.
  • Saw pulls record a valid pullerPHID in the pull log.
  • Used echo {} | ssh ... conduit conduit.ping to test conduit over SSH.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

src/applications/diffusion/ssh/DiffusionSSHWorkflow.php
268

This is the actual bugfix.

I also grepped for anything else calling getViewer(), since it would probably indicate another bug, but it looks like this was the only one.

This revision is now accepted and ready to land.Jan 23 2018, 8:52 PM
This revision was automatically updated to reflect the committed changes.