Page MenuHomePhabricator

Legalpad - add policy rule for legalpad document signatures
ClosedPublic

Authored by btrahan on Jan 15 2014, 10:33 PM.
Tags
None
Referenced Files
F18701082: D7977.diff
Sat, Sep 27, 5:14 PM
F18659545: D7977.diff
Sep 23 2025, 1:16 PM
F18624727: D7977.diff
Sep 15 2025, 8:55 PM
F18110688: D7977.id18053.diff
Aug 11 2025, 10:30 PM
F18080984: D7977.id18054.diff
Aug 4 2025, 10:20 PM
F18052257: D7977.id18052.diff
Aug 4 2025, 1:58 AM
F18034772: D7977.id18049.diff
Aug 3 2025, 1:17 AM
F18030199: D7977.id18054.diff
Aug 2 2025, 11:33 PM

Details

Reviewers
epriestley
Maniphest Tasks
Restricted Maniphest Task
Commits
Restricted Diffusion Commit
rPd740374cca7a: Legalpad - add policy rule for legalpad document signatures
Summary

Ref T3116. This creates a policy rule where you can require a signature on a given legalpad document.

NOTE: signatures must be for the *latest* document version.
Test Plan

made a task have a custom policy requiring a legalpad signature. verified non-signers were locked out.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

src/applications/policy/rule/PhabricatorPolicyRuleLegalpadSignature.php
25

there's a few keys on this table, but the one with document phid is currently

document phid, document version, signer phid

I guess I could (and probably should) re-jigger this so document version is the 3rd value. I think queries on document phid and signer phid (with no version) will be helpful so we can say things lke "you signed a previous version of this document and must sign again" while still getting the really fast 3 column query.

Neat!

src/applications/policy/rule/PhabricatorPolicyRuleLegalpadSignature.php
21–22

Maybe we should bundle a needViewerSignatures() into this, seems like we must be doing similar queries elsewhere (or could benefit from doing them)?

25

If this was part of the DocumentQuery it could at least add a ... AND documentPHID IN (%Ls) clause to get most of the benefit of the key.

Oh, one thought: this rule/logic should probably be AND, not OR. That is, it seems reasonable to want to say "You have to sign the Invention Assignment Agreement and the Contracting Agreement".

btrahan updated this revision to Unknown Object (????).Jan 16 2014, 12:19 AM
  • re-jigger the key
  • add "withSignerPHIDs" to query class. this filters out documents that don't have the full set of signer phids from the result set
  • use "withSignerPHIDs" in the policy rule object
  • update a query on the "sign" controller to specify key columns in proper order

oh yeah, also made it "AND" and not "OR"

src/applications/legalpad/query/LegalpadDocumentQuery.php
90

gotta add something to check for versions matching, whoops

btrahan updated this revision to Unknown Object (????).Jan 16 2014, 12:44 AM

fix the document version thing and this generally not actually working (I got "lucky" on my re-factor at first and my quick tests were passing and they should not have been)

re-tested extensively by toggling the custom policy between various legalpad documents (1 and N) and verifying proper access or lack of access