!!! warning
This release fixes rolling back migrations. In order to migrate to
dj-stripe 2.4.0, you will have to be in an already-migrated 2.2+
installation of dj-stripe.
!!! warning
**Settings changes: Introduction of `DJSTRIPE_FOREIGN_KEY_TO_FIELD`**
You are required to set this new setting in 2.4.0.
For more information, checkout
[settings](https://dj-stripe.readthedocs.io/en/latest/reference/settings.html).
-
Support Django 3.1.
-
First-class support for the Price model, replacing Plans.
-
Support subscription schedules (#899).
-
Support multi-item subscriptions.
-
Support for API keys in the database. Check API keys.
-
Support for multiple Stripe accounts.
-
Add DJSTRIPE_USE_NATIVE_JSONFIELD setting to use Django 3.1 native JSONField over django-jsonfield.
-
Add support for Reporting categories, TaxIds and the following fields:
BalanceTransaction.source
InvoiceItem.unit_amount
InvoiceItem.unit_amount_decimal
Subscription.cancel_at
Subscription.billing_thresholds
SubscriptionItem.billing_thresholds
SubscriptionSchedule.billing_thresholds
alipay_account
inDjstripePaymentMethodType
and updated the following models:Charge
FileUploadPurpose
SourceTypes
-
Made
Account.payouts_enabled
nullable (#1107). -
Add an owner account to every StripeModel.
-
Rename PlanBillingScheme to BillingScheme.
-
Remove
Plan.update_name()
and these previously-deprecated fields:Customer.business_vat_id
Subscription.start
Subscription.billing
-
Increase minimum stripe-python version to 2.48.0.
-
Upgrade default Stripe API version to 2020-03-02.
-
Increased max_length of
DjstripePaymentMethod.type
, as first step towards support of alipay_account (#1120). -
Fixed Account.get_default_account() for Restricted API Keys.
-
Fixed Account logo sync failure on test mode (#830).
-
Changed
JSONField
dependency back to jsonfield from jsonfield2 (see Warning about safe uninstall of jsonfield2 on upgrade). -
Dropped support for Django 2.1 (#1056).
-
Dropped support for python 3.5 (#1073).
-
Fixed handling of
TaxRate
events (#1094). -
Fixed pagination issue in
Invoice.sync_from_stripe_data
(#1052). -
Fixed pagination issues in
Subscription
&Charge
.sync_from_stripe_data
(#1054). -
Tidyup
_stripe_object_set_total_tax_amounts
unique handling (#1139). -
Dropped previously-deprecated
Invoice
fields (see https://stripe.com/docs/upgrades#2018-11-08 ):.closed
.forgiven
.billing
(renamed to.collection_method
)
-
Dropped previously-deprecated
enums.InvoiceStatus
(#1020). -
Deprecated the following fields - will be removed in 2.4 (#1087):
Subscription.billing
(use.collection_method
instead)Subscription.start
(use.start_date
instead)Subscription.tax_percent
(use.default_tax_rates
instead)
-
Added
Invoice.status
andenums.InvoiceStatus
(#1020). -
Fixed str(Account) crash when settings or business_profile were NULL (#1104).
-
Added new
Invoice
fields (#1020, #1087):.discount
.default_source
.status
-
Added new
Subscription
fields (#1087):.default_payment_method
.default_source
.next_pending_invoice_item_invoice
.pending_invoice_item_interval
.pending_update
.start_date
!!! warning
Both **jsonfield** and **jsonfield2** use the same import path, so if
upgrading from dj-stripe\~=2.2.0 in an existing virtualenv, be sure to
uninstall jsonfield2 first. eg:
# ensure jsonfield is uninstalled before we install jsonfield2
pip uninstall jsonfield2 -y && pip install "dj-stripe>=2.3.0dev"
Otherwise, `pip uninstall jsonfield2` will remove jsonfield's
`jsonfield` module from `site-packages`, which would cause errors like
`ImportError: cannot import name 'JSONField' from 'jsonfield' (unknown location)`
If you have hit this ImportError already after upgrading, running this
should resolve it:
# remove both jsonfield packages before reinstall to fix ImportError:
pip uninstall jsonfield jsonfield2 -y && pip install "dj-stripe>=2.3.0dev"
Note that this is only necessary if upgrading from dj-stripe 2.2.x,
which temporarily depended on jsonfield2. This process is not necessary
if upgrading from an earlier version of dj-stripe.
This is a bugfix-only version:
- Fixed handling of
TaxRate
events (#1094).
This is a bugfix-only version:
- Fixed bad package build.
-
Changed
JSONField
dependency package from jsonfield to jsonfield2, for Django 3 compatibility (see Warning about safe uninstall of jsonfield on upgrade). Note that Django 2.1 requires jsonfield<3.1. -
Added support for Django 3.0 (requires jsonfield2>=3.0.3).
-
Added support for python 3.8.
-
Refactored
UpcomingInvoice
, so it's no longer a subclass ofInvoice
(to allowInvoice
to useManyToManyFields
). -
Dropped previously-deprecated
Account
fields (see https://stripe.com/docs/upgrades#2019-02-19 ):.business_name
.business_primary_color
.business_url
(changed to a property).debit_negative_balances
.decline_charge_on
.display_name
.legal_entity
.payout_schedule
.payout_statement_descriptor
.statement_descriptor
.support_email
.support_phone
.support_url
.timezone
.verification
-
Dropped previously-deprecated
Account.business_logo
property (renamed to.branding_icon
) -
Dropped previously-deprecated
Customer.account_balance
property (renamed to.balance
) -
Dropped previously-deprecated properties
Invoice.application_fee
,Invoice.date
-
Dropped previously-deprecated enum
PaymentMethodType
(useDjstripePaymentMethodType
instead) -
Renamed
Invoice.billing
to.collection_method
(added deprecated property for the old name). -
Updated
Invoice
model to add missing fields. -
Added
TaxRate
model, andInvoice.default_tax_rates
,InvoiceItem.tax_rates
,Invoice.total_tax_amounts
,Subscription.default_tax_rates
,SubscriptionItem.tax_rates
(#1027). -
Change urls.py to use the new style urls.
-
Update forward relation fields in the admin to be raw id fields.
-
Updated
StripeQuantumCurrencyAmountField
andStripeDecimalCurrencyAmountField
to support Stripe Large Charges (#1045). -
Update event handling so
customer.subscription.deleted
updates subscriptions tostatus="canceled"
instead of deleting it from our database, to match Stripe's behaviour (#599). -
Added missing
Refund.reason
value, increases field width (#1075). -
Fixed
Refund.status
definition, reduces field width (#1076). -
Deprecated non-standard
Invoice.status
(renamed toInvoice.legacy_status
) to make way for the Stripe field (preparation for #1020).
!!! warning
Both **jsonfield** and **jsonfield2** use the same import path, so if
upgrading to dj-stripe>=2.2 in an existing virtualenv, be sure to
uninstall jsonfield first. eg:
# ensure jsonfield is uninstalled before we install jsonfield2
pip uninstall jsonfield -y && pip install "dj-stripe>=2.2.0dev"
Otherwise, `pip uninstall jsonfield` will remove jsonfield2’s
`jsonfield` module from `site-packages`, which would cause errors like
`ImportError: cannot import name 'JSONField' from 'jsonfield' (unknown location)`
If you have hit this ImportError already after upgrading, running this
should resolve it:
# remove both jsonfield packages before reinstall to fix ImportError:
pip uninstall jsonfield jsonfield2 -y && pip install "dj-stripe>=2.2.0dev"
See https://dj-stripe.readthedocs.io/en/latest/stripe_elements_js.html for notes about usage of the Stripe Elements frontend JS library.
TLDR: if you haven't yet migrated to PaymentIntents, prefer
stripe.createSource()
to stripe.createToken()
.
This is a bugfix-only version:
- Updated webhook signals list (#1000).
- Fixed issue syncing PaymentIntent with destination charge (#960).
- Fixed
Customer.subscription
&.valid_subscriptions()
to ignorestatus=incomplete_expired
(#1006). - Fixed error on
paymentmethod.detached
event withcard_xxx
payment methods (#967). - Added
PaymentMethod.detach()
(#943). - Updated
help_text
on all currency fields to make it clear if they're holding integer cents (StripeQuantumCurrencyAmountField
) or decimal dollar (or euro, pound etc) (StripeDecimalCurrencyAmountField
) (#999) - Documented our preferred Django model field types (#986)
Please be aware that we're looking at standardising our currency storage fields as integer quanta (cents) instead of Decimal (dollar) values, to match stripe.
This is intended to be part of the 3.0 release, since it will involve some breaking changes. See #955 for details and discussion.
-
Dropped Django 2.0 support
-
The Python stripe library minimum version is now
2.32.0
, also2.36.0
is excluded due to a regression (#991). -
Dropped previously-deprecated
Charge.fee_details
property. -
Dropped previously-deprecated
Transfer.fee_details
property. -
Dropped previously-deprecated
field_name
parameter tosync_from_stripe_data
-
Dropped previously-deprecated alias
StripeObject
ofStripeModel
-
Dropped previously-deprecated alias
PaymentMethod
ofDjstripePaymentMethod
-
Dropped previously-deprecated properties
Charge.source_type
andCharge.source_stripe_id
-
enums.PaymentMethodType
has been deprecated, useenums.DjstripePaymentMethodType
-
Made
SubscriptionItem.quantity
nullable as per Plans withusage_type="metered"
(follow-up to #865) -
Added manage commands
djstripe_sync_models
anddjstripe_process_events
(#727, #89) -
Fixed issue with re-creating a customer after
Customer.purge()
(#916) -
Fixed sync of Customer Bank Accounts (#829)
-
Fixed
Subscription.is_status_temporarily_current()
(#852) -
New models
- Payment Intent
- Setup Intent
- Payment Method
- Session
-
Added fields to
Customer
model:address
,invoice_prefix
,invoice_settings
,phone
,preferred_locales
,tax_exempt
Changes from API 2018-11-08:
- Added
Invoice.auto_advance
, deprecatedInvoice.closed
andInvoice.forgiven
, see https://stripe.com/docs/billing/invoices/migrating-new-invoice-states#autoadvance
Changes from API 2019-02-19:
-
Major changes to Account fields, see https://stripe.com/docs/upgrades#2019-02-19 , updated Account fields to match API 2019-02-19:
-
Added
Account.business_profile
,.business_type
,.company
,.individual
,.requirements
,.settings
-
Deprecated the existing fields, to be removed in 2.2
-
Special handling of the icon and logo fields:
- Renamed
Account.business_logo
toAccount.branding_icon
(note that in Stripe's APIAccount.business_logo
was renamed toAccount.settings.branding_icon
, andAccount.business_logo_large
(which we didn't have a field for) was renamed toAccount.settings.branding_logo
) - Added deprecated property for
Account.business_logo
- Added
Account.branding_logo
as a ForeignKey - Populate
Account.branding_icon
and.branding_logo
from the newAccount.settings.branding.icon
and.logo
- Renamed
Changes from API 2019-03-14:
- Renamed
Invoice.application_fee
toInvoice.application_fee_amount
(added deprecated property for the old name) - Removed
Invoice.date
, in place ofInvoice.created
(added deprecated property for the old name) - Added
Invoice.status_transitions
- Renamed
Customer.account_balance
toCustomer.balance
(added deprecated property for the old name) - Renamed
Customer.payment_methods
toCustomer.customer_payment_methods
- Added new
SubscriptionStatus.incomplete
andSubscriptionStatus.incomplete_expired
statuses (#974) - Added new
BalanceTransactionType
values (#983)
As per our migration policy unreleased migrations on the master branch (migration numbers >=0004) have been squashed.
If you have been using the 2.1.0dev branch from master, you'll need to run the squashed migrations migrations before upgrading to >=2.1.0.
The simplest way to do this is to pip install dj-stripe==2.1.0rc0
and
migrate, alternatively check out the 2.1.0rc0
git tag.
This is a bugfix-only version:
- Avoid stripe==2.36.0 due to regression (#991)
This is a bugfix-only version:
- Fixed irreversible migration (#909)
This is a bugfix-only version:
- In
_get_or_create_from_stripe_object
, wrap create_create_from_stripe_object
in transaction, fixesTransactionManagementError
on race condition in webhook processing (#877/#903).
This is a bugfix-only version:
- Don't save event objects if the webhook processing fails (#832).
- Fixed IntegrityError when
REMOTE_ADDR
is an empty string. - Deprecated
field_name
parameter tosync_from_stripe_data
This is a bugfix-only version:
- Fixed an error on
invoiceitem.updated
(#848). - Handle test webhook properly in recent versions of Stripe API
(#779). At some point 2018 Stripe silently changed the ID used for
test events and
evt_00000000000000
is not used anymore. - Fixed OperationalError seen in migration 0003 on postgres (#850).
- Fixed issue with migration 0003 not being unapplied correctly (#882).
- Fixup missing
SubscriptionItem.quantity
on Plans withusage_type="metered"
(#865). - Fixed
Plan.create()
(#870).
- The Python stripe library minimum version is now
2.3.0
. PaymentMethod
has been renamed toDjstripePaymentMethod
(#841). An alias remains but will be removed in the next version.- Dropped support for Django < 2.0, Python < 3.4.
- Dropped previously-deprecated
stripe_objects
module. - Dropped previously-deprecated
stripe_timestamp
field. - Dropped previously-deprecated
Charge.receipt_number
field. - Dropped previously-deprecated
StripeSource
alias forCard
- Dropped previously-deprecated
SubscriptionView
,CancelSubscriptionView
andCancelSubscriptionForm
. - Removed the default value from
DJSTRIPE_SUBSCRIPTION_REDIRECT
. - All
stripe_id
fields have been renamedid
. Charge.source_type
has been deprecated. UseCharge.source.type
.Charge.source_stripe_id
has been deprecated. UseCharge.source.id
.- All deprecated Transfer fields (Stripe API < 2017-04-06), have
been dropped. This includes
date
,destination_type
(type
),failure_code
,failure_message
,statement_descriptor
andstatus
. - Fixed IntegrityError when
REMOTE_ADDR
is missing (#640). - New models:
ApplicationFee
ApplicationFeeRefund
BalanceTransaction
CountrySpec
ScheduledQuery
SubscriptionItem
TransferReversal
UsageRecord
- The
fee
andfee_details
attributes of both theCharge
andTransfer
objects are no longer stored in the database. Instead, they access their respective newbalance_transaction
foreign key. Note thatfee_details
has been deprecated on both models. - The
fraudulent
attribute onCharge
is now a property that checks thefraud_details
field. - Object key validity is now always enforced (#503).
Customer.sources
no longer refers to a Card queryset, but to a Source queryset. In order to correctly transition, you should change all your references tocustomer.sources
tocustomer.legacy_cards
instead. Thelegacy_cards
attribute already exists in 1.2.0.Customer.sources_v3
is now namedCustomer.sources
.- A new property
Customer.payment_methods
is now available, which allows you to iterate over all of a customer's payment methods (sources then cards). Card.customer
is now nullable and cards are no longer deleted when their corresponding customer is deleted (#654).- Webhook signature verification is now available and is preferred.
Set the
DJSTRIPE_WEBHOOK_SECRET
setting to your secret to start using it. StripeObject
has been renamedStripeModel
. An alias remains but will be removed in the next version.- The metadata key used in the
Customer
object can now be configured by changing theDJSTRIPE_SUBSCRIBER_CUSTOMER_KEY
setting. Setting this to None or an empty string now also disables the behaviour altogether. - Text-type fields in dj-stripe will no longer ever be None. Instead, any falsy text field will return an empty string.
- Switched test runner to pytest-django
StripeModel.sync_from_stripe_data()
will now automatically retrieve related objects and populate foreign keys (#681)- Added
Coupon.name
- Added
Transfer.balance_transaction
- Exceptions in webhooks are now re-raised as well as saved in the database (#833)
This is a bugfix-only version:
- Allow billing_cycle_anchor argument when creating a subscription (#814)
- Fixup plan amount null with tier plans (#781)
- Update Cancel subscription view tests to match backport in f64af57
- Implement Invoice._manipulate_stripe_object_hook for compatability with API 2018-11-08 (#771)
- Fix product webhook for type="good" (#724)
- Add trial_from_plan, trial_period_days args to Customer.subscribe() (#709)
This is a bugfix-only version:
- Updated Subscription.cancel() for compatibility with Stripe 2018-08-23 (#723)
This is a bugfix-only version:
- Fixed an error with request.urlconf in some setups (#562)
- Always save text-type fields as empty strings in db instead of null (#713)
- Fix support for DJSTRIPE_SUBSCRIBER_MODEL_MIGRATION_DEPENDENCY (#707)
- Fix reactivate() with Stripe API 2018-02-28 and above
This is a bugfix-only version:
- Fixed various Python 2.7 compatibility issues
- Fixed issues with max_length of receipt_number
- Fixed various fields incorrectly marked as required
- Handle product webhook calls
- Fix compatibility with stripe-python 2.0.0
The dj-stripe 1.2.0 release resets all migrations.
Do not upgrade to 1.2.0 directly from 1.0.1 or below. You must upgrade to 1.1.0 first.
Please read the 1.1.0 release notes below for more information.
In dj-stripe 1.1.0, we made a lot of changes to models in order to bring the dj-stripe model state much closer to the upstream API objects. If you are a current user of dj-stripe, you will most likely have to make changes in order to upgrade. Please read the full changelog below. If you are having trouble upgrading, you may ask for help by filing an issue on GitHub.
The next version of dj-stripe, 1.2.0, will reset all the migrations
to 0001_initial
. Migrations are currently in an unmaintainable state.
What this means is you will not be able to upgrade directly to dj-stripe 1.2.0. You must go through 1.1.0 first, run ``manage.py migrate djstripe``, then upgrade to 1.2.0.
dj-stripe 1.1.0 drops support for Django 1.10 and adds support for Django 2.0. Django 1.11+ and Python 2.7+ or 3.4+ are required.
Support for Python versions older than 3.5, and Django versions older than 2.0, will be dropped in dj-stripe 2.0.0.
The model architecture of dj-stripe has been simplified. Polymorphic models have been dropped and the old base StripeCustomer, StripeCharge, StripeInvoice, etc models have all been merged into the top-level Customer, Charge, Invoice, etc models.
Importing those legacy models from djstripe.stripe_objects
will yield
the new ones. This is deprecated and support for this will be dropped in
dj-stripe 2.0.0.
Stripe sources (src_XXXX
) are objects that can arbitrarily reference
any of the payment method types that Stripe supports. However, the
legacy Card
object (with object IDs like card_XXXX
or cc_XXXX
) is
not a Source object, and cannot be turned into a Source object at this
time.
In order to support both Card and Source objects in ForeignKeys, a new
model PaymentMethod
has been devised (renamed to
DjstripePaymentMethod
in 2.0). That model can resolve into a Card, a
Source, or a BankAccount object.
- The ``default_source`` attribute on ``Customer`` now
refers to a ``PaymentMethod`` object. You will need to call
.resolve()
on it to get the Card or Source in question. - References to
Customer.sources
expecting a queryset of Card objects should be updated toCustomer.legacy_cards
. - The legacy
StripeSource
name refers to theCard
model. This will be removed in dj-stripe 2.0.0. Update your references to eitherCard
orSource
. enums.SourceType
has been renamed toenums.LegacySourceType
.enums.SourceType
now refers to the actual Stripe Source types enum.
- The numeric
id
field has been renamed todjstripe_id
. This avoids a clash with the upstream stripe id. Accessing.id
is deprecated and **will reference the upstreamstripe_id
in dj-stripe 2.0.0
It's finally here! We've made significant changes to the codebase and are now compliant with stripe API version 2017-06-05.
I want to give a huge thanks to all of our contributors for their help in making this happen, especially Bill Huneke (@wahuneke) for his impressive design work and @jleclanche for really pushing this release along.
I also want to welcome onboard two more maintainers, @jleclanche and @lskillen. They've stepped up and have graciously dedicated their resources to making dj-stripe such an amazing package.
Almost all methods now mimic the parameters of those same methods in the stripe API. Note that some methods do not have some parameters implemented. This is intentional. That being said, expect all method signatures to be different than those in previous versions of dj-stripe.
Finally, please note that there is still a bit of work ahead of us. Not everything in the Stripe API is currently supported by dj-stripe -- we're working on it. That said, v1.0.0 has been thoroughly tested and is verified stable in production applications.
- Multiple subscription support (finally)
- Multiple sources support (currently limited to Cards)
- Idempotency support (See #455, #460 for discussion -- big thanks to @jleclanche)
- Full model documentation
- Objects that come through webhooks are now tied to the API version set in dj-stripe. No more errors if dj-stripe falls behind the newest stripe API version.
- Any create/update action on an object automatically syncs the object.
- Concurrent LIVE and TEST mode support (Thanks to @jleclanche). Note
that you'll run into issues if
livemode
isn't set on your existing customer objects. - All choices are now enum-based (Thanks @jleclanche, See #520).
Access them from the new
djstripe.enums
module. The ability to check against model property based choices will be deprecated in 1.1 - Support for the Coupon model, and coupons on Customer objects.
- Support for the Payout/Transfer
split from api
version
2017-04-06
.
-
Documentation. Our original documentation was not very helpful, but it covered the important bits. It will be very out of date after this update and will need to be rewritten. If you feel like helping, we could use all the help we can get to get this pushed out asap.
-
Master sync re-write. This sounds scary, but really isn't. The current management methods run sync methods on Customer that aren't very helpful and are due for removal. My plan is to write something that first updates local data (via
api_retrieve
andsync_from_stripe_data
) and then pulls all objects from Stripe and populates the local database with any records that don't already exist there.You might be wondering, "Why are they releasing this if there are only a few things left?" Well, that thinking turned this into a two year release... Trust me, this is a good thing.
- Idempotency. #460 introduces idempotency keys and implements
idempotency for
Customer.get_or_create()
. Idempotency will be enabled for all calls that need it. - Improved Admin Interface. This is almost complete. See #451 and #452.
- Drop non-trivial endpoint views. We're dropping everything except the webhook endpoint and the subscription cancel endpoint. See #428.
- Drop support for sending receipts. Stripe now handles this for you. See #478.
- Drop support for plans as settings, including custom plan hierarchy (if you want this, write something custom) and the dynamic trial callback. We've decided to gut having plans as settings. Stripe should be your source of truth; create your plans there and sync them down manually. If you need to create plans locally for testing, etc., simply use the ORM to create Plan models. The sync rewrite will make this drop less annoying.
- Orphan Customer Sync. We will now sync Customer objects from Stripe even if they aren't linked to local subscriber objects. You can link up subscribers to those Customers manually.
- Concurrent Live and Test Mode. dj-stripe now supports test-mode and live-mode Customer objects concurrently. As a result, the User.customer One-to-One reverse-relationship is now the User.djstripe_customers RelatedManager. (Thanks @jleclanche) #440. You'll run into some dj-stripe check issues if you don't update your KEY settings accordingly. Check our GitHub issue tracker for help on this.
- The
PLAN_CHOICES
,PLAN_LIST
, andPAYMENT_PLANS
objects are removed. Use Plan.objects.all() instead. - The
plan_from_stripe_id
function is removed. Use Plan.objects.get(stripe_id=)
- sync_plans no longer takes an api_key
- sync methods no longer take a
cu
parameter - All sync methods are now private. We're in the process of building a better syncing mechanism.
- dj-stripe decorators now take a plan argument. If you're passing in
a custom test function to
subscriber_passes_pay_test
, be sure to account for this new argument.
- The context provided by dj-stripe's mixins has changed.
PaymentsContextMixin
now providesSTRIPE_PUBLIC_KEY
andplans
(changed toPlan.objects.all()
).SubscriptionMixin
now providescustomer
andis_plans_plural
. - We've removed the SubscriptionPaymentRequiredMixin. Use
@method_decorator("dispatch",
subscription_payment_required)
instead.
- dj-stripe middleware doesn't support multiple subscriptions.
- Local custom signals are deprecated in favor of Stripe webhooks:
cancelled
-> WEBHOOK_SIGNALS["customer.subscription.deleted"]card_changed
-> WEBHOOK_SIGNALS["customer.source.updated"]subscription_made
-> WEBHOOK_SIGNALS["customer.subscription.created"]
- The Event Handlers designed by @wahuneke are the new way to handle
events that come through webhooks. Definitely take a look at
event_handlers.py
andwebhooks.py
.
SubscriptionUpdateFailure
andSubscriptionCancellationFailure
exceptions are removed. There should no longer be a case where they would have been useful. Catch native stripe errors in their place instead.
CHARGE
-
Charge.charge_created
->Charge.stripe_timestamp
-
Charge.card_last_4
andCharge.card_kind
are removed. UseCharge.source.last4
andCharge.source.brand
(if the source is a Card) -
Charge.invoice
is no longer a foreign key to the Invoice model.Invoice
now has a OneToOne relationship withCharge
. (Charge.invoice
will still work, but will no longer be represented in the database).CUSTOMER
-
dj-stripe now supports test mode and live mode Customer objects concurrently (See #440). As a result, the
<subscriber_model>.customer
OneToOne reverse relationship is no longer a thing. You should now instead add acustomer
property to your subscriber model that checks whether you're in live or test mode (see djstripe.settings.STRIPE_LIVE_MODE as an example) and grabs the customer from<subscriber_model>.djstripe_customers
with a simplelivemode=
filter. -
Customer no longer has a
current_subscription
property. We've added asubscription
property that should suit your needs. -
With the advent of multiple subscriptions, the behavior of
Customer.subscribe()
has changed. Before,calling subscribe()
when a customer was already subscribed to a plan would switch the customer to the new plan with an option to prorate. Now callingsubscribe()
simply subscribes that customer to a new plan in addition to it's current subsription. UseSubscription.update()
to change a subscription's plan instead. -
Customer.cancel_subscription()
is removed. UseSubscription.cancel()
instead. -
The
Customer.update_plan_quantity()
method is removed. UseSubscription.update()
instead. -
CustomerManager
is nowSubscriptionManager
and works on theSubscription
model instead of theCustomer
model. -
Customer.has_valid_card()
is nowCustomer.has_valid_source()
. -
Customer.update_card()
now takes an id. If the id is not supplied, the default source is updated. -
Customer.stripe_customer
property is removed. UseCustomer.api_retrieve()
instead. -
The
at_period_end
parameter ofCustomer.cancel_subscription()
now actually follows the DJSTRIPE_PRORATION_POLICY setting. -
Customer.card_fingerprint
,Customer.card_last_4
,Customer.card_kind
,Customer.card_exp_month
,Customer.card_exp_year
are all removed. CheckCustomer.default_source
(if it's a Card) or one of the sources inCustomer.sources
(again, if it's a Card) instead. -
The
invoice_id
parameter ofCustomer.add_invoice_item
is now namedinvoice
and can be either an Invoice object or the stripe_id of an Invoice.EVENT
-
Event.kind
->Event.type
-
Removed
Event.validated_message
. Just check if the event is valid- no need to double check (we do that for you)
TRANSFER
-
Removed
Transfer.update_status()
-
Removed
Transfer.event
-
TransferChargeFee
is removed. It hasn't been used in a while due to a broken API version. UseTransfer.fee_details
instead. -
Any fields that were in
Transfer.summary
no longer exist and are therefore deprecated (unused but not removed from the database). Because of this,TransferManager
now only aggregatestotal_sum
INVOICE
-
Invoice.attempts
->Invoice.attempt_count
-
InvoiceItems are no longer created when Invoices are synced. You must now sync InvoiceItems directly.
INVOICEITEM
-
Removed
InvoiceItem.line_type
PLAN
-
Plan no longer has a
stripe_plan
property. Useapi_retrieve()
instead. -
Plan.currency
no longer uses choices. Use theget_supported_currency_choices()
utility and create your own custom choices list instead. -
Plan interval choices are now in
Plan.INTERVAL_TYPE_CHOICES
SUBSCRIPTION
-
Subscription.is_period_current()
now checks for a current trial end if the current period has ended. This change means subscriptions extended withSubscription.extend()
will now be seen as valid.
We'll sync your current records with Stripe in a migration. It will take a while, but it's the only way we can ensure data integrity. There were some fields for which we needed to temporarily add placeholder defaults, so just make sure you have a customer with ID 1 and a plan with ID 1 and you shouldn't run into any issues (create dummy values for these if need be and delete them after the migration).
!!! warning
Subscription and InvoiceItem migration is not possible because old
records don't have Stripe IDs (so we can't sync them). Our approach is
to delete all local subscription and invoiceitem objects and re-sync
them from Stripe.
We 100% recommend you create a backup of your database before performing
this upgrade.
- Postgres users now have access to the
DJSTRIPE_USE_NATIVE_JSONFIELD
setting. (Thanks @jleclanche) #517, #523 - Charge receipts now take
DJSTRIPE_SEND_INVOICE_RECEIPT_EMAILS
into account (Thanks @r0fls) - Clarified/modified installation documentation (Thanks @pydanny)
- Corrected and revised ANONYMOUS_USER_ERROR_MSG (Thanks @pydanny)
- Added fnmatching to
SubscriptionPaymentMiddleware
(Thanks @pydanny) SubscriptionPaymentMiddleware.process_request()
functionality broken up into multiple methods, making local customizations easier (Thanks @pydanny)- Fully qualified events are now supported by event handlers as strings e.g. 'customer.subscription.deleted' (Thanks @lskillen) #316
- runtests now accepts positional arguments for declaring which tests to run (Thanks @lskillen) #317
- It is now possible to reprocess events in both code and the admin interface (Thanks @lskillen) #318
- The confirm page now checks that a valid card exists. (Thanks @scream4ik) #325
- Added support for viewing upcoming invoices (Thanks @lskillen) #320
- Event handler improvements and bugfixes (Thanks @lskillen) #321
- API list() method bugfixes (Thanks @lskillen) #322
- Added support for a custom webhook event handler (Thanks @lskillen) #323
- Django REST Framework contrib package improvements (Thanks @aleccool213) #334
- Added
tax_percent
to CreateSubscriptionSerializer (Thanks @aleccool213) #349 - Fixed incorrectly assigned
application_fee
in Charge calls (Thanks @kronok) #382 - Fixed bug caused by API change (Thanks @jessamynsmith) #353
- Added inline documentation to pretty much everything and enforced docsytle via flake8 (Thanks @aleccool213)
- Fixed outdated method call in template (Thanks @kandoio) #391
- Customer is correctly purged when subscriber is deleted, regardless of how the deletion happened (Thanks @lskillen) #396
- Test webhooks are now properly captured and logged. No more bounced requests to Stripe! (Thanks @jameshiew) #408
- CancelSubscriptionView redirect is now more flexible (Thanks @jleclanche) #418
- Customer.sync_cards() (Thanks @jleclanche) #438
- Many stability fixes, bugfixes, and code cleanup (Thanks @jleclanche)
- Support syncing canceled subscriptions (Thanks @jleclanche) #443
- Improved admin interface (Thanks @jleclanche with @jameshiew) #451
- Support concurrent TEST + LIVE API keys (Fix webhook event processing for both modes) (Thanks @jleclanche) #461
- Added Stripe Dashboard link to admin change panel (Thanks @jleclanche) #465
- Implemented
Plan.amount_in_cents
(Thanks @jleclanche) #466 - Implemented
Subscription.reactivate()
(Thanks @jleclanche) #470 - Added
Plan.human_readable_price
(Thanks @jleclanche) #498 - (Re)attach the Subscriber when we find it's id attached to a customer on Customer sync (Thanks @jleclanche) #500
- Made API version configurable (with dj-stripe recommended default) (Thanks @lskillen) #504
- better plan ordering documentation (Thanks @cjrh)
- added a confirmation page when choosing a subscription (Thanks @chrissmejia, @areski)
- setup.py reverse dependency fix (#258/#268) (Thanks @ticosax)
- Dropped official support for Django 1.7 (no code changes were made)
- Python 3.5 support, Django 1.9.1 support
- Migration improvements (Thanks @michi88)
- Fixed "Invoice matching query does not exist" bug (#263) (Thanks @mthornhill)
- Fixed duplicate content in account view (Thanks @areski)
- dj-stripe now responds to the invoice.created event (Thanks @wahuneke)
- dj-stripe now cancels subscriptions and purges customers during sync if they were deleted from the stripe dashboard (Thanks @unformatt)
- dj-stripe now checks for an active stripe subscription in the
update_plan_quantity
call (Thanks @ctrengove) - Event processing is now handled by "event handlers" - functions outside of models that respond to various event types and subtypes. Documentation on how to tie into the event handler system coming soon. (Thanks @wahuneke)
- Experimental Python 3.5 support
- Support for Django 1.6 and lower is now officially gone.
- Much, much more!
- Support for Django 1.6 and lower is now deprecated.
- Improved test harness now tests coverage and pep8
- SubscribeFormView and ChangePlanView no longer populate self.error with form errors
- InvoiceItems.plan can now be null (as it is with individual charges), resolving #140 (Thanks @awechsler and @MichelleGlauser for help troubleshooting)
- Email templates are now packaged during distribution.
- sync_plans now takes an optional api_key
- 100% test coverage
- Stripe ID is now returned as part of each model's str method (Thanks @areski)
- Customer model now stores card expiration month and year (Thanks @jpadilla)
- Ability to extend subscriptions (Thanks @TigerDX)
- Support for plan heirarchies (Thanks @chrissmejia)
- Rest API endpoints for Subscriptions [contrib] (Thanks @philippeluickx)
- Admin interface search by email funtionality is removed (#221) (Thanks @jpadilla)
- Began deprecation of support for Django 1.6 and lower.
- Added formal support for Django 1.8.
- Removed the StripeSubscriptionSignupForm
- Removed
djstripe.safe_settings
. Settings are now all located indjstripe.settings
DJSTRIPE_TRIAL_PERIOD_FOR_SUBSCRIBER_CALLBACK
can no longer be a module string- The sync_subscriber argument has been renamed from subscriber_model to subscriber
- Moved available currencies to the DJSTRIPE_CURRENCIES setting (Thanks @martinhill)
- Allow passing of extra parameters to stripe Charge API (Thanks @mthornhill)
- Support for all available arguments when syncing plans (Thanks @jamesbrobb)
- charge.refund() now returns the refunded charge object (Thanks @mthornhill)
- Charge model now has captured field and a capture method (Thanks @mthornhill)
- Subscription deleted webhook bugfix
- South migrations are now up to date (Thanks @Tyrdall)
- Formal Python 3.3+/Django 1.7 Support (including migrations)
- Removed Python 2.6 from Travis CI build. (Thanks @audreyr)
- Dropped Django 1.4 support. (Thanks @audreyr)
- Deprecated the
djstripe.forms.StripeSubscriptionSignupForm
. Making this form work easily with bothdj-stripe
anddjango-allauth
required too much abstraction. It will be removed in the 0.5.0 release. - Add the ability to add invoice items for a customer (Thanks @kavdev)
- Add the ability to use a custom customer model (Thanks @kavdev)
- Added setting to disable Invoice receipt emails (Thanks Chris Halpert)
- Enable proration when customer upgrades plan, and pass proration policy and cancellation at period end for upgrades in settings. (Thanks Yasmine Charif)
- Removed the redundant context processor. (Thanks @kavdev)
- Fixed create a token call in change_card.html (Thanks @dollydagr)
- Fix
charge.dispute.closed
typo. (Thanks @ipmb) - Fix contributing docs formatting. (Thanks @audreyr)
- Fix subscription canceled_at_period_end field sync on plan upgrade (Thanks @nigma)
- Remove "account" bug in Middleware (Thanks @sromero84)
- Fix correct plan selection on subscription in subscribe_form template. (Thanks Yasmine Charif)
- Fix subscription status in account, _subscription_status, and cancel_subscription templates. (Thanks Yasmine Charif)
- Now using
user.get_username()
instead ofuser.username
, to support custom User models. (Thanks @shvechikov) - Update remaining DOM Ids for Bootstrap 3. (Thanks Yasmine Charif)
- Update publish command in setup.py. (Thanks @pydanny)
- Explicitly specify tox's virtual environment names. (Thanks @audreyr)
- Manually call django.setup() to populate apps registry. (Thanks @audreyr)
- Fixed
djstripe_init_customers
management command so it works with custom user models.
- Clarify documentation for redirects on app_name.
- If settings.DEBUG is True, then django-debug-toolbar is exempt from redirect to subscription form.
- Use collections.OrderedDict to ensure that plans are listed in order of price.
- Add
ordereddict
library to support Python 2.6 users. - Switch from
__unicode__
to__str__
methods on models to better support Python 3. - Add
python_2_unicode_compatible
decorator to Models. - Check for PY3 so the
unicode(self.user)
in models.Customer doesn't blow up in Python 3.
- Increased the extendability of the views by removing as many
hard-coded URLs as possible and replacing them with
success_url
and other attributes/methods. - Added single unit purchasing to the cookbook
- Made Yasmine Charif a core committer
- Take into account trial days in a subscription plan (Thanks Yasmine Charif)
- Correct invoice period end value (Thanks Yasmine Charif)
- Make plan cancellation and plan change consistently not prorating (Thanks Yasmine Charif)
- Fix circular import when ACCOUNT_SIGNUP_FORM_CLASS is defined (Thanks Dustin Farris)
- Add send e-mail receipt action in charges admin panel (Thanks Buddy Lindsay)
- Add
created
field to all ModelAdmins to help with internal auditing (Thanks Kulbir Singh)
- Cancellation fix (Thanks Yasmine Charif)
- Add setup.cfg for wheel generation (Thanks Charlie Denton)
- Fully tested against Django 1.6, 1.5, and 1.4
- Fix boolean default issue in models (from now on they are all
default to
False
). - Replace duplicated code with
djstripe.utils.user_has_active_subscription
.
- Cancellation added to views.
- Support for kwargs on charge and invoice fetching.
- def charge() now supports send_receipt flag, default to True.
- Fixed templates to work with Bootstrap 3.0.0 column design.
- Improved usage documentation.
- Corrected order of fields in StripeSubscriptionSignupForm.
- Corrected transaction history template layout.
- Updated models to take into account when settings.USE_TZ is disabled.
- Add handy rest_framework permission class.
- Fixing attribution for django-stripe-payments.
- Add new status to Invoice model.
- Changed name of division tag to djdiv.
- Added
safe_setting.py
module to handle edge cases when working with custom user models. - Added cookbook page in the documentation.
- Fixed bug in initial checkout
- You can't purchase the same plan that you currently have.
- Recursive package finding.
- Fix packaging so all submodules are loaded
- Added Registration + Subscription form
- Fixed a bug on CurrentSubscription tests
- Improved usage documentation
- Added to migration from other tools documentation
- Cancellation of plans now works.
- Upgrades and downgrades of plans now work.
- Changing of cards now works.
- Added breadcrumbs to improve navigation.
- Improved installation instructions.
- Consolidation of test instructions.
- Minor improvement to django-stripe-payments documentation
- Added coverage.py to test process.
- Added south migrations.
- Fixed the subscription_payment_required function-based view decorator.
- Removed unnecessary django-crispy-forms
- Middleware excepts all of the djstripe namespaced URLs. This way people can pay.
- Fixed a couple template paths
- Fixed the manifest so we include html, images.
- Fixed the manifest so we include html, css, js, images.
- Change PaymentRequiredMixin to SubscriptionPaymentRequiredMixin
- Add subscription_payment_required function-based view decorator
- Added SubscriptionPaymentRedirectMiddleware
- Much nicer accounts view display
- Much improved subscription form display
- Payment plans can have decimals
- Payment plans can have custom images
- Added account view
- Added Customer.get_or_create method
- Added djstripe_sync_customers management command
- sync file for all code that keeps things in sync with stripe
- Use client-side JavaScript to get history data asynchronously
- More user friendly action views
- Admin working
- Better publish statement
- Fix dependencies
- Ported internals from django-stripe-payments
- Began writing the views
- Travis-CI
- All tests passing on Python 2.7 and 3.3
- All tests passing on Django 1.4 and 1.5
- Began model cleanup
- Better form
- Provide better response from management commands
- First release on PyPI.