name = $name; return $this; } public function getName() { return $this->name; } public function setEmailAddress($email_address) { $this->emailAddress = $email_address; return $this; } public function getEmailAddress() { return $this->emailAddress; } public function setPHID($phid) { $this->phid = $phid; return $this; } public function getPHID() { return $this->phid; } public function setUndeliverable($reason) { $this->reasons[] = $reason; $this->status = self::STATUS_UNDELIVERABLE; return $this; } public function setDeliverable($reason) { $this->reasons[] = $reason; $this->status = self::STATUS_DELIVERABLE; return $this; } public function isDeliverable() { return ($this->status === self::STATUS_DELIVERABLE); } public function getDeliverabilityReasons() { return $this->reasons; } public static function getReasonDescription($reason) { $descriptions = array( self::REASON_DISABLED => pht( 'This user is disabled; disabled users do not receive mail.'), self::REASON_BOT => pht( 'This user is a bot; bot accounts do not receive mail.'), self::REASON_NO_ADDRESS => pht( 'Unable to load an email address for this PHID.'), self::REASON_EXTERNAL_TYPE => pht( 'Only external accounts of type "email" are deliverable; this '. 'account has a different type.'), self::REASON_UNMAILABLE => pht( 'This PHID type does not correspond to a mailable object.'), self::REASON_RESPONSE => pht( 'This message is a response to another email message, and this '. 'recipient received the original email message, so we are not '. 'sending them this substantially similar message (for example, '. 'the sender used "Reply All" instead of "Reply" in response to '. 'mail from Phabricator).'), self::REASON_SELF => pht( 'This recipient is the user whose actions caused delivery of '. 'this message, but they have set preferences so they do not '. 'receive mail about their own actions (Settings > Email '. 'Preferences > Self Actions).'), self::REASON_MAIL_DISABLED => pht( 'This recipient has disabled all email notifications '. '(Settings > Email Preferences > Email Notifications).'), self::REASON_MAILTAGS => pht( 'This mail has tags which control which users receive it, and '. 'this recipient has not elected to receive mail with any of '. 'the tags on this message (Settings > Email Preferences).'), self::REASON_UNLOADABLE => pht( 'Unable to load user record for this PHID.'), self::REASON_FORCE => pht( 'Delivery of this mail is forced and ignores deliver preferences. '. 'Mail which uses forced delivery is usually related to account '. 'management or authentication. For example, password reset email '. 'ignores mail preferences.'), self::REASON_FORCE_HERALD => pht( 'This recipient was added by a "Send me an Email" rule in Herald, '. 'which overrides some delivery settings.'), ); return idx($descriptions, $reason, pht('Unknown Reason ("%s")', $reason)); } }