mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-31 18:01:00 +01:00
Give Phortune carts a proper isInvoice
flag
Summary: See some earlier discussion in D11593: > One thing I'm vaguely thinking about is the possibilty that users may be able to invoice one another directly, eventually. For example, we might invoice a contracting client. > We might need an `isInvoice` flag eventually, but `subscriptionPHID` is a reasonable stand-in for now. This adds such a flag. Test Plan: - Generated an ad-hoc invoice and verified it showed up in the right place. - Used `bin/phortune invoice` to invoice a subscription and verified it worked correctly. - Paid an invoice and saw it leave "pending invoices" status. {F377029} Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Differential Revision: https://secure.phabricator.com/D12480
This commit is contained in:
parent
0195e751c6
commit
01c99335fd
8 changed files with 43 additions and 30 deletions
|
@ -7,8 +7,8 @@
|
||||||
*/
|
*/
|
||||||
return array(
|
return array(
|
||||||
'names' => array(
|
'names' => array(
|
||||||
'core.pkg.css' => 'bf29d341',
|
'core.pkg.css' => '7d05ad2a',
|
||||||
'core.pkg.js' => 'a626d14c',
|
'core.pkg.js' => 'dfea788f',
|
||||||
'darkconsole.pkg.js' => '8ab24e01',
|
'darkconsole.pkg.js' => '8ab24e01',
|
||||||
'differential.pkg.css' => '3500921f',
|
'differential.pkg.css' => '3500921f',
|
||||||
'differential.pkg.js' => 'c0506961',
|
'differential.pkg.js' => 'c0506961',
|
||||||
|
@ -27,7 +27,7 @@ return array(
|
||||||
'rsrc/css/aphront/panel-view.css' => '8427b78d',
|
'rsrc/css/aphront/panel-view.css' => '8427b78d',
|
||||||
'rsrc/css/aphront/phabricator-nav-view.css' => '7aeaf435',
|
'rsrc/css/aphront/phabricator-nav-view.css' => '7aeaf435',
|
||||||
'rsrc/css/aphront/table-view.css' => '59e2c0f8',
|
'rsrc/css/aphront/table-view.css' => '59e2c0f8',
|
||||||
'rsrc/css/aphront/tokenizer.css' => 'c10c061e',
|
'rsrc/css/aphront/tokenizer.css' => '86a13f7f',
|
||||||
'rsrc/css/aphront/tooltip.css' => '7672b60f',
|
'rsrc/css/aphront/tooltip.css' => '7672b60f',
|
||||||
'rsrc/css/aphront/two-column.css' => '16ab3ad2',
|
'rsrc/css/aphront/two-column.css' => '16ab3ad2',
|
||||||
'rsrc/css/aphront/typeahead-browse.css' => 'efe293a0',
|
'rsrc/css/aphront/typeahead-browse.css' => 'efe293a0',
|
||||||
|
@ -147,7 +147,7 @@ return array(
|
||||||
'rsrc/css/phui/phui-remarkup-preview.css' => '19ad512b',
|
'rsrc/css/phui/phui-remarkup-preview.css' => '19ad512b',
|
||||||
'rsrc/css/phui/phui-spacing.css' => '042804d6',
|
'rsrc/css/phui/phui-spacing.css' => '042804d6',
|
||||||
'rsrc/css/phui/phui-status.css' => '888cedb8',
|
'rsrc/css/phui/phui-status.css' => '888cedb8',
|
||||||
'rsrc/css/phui/phui-tag-view.css' => 'ea469f3a',
|
'rsrc/css/phui/phui-tag-view.css' => '402691cc',
|
||||||
'rsrc/css/phui/phui-text.css' => 'cf019f54',
|
'rsrc/css/phui/phui-text.css' => 'cf019f54',
|
||||||
'rsrc/css/phui/phui-timeline-view.css' => 'b0fbc4d7',
|
'rsrc/css/phui/phui-timeline-view.css' => 'b0fbc4d7',
|
||||||
'rsrc/css/phui/phui-workboard-view.css' => '3279cbbf',
|
'rsrc/css/phui/phui-workboard-view.css' => '3279cbbf',
|
||||||
|
@ -450,7 +450,7 @@ return array(
|
||||||
'rsrc/js/core/KeyboardShortcutManager.js' => 'c1700f6f',
|
'rsrc/js/core/KeyboardShortcutManager.js' => 'c1700f6f',
|
||||||
'rsrc/js/core/MultirowRowManager.js' => 'b5d57730',
|
'rsrc/js/core/MultirowRowManager.js' => 'b5d57730',
|
||||||
'rsrc/js/core/Notification.js' => '0c6946e7',
|
'rsrc/js/core/Notification.js' => '0c6946e7',
|
||||||
'rsrc/js/core/Prefab.js' => 'b972bdcd',
|
'rsrc/js/core/Prefab.js' => '6920d200',
|
||||||
'rsrc/js/core/ShapedRequest.js' => '7cbe244b',
|
'rsrc/js/core/ShapedRequest.js' => '7cbe244b',
|
||||||
'rsrc/js/core/TextAreaUtils.js' => '5c93c52c',
|
'rsrc/js/core/TextAreaUtils.js' => '5c93c52c',
|
||||||
'rsrc/js/core/Title.js' => 'df5e11d2',
|
'rsrc/js/core/Title.js' => 'df5e11d2',
|
||||||
|
@ -510,7 +510,7 @@ return array(
|
||||||
'aphront-pager-view-css' => '2e3539af',
|
'aphront-pager-view-css' => '2e3539af',
|
||||||
'aphront-panel-view-css' => '8427b78d',
|
'aphront-panel-view-css' => '8427b78d',
|
||||||
'aphront-table-view-css' => '59e2c0f8',
|
'aphront-table-view-css' => '59e2c0f8',
|
||||||
'aphront-tokenizer-control-css' => 'c10c061e',
|
'aphront-tokenizer-control-css' => '86a13f7f',
|
||||||
'aphront-tooltip-css' => '7672b60f',
|
'aphront-tooltip-css' => '7672b60f',
|
||||||
'aphront-two-column-view-css' => '16ab3ad2',
|
'aphront-two-column-view-css' => '16ab3ad2',
|
||||||
'aphront-typeahead-control-css' => '0e403212',
|
'aphront-typeahead-control-css' => '0e403212',
|
||||||
|
@ -744,7 +744,7 @@ return array(
|
||||||
'phabricator-notification-menu-css' => '3c9d8aa1',
|
'phabricator-notification-menu-css' => '3c9d8aa1',
|
||||||
'phabricator-object-selector-css' => '029a133d',
|
'phabricator-object-selector-css' => '029a133d',
|
||||||
'phabricator-phtize' => 'd254d646',
|
'phabricator-phtize' => 'd254d646',
|
||||||
'phabricator-prefab' => 'b972bdcd',
|
'phabricator-prefab' => '6920d200',
|
||||||
'phabricator-profile-css' => '1a20dcbf',
|
'phabricator-profile-css' => '1a20dcbf',
|
||||||
'phabricator-remarkup-css' => 'e10512ff',
|
'phabricator-remarkup-css' => 'e10512ff',
|
||||||
'phabricator-search-results-css' => '15c71110',
|
'phabricator-search-results-css' => '15c71110',
|
||||||
|
@ -806,7 +806,7 @@ return array(
|
||||||
'phui-remarkup-preview-css' => '19ad512b',
|
'phui-remarkup-preview-css' => '19ad512b',
|
||||||
'phui-spacing-css' => '042804d6',
|
'phui-spacing-css' => '042804d6',
|
||||||
'phui-status-list-view-css' => '888cedb8',
|
'phui-status-list-view-css' => '888cedb8',
|
||||||
'phui-tag-view-css' => 'ea469f3a',
|
'phui-tag-view-css' => '402691cc',
|
||||||
'phui-text-css' => 'cf019f54',
|
'phui-text-css' => 'cf019f54',
|
||||||
'phui-timeline-view-css' => 'b0fbc4d7',
|
'phui-timeline-view-css' => 'b0fbc4d7',
|
||||||
'phui-workboard-view-css' => '3279cbbf',
|
'phui-workboard-view-css' => '3279cbbf',
|
||||||
|
@ -1296,6 +1296,18 @@ return array(
|
||||||
'6882e80a' => array(
|
'6882e80a' => array(
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
),
|
),
|
||||||
|
'6920d200' => array(
|
||||||
|
'javelin-install',
|
||||||
|
'javelin-util',
|
||||||
|
'javelin-dom',
|
||||||
|
'javelin-typeahead',
|
||||||
|
'javelin-tokenizer',
|
||||||
|
'javelin-typeahead-preloaded-source',
|
||||||
|
'javelin-typeahead-ondemand-source',
|
||||||
|
'javelin-dom',
|
||||||
|
'javelin-stratcom',
|
||||||
|
'javelin-util',
|
||||||
|
),
|
||||||
'69adf288' => array(
|
'69adf288' => array(
|
||||||
'javelin-install',
|
'javelin-install',
|
||||||
),
|
),
|
||||||
|
@ -1469,6 +1481,10 @@ return array(
|
||||||
'phabricator-tooltip',
|
'phabricator-tooltip',
|
||||||
'changeset-view-manager',
|
'changeset-view-manager',
|
||||||
),
|
),
|
||||||
|
'86a13f7f' => array(
|
||||||
|
'aphront-typeahead-control-css',
|
||||||
|
'phui-tag-view-css',
|
||||||
|
),
|
||||||
'87cb6b51' => array(
|
'87cb6b51' => array(
|
||||||
'javelin-behavior',
|
'javelin-behavior',
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
|
@ -1707,18 +1723,6 @@ return array(
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
'javelin-util',
|
'javelin-util',
|
||||||
),
|
),
|
||||||
'b972bdcd' => array(
|
|
||||||
'javelin-install',
|
|
||||||
'javelin-util',
|
|
||||||
'javelin-dom',
|
|
||||||
'javelin-typeahead',
|
|
||||||
'javelin-tokenizer',
|
|
||||||
'javelin-typeahead-preloaded-source',
|
|
||||||
'javelin-typeahead-ondemand-source',
|
|
||||||
'javelin-dom',
|
|
||||||
'javelin-stratcom',
|
|
||||||
'javelin-util',
|
|
||||||
),
|
|
||||||
'bba9eedf' => array(
|
'bba9eedf' => array(
|
||||||
'javelin-behavior',
|
'javelin-behavior',
|
||||||
'javelin-stratcom',
|
'javelin-stratcom',
|
||||||
|
@ -1764,9 +1768,6 @@ return array(
|
||||||
'javelin-util',
|
'javelin-util',
|
||||||
'phabricator-shaped-request',
|
'phabricator-shaped-request',
|
||||||
),
|
),
|
||||||
'c10c061e' => array(
|
|
||||||
'aphront-typeahead-control-css',
|
|
||||||
),
|
|
||||||
'c1700f6f' => array(
|
'c1700f6f' => array(
|
||||||
'javelin-install',
|
'javelin-install',
|
||||||
'javelin-util',
|
'javelin-util',
|
||||||
|
|
2
resources/sql/autopatches/20150420.invoice.1.sql
Normal file
2
resources/sql/autopatches/20150420.invoice.1.sql
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
ALTER TABLE {$NAMESPACE}_phortune.phortune_cart
|
||||||
|
ADD isInvoice BOOL NOT NULL;
|
2
resources/sql/autopatches/20150420.invoice.2.sql
Normal file
2
resources/sql/autopatches/20150420.invoice.2.sql
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
UPDATE {$NAMESPACE}_phortune.phortune_cart
|
||||||
|
SET isInvoice = 1 WHERE subscriptionPHID IS NOT NULL;
|
|
@ -41,7 +41,7 @@ final class PhortuneCartViewController
|
||||||
$resume_uri = null;
|
$resume_uri = null;
|
||||||
switch ($cart->getStatus()) {
|
switch ($cart->getStatus()) {
|
||||||
case PhortuneCart::STATUS_READY:
|
case PhortuneCart::STATUS_READY:
|
||||||
if ($authority && $request->getStr('invoice')) {
|
if ($authority && $cart->getIsInvoice()) {
|
||||||
// We arrived here by following the ad-hoc invoice workflow, and
|
// We arrived here by following the ad-hoc invoice workflow, and
|
||||||
// are acting with merchant authority.
|
// are acting with merchant authority.
|
||||||
|
|
||||||
|
|
|
@ -167,13 +167,14 @@ final class PhortuneMerchantInvoiceCreateController
|
||||||
->setMetadataValue('adhoc.name', $v_name)
|
->setMetadataValue('adhoc.name', $v_name)
|
||||||
->save();
|
->save();
|
||||||
|
|
||||||
// TODO: Actually mark these as invoices. Right now, there's no easy
|
$cart
|
||||||
// way to do that.
|
->setIsInvoice(1)
|
||||||
|
->save();
|
||||||
|
|
||||||
$cart->activateCart();
|
$cart->activateCart();
|
||||||
$cart_id = $cart->getID();
|
$cart_id = $cart->getID();
|
||||||
|
|
||||||
$uri = "/merchant/{$merchant_id}/cart/{$cart_id}/?invoice=true";
|
$uri = "/merchant/{$merchant_id}/cart/{$cart_id}/";
|
||||||
$uri = $this->getApplicationURI($uri);
|
$uri = $this->getApplicationURI($uri);
|
||||||
|
|
||||||
return id(new AphrontRedirectResponse())->setURI($uri);
|
return id(new AphrontRedirectResponse())->setURI($uri);
|
||||||
|
|
|
@ -203,12 +203,12 @@ final class PhortuneCartQuery
|
||||||
if ($this->invoices) {
|
if ($this->invoices) {
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
$conn,
|
$conn,
|
||||||
'cart.status = %s AND cart.subscriptionPHID IS NOT NULL',
|
'cart.status = %s AND cart.isInvoice = 1',
|
||||||
PhortuneCart::STATUS_READY);
|
PhortuneCart::STATUS_READY);
|
||||||
} else {
|
} else {
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
$conn,
|
$conn,
|
||||||
'cart.status != %s OR cart.subscriptionPHID IS NULL',
|
'cart.status != %s OR cart.isInvoice = 0',
|
||||||
PhortuneCart::STATUS_READY);
|
PhortuneCart::STATUS_READY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@ final class PhortuneCart extends PhortuneDAO
|
||||||
protected $status;
|
protected $status;
|
||||||
protected $metadata = array();
|
protected $metadata = array();
|
||||||
protected $mailKey;
|
protected $mailKey;
|
||||||
|
protected $isInvoice;
|
||||||
|
|
||||||
private $account = self::ATTACHABLE;
|
private $account = self::ATTACHABLE;
|
||||||
private $purchases = self::ATTACHABLE;
|
private $purchases = self::ATTACHABLE;
|
||||||
|
@ -35,6 +36,7 @@ final class PhortuneCart extends PhortuneDAO
|
||||||
->setAuthorPHID($actor->getPHID())
|
->setAuthorPHID($actor->getPHID())
|
||||||
->setStatus(self::STATUS_BUILDING)
|
->setStatus(self::STATUS_BUILDING)
|
||||||
->setAccountPHID($account->getPHID())
|
->setAccountPHID($account->getPHID())
|
||||||
|
->setIsInvoice(0)
|
||||||
->attachAccount($account)
|
->attachAccount($account)
|
||||||
->setMerchantPHID($merchant->getPHID())
|
->setMerchantPHID($merchant->getPHID())
|
||||||
->attachMerchant($merchant);
|
->attachMerchant($merchant);
|
||||||
|
@ -531,6 +533,7 @@ final class PhortuneCart extends PhortuneDAO
|
||||||
'cartClass' => 'text128',
|
'cartClass' => 'text128',
|
||||||
'mailKey' => 'bytes20',
|
'mailKey' => 'bytes20',
|
||||||
'subscriptionPHID' => 'phid?',
|
'subscriptionPHID' => 'phid?',
|
||||||
|
'isInvoice' => 'bool',
|
||||||
),
|
),
|
||||||
self::CONFIG_KEY_SCHEMA => array(
|
self::CONFIG_KEY_SCHEMA => array(
|
||||||
'key_account' => array(
|
'key_account' => array(
|
||||||
|
|
|
@ -59,7 +59,11 @@ final class PhortuneSubscriptionWorker extends PhabricatorWorker {
|
||||||
->setMetadataValue('epoch.end', $next_epoch)
|
->setMetadataValue('epoch.end', $next_epoch)
|
||||||
->save();
|
->save();
|
||||||
|
|
||||||
$cart->setSubscriptionPHID($subscription->getPHID());
|
$cart
|
||||||
|
->setSubscriptionPHID($subscription->getPHID())
|
||||||
|
->setIsInvoice(1)
|
||||||
|
->save();
|
||||||
|
|
||||||
$cart->activateCart();
|
$cart->activateCart();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
Loading…
Reference in a new issue