mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-25 00:02:41 +01:00
960ac3b2a6
Summary: Ref T2787. This does very little so far, but makes inroads on accounts and billing. This is mostly just modeled on what Stripe looks like. The objects are: - **Account**: Has one or more authorized users, who can make manage the account. An example might be "Phacility", and the three of us would be able to manage it. A user may be associated with more than one account (e.g., a corporate account and a personal account) but the UI tries to simplify the common case of a single account. - **Payment Method**: Something we can get sweet sweet money from; for now, a credit card registered with Stripe. Payment methods are associated with an account. - **Product**: A good (one time charge) or service (recurring charge). This might be "t-shirt" or "enterprise plan" or "hourly support" or whatever else. - **Purchase**: Represents a user purchasing a Product for an Account, using a Payment Method. e.g., you bought a shirt, or started a plan, or purchased support. - **Charge**: Actual charges against payment methods. A Purchase can create more than one charge if it's a plan, or if the first charge fails and we re-bill. This doesn't fully account for stuff like coupons/discounts yet but they should fit into the model without any issues. This only implements `Account`, and that only partially. Test Plan: {F37531} Reviewers: chad, btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2787 Differential Revision: https://secure.phabricator.com/D5435
29 lines
719 B
PHP
29 lines
719 B
PHP
<?php
|
|
|
|
final class PhortuneLandingController extends PhortuneController {
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$user = $request->getUser();
|
|
|
|
$accounts = id(new PhortuneAccountQuery())
|
|
->setViewer($user)
|
|
->withMemberPHIDs(array($user->getPHID()))
|
|
->execute();
|
|
|
|
if (!$accounts) {
|
|
$account = $this->createUserAccount($user);
|
|
$accounts = array($account);
|
|
}
|
|
|
|
if (count($accounts) == 1) {
|
|
$account = head($accounts);
|
|
$next_uri = $this->getApplicationURI($account->getID().'/');
|
|
} else {
|
|
$next_uri = $this->getApplicationURI('account/');
|
|
}
|
|
|
|
return id(new AphrontRedirectResponse())->setURI($next_uri);
|
|
}
|
|
|
|
}
|