Team
Launch LogCancel Flows
Quick Start GuideFurther ConfigurationCustom StylingMulti-Language SupportEmail-Verified Cancel FlowA/B TestingCancel Flow TestingPause WallFailed Payment Recovery
Payment RecoveryCampaign CustomizationFailed Payment WallReactivations
ReactivationsCampaign Customization GuideCustomer Health
Customer HealthData Integrations
Data APIWebhooksEvent TrackingBilling Providers
Payment Provider OverviewSlackStripeChargebeePaddle ClassicPaddle BillingBraintreeZuoraSupport
FAQsFrequently Asked Questions
Can I use Churnkey with Stripe Portal?
One of the most common use cases of Churnkey is right along side Stripe Portal. While we cannot integrate directly into Stripe Portal, we can live next to each other under a “Manage Subscription” button to redirect to Stripe Portal, and a “Cancel Subscription” button for launching the Churnkey cancel flow.
When using Churnkey’s cancel flows alongside Stripe Portal, you should disable cancellation from the Stripe Portal. This can be done on the Stripe Portal settings page as shown below
How should I set up my Stripe settings to work well with Churnkey Precision Retries?
Churnkey’s Precision Retries are designed to occur within a 30 day window after a failed payment. They will automatically stop if a payment is recovered, or if the underlying invoice is marked void or uncollectible. Below are the recommended Stripe settings for use with Churnkey Precision Retries. Importantly, Churnkey will not automatically change the subscription status to uncollectible or unpaid. If you are relying on Stripe to do this for tax or other purposes, please consult with your technical team for making sure these continue to work as expected. For most companies, the best way to achieve this is to leave on Stripe’s Smart Retries 4x within 1 month, and then marking the invoice and subscription status as desired.
What are some best practices for setting up cancel flows?
Check out our guide for best practices for customer retention.
What kind of retention numbers can I expect to see?
We’ve seen retention boosts from 10% all the way up to 42%. Some of the most important factors are price point, B2C vs B2B, percentage of customers on annual plans, and your current churn rate. We’d be happy to hop on a call and give you an estimate of what improvement you’re likely to see based on our in-house dataset.
How does pause work for annual customers?
Pause offers won't be shown to your annual customers because of how billing providers handle this. Essentially, if an annual customer pauses their subscription for 2 months, billing providers (Stripe, Chargebee, Braintree) will stop collecting invoices for 2 months. If the customer's renewal date falls within that 2 month timeframe, they'll essentially get the entire next year for free. If it does not fall within that timeframe, the pause will have no effect. What we've seen work really well for annual customers is creating a lower percentage 12-month coupon (10 or 20%) and then tailoring the copy on the discount offer step to highlight that this is on top of the already discounted annual plan.
Why are my coupons and plans from my payment provider not showing up?
You will have to connect your live mode credentials for coupons and plans from Stripe, Chargebee, Paddle, and Braintree for them to show in the cancel flow builder on Churnkey. You can connect you live mode credentials at Churnkey | Settings | Billing Provider.
How can I check if a Stripe subscription is paused?
You can detect a pause on the Stripe subscription object. We use Stripe's recommended "Pause Collection" method for handling pause, so the subscription will be updated with the following property (with an appropriate resumes_at
date).
{
pause_collection: {
behavior: "mark_uncollectible",
resumes_at: 1673536945
}
}
What if I need to use custom billing logic?
By default, Churnkey takes care of billing updates for you; this includes subscription pauses, discounts, plan changes, and cancellations. If you’d like to implement custom billing logic, you can use handler callbacks.
Handler callbacks are intended for when you want to handle changes to a customer's subscription instead of having Churnkey do it on your behalf. If a handler callback for a customer event is defined, Churnkey will not take action on your behalf when this event occurs.
Most handler type callbacks (with the exception of handleSupportRequest
) are JavaScript Promise objects. Calling resolve
will advance Churnkey's flow to a success state. Optionally, you can pass a message which will be shown to the customer. Calling reject
will advance Churnkey's to an error state. Again, you can optionally pass a message to show the customer.
{
handlePause: <Promise>,
handleCancel: <Promise>,
handleDiscount: <Promise>,
handleTrialExtension: <Promise>,
handleSupportRequest: <function>
handlePlanChange: <Promise<(customer, { plan })>,
}
In addition to handler callbacks, we also provide listener callbacks. More details on those here →
Can I make the “Contact Us” button open an email to our support team?
Yes. You can achieve this by using the handleSupportRequest callback with something like the following, which will open up a new email to your email of choice and optionally a pre-filled email subject and body.
window.churnkey.init('show', {
appId: 'YOUR_APP_ID',
customerId: 'STRIPE_CUSTOMER_ID',
authHash: 'HMAC_HASH,
...
handleSupportRequest: (customer) => {
window.open(
`mailto:${customer.email}?subject=${emailSub}&body=${emailBody}`,
'_self'
);
},
})
Can I apply prorations when a customer accepts a plan change offer (upgrades and downgrades)?
By default, subscription plan changes will create proration adjustments (either charges or credits). You can optionally switch off proration charges under Cancel Flows | Settings.
How can I change the fallback behavior in case of error?
- Head to https://app.churnkey.co/flows/settings
- Update
genericErrorDescription
from its default “Please contact us” to a more specific message e.g. “Please contact us at [email protected]”
How can I delete test data?
From the Cancel Flow Dashboard, scroll to the Activity Overview and click on the customer whose data you would like to clear. This will take you to that customer’s timeline. On that page, you should see an overflow menu which can be accessed through the three dots in the top right. Under that menu is an option to delete customer data, which will clear the Churnkey cancel flow sessions associated with that customer.
What is a “bounced” session?
A cancel flow session will get marked as "bounced" if another more relevant session takes place within 24 hours of that initial session. For instance, if a customer pauses and then decides to cancel within 24 hours, that first session with the pause offer accepted will be marked as bounced. Bounced sessions are not included in dashboard analytics.
When can we expect dunning (failed payment recovery) for Chargebee?
Regarding failed payment recovery, Chargebee has a pretty good tool built-in, but we can offer some advice on how to better set up their default campaign.
We recommend you:
1. Send emails in the sequence from different sending addresses and sender names. Email clients like Gmail will thread emails if they're from the same address + it increases your chances of catching someone's eye with different names
2. Day 0, day 3, day 5, day 7, day 14 for sending emails performed the best during our experimentation.
For more details, we offer consultation services on how to best optimize retention campaigns based on our in-house dunning dataset.
Can I apply subscription pauses at the end of the billing cycle?
Unfortunately the Stripe API doesn't allow for scheduling pauses. Instead, we now have an option on this page where you can set "Pause wall to show at the end of the billing cycle" on Churnkey | Flows | Settings. This setting switched to end of term will do a few things:
- It will set the pause end date to be at the end of the billing term of the nth month after pause. For example, if someone pauses on May 15th and their billing period renews on the 30th, a 2-month pause will pause until July 30th instead of July 15th. Note that the pause will still be applied immediately, but the end date will be moved further until the end of that future billing cycle.
- Within the Stripe subscription metadata, there will be a
pauseWallStartDate
set tosubscription.current_period_end
when the customer pauses. We use this internally for the pause wall, but if you want to use it for your own purposes it will be there - The pause wall will only render after the current date is greater than
pauseWallStartDate
(and until the subscription is resumed at the end of the pause date).
How can I filter a segmented audience using the number of months since a custom attribute?
If you have the customFieldDate
handy, you can calculate a monthsSinceCustomDate
from that, and use this as that as an audience filter using with monthsSinceCustomDate
as a custom attribute of type number. When initializing Churnkey, pass monthsSinceCustomDate
as a customerAttribute
.
Churnkey cannot edit subscriptions created by another 3rd party Stripe connection
In some instances, you may be using another 3rd party other than Churnkey to create subscriptions - for instance, ProfitWell reactivations or Chargedesk. This is perfectly fine, but Stripe does have a permissions restriction that doesn’t allow third parties (i.e. Churnkey in this case) from updating subscriptions created by other third parties.
We put in place a 3 step fix for this (5 minutes) where we'll use a restricted API key instead of the Stripe connect OAuth permissions for those requests:
1. Go to Stripe Dashboard | API Keys
2. Create a new API key (call it something like “Churnkey”) and copy the secret key to clipboard
3. Add this API key to Churnkey on the Account | Billing Provider page. The option to add an API key is listed on the hamburger overflow menu in the top right corner If you would prefer to use a restricted key which is recommended, make sure to include the following permissions:
- Core | Customers | Write
- Billing | Subscriptions | Write
- Billing | Invoices | Write
- Billing | Coupons | Write
You can create a restricted API key here: https://dashboard.stripe.com/apikeys/create
How can I update the Churnkey Stripe App
On this page
- Frequently Asked Questions
- Can I use Churnkey with Stripe Portal?
- How should I set up my Stripe settings to work well with Churnkey Precision Retries?
- What are some best practices for setting up cancel flows?
- What kind of retention numbers can I expect to see?
- How does pause work for annual customers?
- Why are my coupons and plans from my payment provider not showing up?
- How can I check if a Stripe subscription is paused?
- What if I need to use custom billing logic?
- Can I make the “Contact Us” button open an email to our support team?
- Can I apply prorations when a customer accepts a plan change offer (upgrades and downgrades)?
- How can I change the fallback behavior in case of error?
- How can I delete test data?
- What is a “bounced” session?
- When can we expect dunning (failed payment recovery) for Chargebee?
- Can I apply subscription pauses at the end of the billing cycle?
- How can I filter a segmented audience using the number of months since a custom attribute?
- Churnkey cannot edit subscriptions created by another 3rd party Stripe connection
- How can I update the Churnkey Stripe App