- Add Visa Checkout support
- Add ConnectedMerchantStatusTransitioned and ConnectedMerchantPayPalStatusChanged Auth webhooks
- Add new properties to
CreditCardVerification
andCustomer
- Add SDK support for skip AVS and skip CVV
- Add option to disable Accept-Encoding: gzip header for Google App Engine
- Fix a bug where
merchantAccount->all
would attempt to fetch too many pages of merchant accounts
- Add back in
options->three_d_secure
to transaction params that was accidentally removed in v3.14.0
- Allow optional configuration of SSL version
- Replace
var_dump
withprint_r
. Thanks, @mnlg - Add functionality to list all merchant accounts for a merchant with
merchantAccount->all
- Stop sending account_description field from us bank accounts
- Add option
skip_advanced_fraud_check
for transaction flows
- Add multi-currency updates to merchants onboarded through Braintree Auth
- Raise an exception if fetching pages of results times out during a transaction search
- Fix
UsBankAccount
support forCustomer
s - Update
Grant
api to support options hash
- Add 'UsBankAccount' payment method
- Add authenticated proxy functionality
- Add constant for Venmo Account payment instrument type
- Add validation error for verifications with submerchants
- Add 'default_payment_method' option for Customer
Note: This version introduced an unintentional breaking change where the options->three_d_secure
transaction parameter was changed to options->threeDSecure
. Starting in v3.21.1, both case conventions are supported for backwards compatibility.
- Add OrderId to refund
- Add 3DS Pass thru support
- Expose IDs in resource collections
- Add leading slash to the namespace. Thanks, @bocharsky-bw
- Stop modifying DateTime parameters during XML generation. Thanks, @jodarove
- Add method of revoking OAuth access tokens.
- Add Transaction
update_details
- Support for Too Many Requests response codes
- Add ability to count errors in ErrorCollection object. Thanks, @bocharsky-bw
- Improve Type Hinting
- Remove final from classes. Thanks, @ibrahimlawal!
- Add currency to Transaction search
- Add timeout attribute
- Add start-date and end-date to SUBSCRIPTION_CHARGED_SUCCESSFULLY test webhook response
- Add AccountUpdaterDailyReport webhook parsing
- Add payment method revoke
- Add support for options in
submit_for_settlement
transaction flows - Add verification create API
- Update https certificate bundle
- Add VenmoAccount
- Allow order_id and descriptor to be passed in for Transaction submit_for_settlement
- Add facilitator details onto transactions
- Add check webhook constant
- Fix PSR-0 style namespacing when using Symfony
- Add support for proxy servers
- Add PSR-4 namespacing support
- Add support for AMEX Express Checkout
- Add support for new fields in dispute webhooks (
dateWon
,dateOpened
,kind
) - Add transaction data to sucessful subscription webhook
- Add support for raw ApplePay params on Transaction create
- Add sourceDescription method to Android Pay and Apple Pay payment methods
- Add new Android Pay test nonces
- Add billing agreement ID to PayPal Account
- Support amex rewards transactions
- Add new test payment method nonces
- Allow passing description on PayPal transactions
- Add methods to change transaction settlement status in sandbox
- Fix issue where customer with an id of 0 could not be found
- Add Europe Bank Account functionality
- Add additional search criteria
- Add support for HHVM
- Validate that configuration is valid before verifying webhooks
- Make OAuth methods conform more to existing API
- Expose customer paymentMethods as an attribute
- Add support for Android Pay
- Deprecate PHP 5.2 and 5.3
- Validate webhook challenge payload
- Bugfix for calling
__toString()
on objects that contain a\DateTime
- Add missing criteria to credit card verification search
- Bugfix for autoloading files with Composer
- Add oauth functionality
- Add 3DS info to the server side
- Update payment instrument types and test nonces
- Add missing valid params to PaymentMethodGateway
- Add 3D Secure transaction fields
- Add ability to create nonce from vaulted payment methods
- Surface Apple Pay payment instrument name in responses
- Support Coinbase payment instruments
- Fix E_STRICT errors
- Expose subscription status details
- Bugfix for auto loading files
- Allow PayPal fields in transaction.options.paypal
- Add error code constants
- Internal refactoring
- Add risk_data to Transaction and Verification with Kount decision and id
- Add verification_amount an option when creating a credit card
- Add TravelCruise industry type to Transaction
- Add room_rate to Lodging industry type
- Add CreditCard#verification as the latest verification on that credit card
- Add ApplePay support to all endpoints that may return ApplePayCard objects
- Add prefix to sample Webhook to simulate webhook query params
- Allow descriptor to be passed in Funding Details options params for Merchant Account create and update.
- Add additionalProcessorResponse to Transaction
- Allow payee_email to be passed in options params for Transaction create
- Added paypal specific fields to transaction calls
- Added SettlementPending, SettlementDeclined transaction statuses
- Add descriptor url support
- Allow credit card verification options to be passed outside of the nonce for PaymentMethod.create
- Allow billing_address parameters and billing_address_id to be passed outside of the nonce for PaymentMethod.create
- Add Subscriptions to paypal accounts
- Add PaymentMethod.update
- Add fail_on_duplicate_payment_method option to PaymentMethod.create
- Adds support for v.zero SDKs.
- Make webhook parsing more robust with newlines
- Add messages to InvalidSignature exceptions
- Updated secureCompare to correctly compare strings in consistent time
- Add better error messages around webhook verification
- Include Dispute information on Transaction
- Search for Transactions disputed on a certain date
- Disbursement Webhooks
- Fix factories on AddOn and Discount (thanks stewe)
- Allow billingAddressId on transaction create
- Merchant account find API
- Merchant account update API
- Merchant account create API v2
- Update configuration URLs
- Official Partnership support
- Add Partner Merchant Declined webhook
- use preg_callback_replace instead of preg_replace (thanks jonthornton!)
- Adds missing test contstant to library namespace
- Adds holdInEscrow method
- Add error codes for verification not supported error
- Add companyName and taxId to merchant account create
- Adds cancelRelease method
- Adds releaseFromEscrow functionality
- Adds phone to merchant account signature.
- Adds merchant account phone error code.
- Fix casing issues with Braintree_Http and Braintree_Util references (thanks steven-hadfield!)
- Fixed transaction initialization arguments to be optional (thanks karolsojko!)
- Enable device data.
- Fixed getting custom fields with valueForHtmlField. Thanks to Miguel Manso for the fix.
- Adds disbursement details to transactions.
- Adds image url to transactions.
- Adds channel field to transactions.
- Adds country of issuance and issuing bank bin database fields
- Adds verification search
- Additional card information, such as prepaid, debit, commercial, Durbin regulated, healthcare, and payroll, are returned on credit card responses
- Allows transactions to be specified as recurring
- Adds prepaid field to credit cards (possible values include Yes, No, Unknown)
- Adds composer support (thanks till)
- Fixes erroneous version number
- Braintree_Plan::all() returns empty array if no plans exist
- Adds webhook gateways for parsing, verifying, and testing notifications
- Adds search for duplicate credit cards given a payment method token
- Adds flag to fail saving credit card to vault if card is duplicate
- Exposes plan_id on transactions
- Added error code for invalid purchase order number
- Fixed problematic case in ResourceCollection when no results are returned from a search.
- Fixed customer search, which returned customers when no customers matched search criteria
- Added new error message for merchant accounts that do not support refunds
- Added ability to retrieve all Plans, AddOns, and Discounts
- Added Transaction cloning
- Added Braintree_SettlementBatchSummary
- Wrap dependency requirement in a function, to prevent pollution of the global namespace
- Added subscriptionDetails to Transaction
- Added flag to store in vault only when a transaction is successful
- Added new error code
- Added a new transaction state, AUTHORIZATION_EXPIRED.
- Enabled searching by authorizationExpiredAt.
- Added next_billing_date and transaction_id to subscription search
- Added address_country_name to customer search
- Added new error codes
- Added Customer search
- Added dynamic descriptors to Subscriptions and Transactions
- Added level 2 fields to Transactions:
- tax_amount
- tax_exempt
- purchase_order_number
- Added billingAddressId to allowed parameters for credit cards create and update
- Allow searching on subscriptions that are currently in a trial period using inTrialPeriod
- Added ability to perform multiple partial refunds on Braintree_Transactions
- Allow passing expirationMonth and expirationYear separately when creating Braintree_Transactions
- Added revertSubscriptionOnProrationFailure flag to Braintree_Subscription update that specifies how a Subscription should react to a failed proration charge
- Deprecated Braintree_Subscription nextBillAmount in favor of nextBillingPeriodAmount
- Deprecated Braintree_Transaction refundId in favor of refundIds
- Added new fields to Braintree_Subscription:
- balance
- paidThroughDate
- nextBillingPeriodAmount
- Added Braintree_AddOns/Braintree_Discounts
- Enhanced Braintree_Subscription search
- Enhanced Braintree_Transaction search
- Added constants for Braintree_Result_CreditCardVerification statuses
- Added EXPIRED and PENDING statuses to Braintree_Subscription
- Allowed prorateCharges to be specified on Braintree_Subscription update
- Added Braintree_AddOn/Braintree_Discount details to Braintree_Transactions that were created from a Braintree_Subscription
- Removed 13 digit Visa Sandbox Credit Card number and replaced it with a 16 digit Visa
- Added new fields to Braintree_Subscription:
- billingDayOfMonth
- daysPastDue
- firstBillingDate
- neverExpires
- numberOfBillingCycles
- Added ability to specify country using countryName, countryCodeAlpha2, countryCodeAlpha3, or countryCodeNumeric (see ISO_3166-1)
- Added gatewayRejectionReason to Braintree_Transaction and Braintree_Verification
- Added unified message to result objects
- Added unified Braintree_TransparentRedirect url and confirm methods and deprecated old methods
- Added functions to Braintree_CreditCard to allow searching on expiring and expired credit cards
- Allow card verification against a specified merchant account
- Added ability to update a customer, credit card, and billing address in one request
- Allow updating the paymentMethodToken on a subscription
- Prevent race condition when pulling back collection results -- search results represent the state of the data at the time the query was run
- Rename ResourceCollection's approximate_size to maximum_size because items that no longer match the query will not be returned in the result set
- Correctly handle HTTP error 426 (Upgrade Required) -- the error code is returned when your client library version is no long compatible with the gateway
- Add the ability to specify merchant_account_id when verifying credit cards
- Add subscription_id to transactions created from subscriptions
- Added transaction advanced search
- Added ability to partially refund transactions
- Added ability to manually retry past-due subscriptions
- Added new transaction error codes
- Allow merchant account to be specified when creating transactions
- Allow creating a transaction with a vault customer and new payment method
- Allow existing billing address to be updated when updating credit card
- Correctly handle xml with nil=true
- Updated success? on transaction responses to return false on declined transactions
- Search results now include Enumerable and will automatically paginate data
- Added credit_card[cardholder_name] to allowed transaction params and CreditCardDetails (thanks chrismcc)
- Fixed a bug with Customer::all
- Added constants for error codes
- Added methods to get both shallow and deep errors from a Braintree_ValidationErrorCollection
- Added the ability to make a credit card the default card for a customer
- Added constants for transaction statuses
- Updated Quick Start in README.md to show a workflow with error checking
- Added subscription search
- Provide access to associated subscriptions from CreditCard
- Switched from using Zend framework for HTTP requests to using curl extension
- Fixed a bug in Transparent Redirect when arg_separator.output is configured as & instead of &
- Increased http request timeout
- Fixed a bug where ForgedQueryString exception was being raised instead of DownForMaintenance
- Updated SSL CA files
- Added Braintree_Transaction::refund
- Added Braintree_Transaction::submitForSettlementNoValidate
- Fixed a bug in errors->onHtmlField when checking for errors on custom fields when there are none
- Added support for passing merchantAccountId for Transaction and Subscription
- Added recurring billing support
- Fixed bug with Braintree_Error_ErrorCollection.deepSize
- Added methods for accessing validation errors and params by html field name
- Initial release