1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-07 05:11:05 +01:00

Fix a bug with creating Phortune merchant accounts without applying an email address transaction and some null field issues

Summary:
When Phortune merchant accounts are created via mechanisms other than the web UI (for example, by Phacility unit tests) this validation check may fail.

Transactions are validated even if no transactions of the given type are being applied, to allow the editor to raise errors like "Name is required!".

If there's no TYPE_INVOICEEMAIL transaction, we'll get called with empty `$xactions` and fail on `strlen($new_email)` because the variable is never defined.

As a secondary issue, if contactInfo, invoiceEmail or invoiceFooter are not provided the record will fail to insert (none of these are nullable).

Test Plan: Ran Phacility unit tests, got a clean result for new instance creation.

Reviewers: chad

Reviewed By: chad

Differential Revision: https://secure.phabricator.com/D16798
This commit is contained in:
epriestley 2016-11-03 13:38:06 -07:00
parent 0f1785c0aa
commit c2565d5e24
2 changed files with 5 additions and 1 deletions

View file

@ -134,6 +134,7 @@ final class PhortuneMerchantEditor
} }
break; break;
case PhortuneMerchantTransaction::TYPE_INVOICEEMAIL: case PhortuneMerchantTransaction::TYPE_INVOICEEMAIL:
$new_email = null;
foreach ($xactions as $xaction) { foreach ($xactions as $xaction) {
switch ($xaction->getTransactionType()) { switch ($xaction->getTransactionType()) {
case PhortuneMerchantTransaction::TYPE_INVOICEEMAIL: case PhortuneMerchantTransaction::TYPE_INVOICEEMAIL:

View file

@ -19,7 +19,10 @@ final class PhortuneMerchant extends PhortuneDAO
public static function initializeNewMerchant(PhabricatorUser $actor) { public static function initializeNewMerchant(PhabricatorUser $actor) {
return id(new PhortuneMerchant()) return id(new PhortuneMerchant())
->setViewPolicy(PhabricatorPolicies::getMostOpenPolicy()) ->setViewPolicy(PhabricatorPolicies::getMostOpenPolicy())
->attachMemberPHIDs(array()); ->attachMemberPHIDs(array())
->setContactInfo('')
->setInvoiceEmail('')
->setInvoiceFooter('');
} }
protected function getConfiguration() { protected function getConfiguration() {