mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-17 10:11:10 +01:00
e8d217b8bd
Summary: Ref T5532. This adds: - Documents can designate that they should be signed by "Corporations" or "Individuals". - Corporate documents get different fields and a different exemption process. - Basically everything works the same but this is like a zillion lines of form code. Test Plan: See screenshots. Reviewers: btrahan, chad Reviewed By: chad Subscribers: epriestley Maniphest Tasks: T5532 Differential Revision: https://secure.phabricator.com/D9812
78 lines
1.8 KiB
PHP
78 lines
1.8 KiB
PHP
<?php
|
|
|
|
final class LegalpadDocumentSignature
|
|
extends LegalpadDAO
|
|
implements PhabricatorPolicyInterface {
|
|
|
|
const VERIFIED = 0;
|
|
const UNVERIFIED = 1;
|
|
|
|
protected $documentPHID;
|
|
protected $documentVersion;
|
|
protected $signatureType;
|
|
protected $signerPHID;
|
|
protected $signerName;
|
|
protected $signerEmail;
|
|
protected $signatureData = array();
|
|
protected $verified;
|
|
protected $isExemption = 0;
|
|
protected $exemptionPHID;
|
|
protected $secretKey;
|
|
|
|
private $document = self::ATTACHABLE;
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_SERIALIZATION => array(
|
|
'signatureData' => self::SERIALIZATION_JSON,
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function save() {
|
|
if (!$this->getSecretKey()) {
|
|
$this->setSecretKey(Filesystem::readRandomCharacters(20));
|
|
}
|
|
return parent::save();
|
|
}
|
|
|
|
public function isVerified() {
|
|
return ($this->getVerified() != self::UNVERIFIED);
|
|
}
|
|
|
|
public function getDocument() {
|
|
return $this->assertAttached($this->document);
|
|
}
|
|
|
|
public function attachDocument(LegalpadDocument $document) {
|
|
$this->document = $document;
|
|
return $this;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
public function getCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
);
|
|
}
|
|
|
|
public function getPolicy($capability) {
|
|
switch ($capability) {
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
return $this->getDocument()->getPolicy(
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
}
|
|
}
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
return ($viewer->getPHID() == $this->getSignerPHID());
|
|
}
|
|
|
|
public function describeAutomaticCapability($capability) {
|
|
return null;
|
|
}
|
|
|
|
}
|