CustomerBalanceTransaction.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <?php
  2. // File generated from our OpenAPI spec
  3. namespace Stripe;
  4. /**
  5. * Each customer has a <a href="https://stripe.com/docs/api/customers/object#customer_object-balance">Balance</a> value,
  6. * which denotes a debit or credit that's automatically applied to their next invoice upon finalization.
  7. * You may modify the value directly by using the <a href="https://stripe.com/docs/api/customers/update">update customer API</a>,
  8. * or by creating a Customer Balance Transaction, which increments or decrements the customer's <code>balance</code> by the specified <code>amount</code>.
  9. *
  10. * Related guide: <a href="https://stripe.com/docs/billing/customer/balance">Customer balance</a>
  11. *
  12. * @property string $id Unique identifier for the object.
  13. * @property string $object String representing the object's type. Objects of the same type share the same value.
  14. * @property int $amount The amount of the transaction. A negative value is a credit for the customer's balance, and a positive value is a debit to the customer's <code>balance</code>.
  15. * @property int $created Time at which the object was created. Measured in seconds since the Unix epoch.
  16. * @property null|string|\Stripe\CreditNote $credit_note The ID of the credit note (if any) related to the transaction.
  17. * @property string $currency Three-letter <a href="https://www.iso.org/iso-4217-currency-codes.html">ISO currency code</a>, in lowercase. Must be a <a href="https://stripe.com/docs/currencies">supported currency</a>.
  18. * @property string|\Stripe\Customer $customer The ID of the customer the transaction belongs to.
  19. * @property null|string $description An arbitrary string attached to the object. Often useful for displaying to users.
  20. * @property int $ending_balance The customer's <code>balance</code> after the transaction was applied. A negative value decreases the amount due on the customer's next invoice. A positive value increases the amount due on the customer's next invoice.
  21. * @property null|string|\Stripe\Invoice $invoice The ID of the invoice (if any) related to the transaction.
  22. * @property bool $livemode Has the value <code>true</code> if the object exists in live mode or the value <code>false</code> if the object exists in test mode.
  23. * @property null|\Stripe\StripeObject $metadata Set of <a href="https://stripe.com/docs/api/metadata">key-value pairs</a> that you can attach to an object. This can be useful for storing additional information about the object in a structured format.
  24. * @property string $type Transaction type: <code>adjustment</code>, <code>applied_to_invoice</code>, <code>credit_note</code>, <code>initial</code>, <code>invoice_overpaid</code>, <code>invoice_too_large</code>, <code>invoice_too_small</code>, <code>unspent_receiver_credit</code>, or <code>unapplied_from_invoice</code>. See the <a href="https://stripe.com/docs/billing/customer/balance#types">Customer Balance page</a> to learn more about transaction types.
  25. */
  26. class CustomerBalanceTransaction extends ApiResource
  27. {
  28. const OBJECT_NAME = 'customer_balance_transaction';
  29. const TYPE_ADJUSTMENT = 'adjustment';
  30. const TYPE_APPLIED_TO_INVOICE = 'applied_to_invoice';
  31. const TYPE_CREDIT_NOTE = 'credit_note';
  32. const TYPE_INITIAL = 'initial';
  33. const TYPE_INVOICE_OVERPAID = 'invoice_overpaid';
  34. const TYPE_INVOICE_TOO_LARGE = 'invoice_too_large';
  35. const TYPE_INVOICE_TOO_SMALL = 'invoice_too_small';
  36. const TYPE_UNSPENT_RECEIVER_CREDIT = 'unspent_receiver_credit';
  37. const TYPE_ADJUSTEMENT = 'adjustment';
  38. /**
  39. * @return string the API URL for this balance transaction
  40. */
  41. public function instanceUrl()
  42. {
  43. $id = $this['id'];
  44. $customer = $this['customer'];
  45. if (!$id) {
  46. throw new Exception\UnexpectedValueException(
  47. "Could not determine which URL to request: class instance has invalid ID: {$id}",
  48. null
  49. );
  50. }
  51. $id = Util\Util::utf8($id);
  52. $customer = Util\Util::utf8($customer);
  53. $base = Customer::classUrl();
  54. $customerExtn = \urlencode($customer);
  55. $extn = \urlencode($id);
  56. return "{$base}/{$customerExtn}/balance_transactions/{$extn}";
  57. }
  58. /**
  59. * @param array|string $_id
  60. * @param null|array|string $_opts
  61. *
  62. * @throws \Stripe\Exception\BadMethodCallException
  63. */
  64. public static function retrieve($_id, $_opts = null)
  65. {
  66. $msg = 'Customer Balance Transactions cannot be retrieved without a ' .
  67. 'customer ID. Retrieve a Customer Balance Transaction using ' .
  68. "`Customer::retrieveBalanceTransaction('customer_id', " .
  69. "'balance_transaction_id')`.";
  70. throw new Exception\BadMethodCallException($msg);
  71. }
  72. /**
  73. * @param string $_id
  74. * @param null|array $_params
  75. * @param null|array|string $_options
  76. *
  77. * @throws \Stripe\Exception\BadMethodCallException
  78. */
  79. public static function update($_id, $_params = null, $_options = null)
  80. {
  81. $msg = 'Customer Balance Transactions cannot be updated without a ' .
  82. 'customer ID. Update a Customer Balance Transaction using ' .
  83. "`Customer::updateBalanceTransaction('customer_id', " .
  84. "'balance_transaction_id', \$updateParams)`.";
  85. throw new Exception\BadMethodCallException($msg);
  86. }
  87. }