Steward recurring donors like never before while centralizing accounting and reporting and reducing overall costs. We've made it possible to transfer recurring transactions from your current Stripe processor to Givebutter. 👌
For general information, please refer to the migration process in Stripe's partial-migration help article. You will want to ensure your donors' payment details are active and up to date for a seamless migration. We also recommend emailing your recurring donors to let them know you are moving donor platforms so they are expecting the charge from Givebutter moving forward.
If you're migrating recurring donors from Stripe or a platform that doesn’t give you direct access to your Stripe account (Bloomerang, Classy, etc.), you will need to reach out to your platform's support to start the process. You can use the template below to see if they are able to retrieve/upload this data on your behalf in Stripe:
"We are moving our recurring donors from [platform] to Givebutter. We will need assistance with this process, as our donors’ payment tokens are not directly accessible to us. Could you please complete Steps 2 & 3 in this guide, and let me know the associated Stripe account number these tokens are coming from?
I will contact Givebutter to inform them that the donors' information has been sent over when those steps are complete."
Before you begin 📝
We advise emailing your recurring donors to let them know you are moving their donation. This will provide clarity for your donors on their billing and how they can update their plan.
Please feel free to utilize the email template below:
Dear [Contact First Name],
Thank you for your ongoing support to [organization]. Because of you, we are able to continue [impact statement].
To provide a more modern and donor-friendly giving experience, we are switching our online donation platform to Givebutter. Givebutter is free for our organization to use, helping your donation go further! Because of this, you will see 'GB*{Organization Name}' on your bank or card statement for all future donations. If you would like to update your recurring gift, you can do so anytime from your emailed receipt.
We are very excited about the future of [organization] and thrilled that you are part of our journey.
If you have any questions, please do not hesitate to contact us. We’re here for you!
Warmly,
[Signature]
Step 1: Connect a payout method to Givebutter
If you haven't already, follow the directions in our help article about connecting a payment method.
Step 2: Download Stripe Customer IDs
- Login in to the Stripe account that is associated with the donor platform you are migrating from and navigate to the Customers page. 
- Filter the data to show the recurring donors that you want to migrate to Givebutter. Starting with the Repeat Customers tab is a great way to begin isolating your recurring donors. 
- Click Export on the right-hand side. 
- In the Columns field, select Custom. Make sure that only the ID option is selected as one of the fields for export so that the data exports as a single column. 
- Export the selection as a CSV. 
- Your data should only have 1 column and all values should start with "cus_". If you included a title header (i.e. Customer IDs) it will throw an error. 
Step 3: Upload and share your data
- Within that same Stripe account, navigate to the Customers page again. 
- Click Copy customers. 
- In the Copy Method field, click Upload from file. 
- Select the CSV file of customer IDs from their computer. 
- After selecting the correct file, click Continue. To handle errors, refer to Handle upload errors. 
- Enter the account ID (format: acct_xxxx) of our recipient account below. You will receive a message stating that the recipient needs to authorize your request before the copy occurs. - Givebutter's account ID is acct_17qVRFEBuKNYj3GG 
- Click Confirm. 
- After successfully sharing your data, you will see the pending copy request at the top of the Customers page. 
- Next, submit your intake form and our migration team will be notified that you have a pending request. We will respond within 24-72 hours and follow up with the information needed for the remaining steps. 
Step 4: Givebutter accepts your data
Once we authorize and accept your data, the copy process will start. Most data copies finish within 72 hours, but short lists may be completed even faster!
When the copy is complete, the sender and recipient can see the completed copy banner at the top of the Customers page of their Stripe dashboard. After the copy is complete, we will email you some new data that you will need to use in Step 5.
Step 5: Prepare your import spreadsheet
Givebutter needs some basic information about your recurring transactions. This allows us to recreate those records in Givebutter. The data needs to be formatted and uploaded to your Givebutter Dashboard.
You will likely be using three different files to compile all of the necessary information that our system needs:
- The Stripe file our implementation team provides you. This contains the Stripe customer and source ids. 
- A Stripe customer export that contains at least the customer id, name, and description columns. This will help you identify which ID belongs to which of your donors. If you do not have direct access to your Stripe account, your old donor system should be able to retrieve this for you. 
- A recurring donor export from your old donor management system. This will allow you to know the details of each donors’ plan (how often they gave, how much they gave, when they gave, etc.) 
The example template below gives you an idea of how all three of these files contain the information needed for import.
Required fields (in any order):
- First Name: The donor's first name 
- Last Name: The donor's last name 
- Email Address: The primary email of the donor 
- Amount: Only numbers, no currency symbols. 
This is just the donation amount. The donor will not be asked to tip Givebutter or cover the processing fee. When you migrate recurring donors, their donation assumes that you, the org, are covering the processing fee of 2.9% + .30 cents. If you have any donors who are covering this fee for you, you will want to make sure their amount in the template includes the fee as well. We have a fee formula available if you need to add this for any donors.
- Frequency: Available options are Monthly, Quarterly, and Yearly. 
- Last Bill Date: Format is YYYY-MM-DD 
- Givebutter Campaign Code: The Campaign code of the Campaign recurring donors will be migrated into. This can be found by clicking on All Campaigns in the left-hand menu bar. 
- Stripe Customer ID: Stripe metadata (always begins with "cus_") - customer_id_old and customer_id_new are exactly the same 
 
- Stripe Source ID: Stripe metadata, this column is called "source_id_new" in the spreadsheet that Givebutter emails you after the initial copy is completed. 
- Address Line 1 
- City 
- State 
- Zip Code 
- Country Code: Three symbol country codes only. 
Optional Fields (in any order):
- Phone Number 
- Address line 2 
- Fund Code 
We recommend copying the template in Google Sheets (or downloading it if you prefer working in Excel) and then matching your data to the corresponding columns on the template.
Step 6: Upload your import spreadsheet
- Navigate to Transactions, and then Recurring Plans in your Givebutter Dashboard. 
- Click the Import button, then select Recurring plans import and choose the import file from your device. 
- Click Upload file (we do not recommend manually entering data for recurring donation imports.) 
- Review the data mapping. When you're finished, toggle through some of the records to spot-check for completeness and click Continue. 
- You will receive an email confirmation from Givebutter. If that status is failed, follow the directions provided in our email to reconcile any errors. 
Step 7: Validate the Recurring Plans
Once you receive the email confirmation from Givebutter that your import is complete, navigate to Settings and then click Imports under the Settings header.
Click the Recurring Plans tab and choose Validate Plans.
Shortly after clicking Validate Plans, you will receive an email confirmation from Givebutter. Each Recurring Donation is validated individually. Follow the directions provided in our email to reconcile any errors.
Step 8: Activate the Recurring Plans
Now it’s time to cancel or disable your recurring gifts while suppressing any "your monthly donation has been canceled" emails on your legacy platform, if you can.
🚨 Your recurring plans will not automatically be cancelled once they have been imported into Givebutter! It is your responsibility to ensure no one is double-charged.
Once you've completed that step, return to the Imports tab in your Givebutter dashboard. Click the three dots next to each plan and select Activate Plan.
Admins can also edit the plan amount and the next bill date by selecting the (...) menu next to any imported plan before you activate it.
You're all set! 🎉 These recurring donations will begin processing in Givebutter.
Good to know 🌟
While our best-in-class support team is available to guide your way, data migrations can be a challenging and time-consuming process if not well-organized. The state of your data will determine your migration experience.
Givebutter is not able to analyze, structure, or organize your data for you. You are the leader of your migration and will need to cancel your plans on your old platform.
Timing is important. You'll need to coordinate canceling your existing subscriptions and the import to ensure no payments are missed or duplicated.
Platforms you can migrate recurring plans from 💻
Stripe-compatible platforms ✅
You can migrate your recurring donors if your existing platform accepts recurring donations through a Stripe account. While Givebutter's involvement in this process is free, some platforms charge a fee to export and copy your donors' tokens from their Stripe account, or to migrate your recurring donor tokens from their current process to Stripe.
Whether or not your donor management software is listed below, we encourage you to confirm with your platform if it charges a fee for this service to avoid surprises.
View a list of platforms you can migrate from (Stripe-compatible)
View a list of platforms you can migrate from (Stripe-compatible)
- Bloomerang - charges a $250 migration fee (as of 5/30/25) 
- Causevox 
- Donorbox 
- DonorView 
- Fundraise Up 
- Give Lively 
- GiveWP 
- Harness Giving 
- Kindful 
- Little Green Light 
- Memberful 
- Planning Center 
- RaiseDonors 
- Raisely 
- Virtuous 
- Classy - charges a $3,000 migration fee (as of 5/30/25) 
You can see which other non-profit platforms partner with Stripe directly here. If your platform is not on this list, we recommend contacting its support team to confirm that your recurring payments are not billed through Stripe!
Platforms not using Stripe ↪️
If Stripe doesn't power your current platform/payment processor, it's still possible to migrate. Please see our guide to migrating recurring plans from a non-Stripe payment processor →
View a list of platforms that don't use Stripe
View a list of platforms that don't use Stripe
- Neon Pay - charges a $450 migration fee (as of 5/30/25) 
- Funraise - charges a $3,000 migration fee (as of 5/30/25) 
- DonorPerfect - charges a $1,000 migration fee (as of 5/30/25) 
Platforms that won't release data ⚔️
What if your donor management software will not release your data? We encourage you to ask your current donor management software why this isn’t possible and if there are any alternatives or exceptions they can make to release this data.
View a list of platforms that haven't released recurring plan data in the past
View a list of platforms that haven't released recurring plan data in the past
- Flipcause 
- Tithely 
- Aplos 
- ActBlue 
- Bonterra Payments (Network For Good, EveryAction) 
- PushPay 
FAQ 🤔
What payment methods can be migrated over?
The supported payment methods Stripe can migrate between accounts include:
- Cards stored as Card objects 
- Cards stored as Source objects 
- Cards stored as Payment method objects 
- US ACH records stored as Bank account objects 
Stripe can’t copy Single Euro Payments Area (SEPA), BACs, or ACH records stored as payment method objects at this time. Link by Stripe is not a supported payment method for migrations. You can read more about this here.
The file we received from your implementation team has multiple source_ids for the same customer, which should I use?
If the file you receive from our team has multiple source_ids for the same customer, this usually means that the customer had multiple payment methods or profiles in your old Stripe account. We advise using the most recent source_id, which will be the one closer to the bottom of the file we provide you from Stripe.
My plans failed validation, why?
Typically, this happens due to adding in the wrong source_id to your import template file. Make sure you use the ids reflected in the new column. The validation will also fail if the payment method was Link by Stripe, as this isn't a supported payment method.
To fix this, you will need to delete the plans you have imported and redo the import with the correct new source_ids.
I can no longer modify my plans in Givebutter, what happened?
This means you have already activated your plans. Once this is done, the plans cannot be modified within your Givebutter dashboard anymore.
If you need to modify a plan after activating it, you can cancel it in your dashboard and then re-import it with the correct details.
My plans have started charging through Givebutter but some have failed, what do I do?
Try not to panic if some plans fail initially. This is likely due to card changes since your donors were last charged, or their bank flagging it as an unrecognized charge since the merchant is now Givebutter.
Your donors will be notified by email that their charge failed. A link to update those billing details is included for them as well.
Need support while migrating your recurring donations?
If you have any questions about migrating your recurring donations to Givebutter or difficulties with your legacy platform or processor, reach out to our Migrations team by emailing [email protected] and an actual person on our team will get back to you in 2-3 business days.







