Paid Memberships Pro – Mailchimp Add On

Description

Subscribe WordPress users and members to your Mailchimp audiences.

This plugin offers extended functionality for membership websites using the Paid Memberships Pro plugin available for free in the WordPress plugin repository.

With Paid Memberships Pro installed, you can specify unique audiences for each membership level, as well as opt-in audiences that a member can join as part of checkout or by editing their user profile. By default, the integration will merge the user’s email address and membership level information. You can send additional user profile details to Mailchimp using the method described here.

The settings page allows the site admin to specify which audience lists to assign users and members to plus additional features you may wish to adjust. The first step is to connect your website to Mailchimp using your account’s API Key. Here’s how to find the API key in Mailchimp:

Additional Settings

  • Non-member Audiences: These are the audiences that users will be added to if they do not have a membership level. They will also be removed from these audiences when they gain a membership level (assuming the audiences are not also set in the “Membership Levels and Audiences” option for their new level).
  • Opt-in Audiences: These are the audiences that users will have the option to subscribe to during the PMPro checkout process. Users are later able to update their choice from their profile. Audiences set as Opt-in Audiences should not also be set as a Non-member Audience nor a Level Audience.
  • Require Double Opt-in?: If set to “Yes (All audiences)”, users will be set to “Pending” status in Mailchimp when they are added to an audience instead of being subscribed right away. They will then receive an email from Mailchimp to opt-in to the audience.
  • Unsubscribe on Level Change?: If set to “No”, users will not be automatically unsubscribed from any audiences when they lose a membership level. If set to “Yes (Only old level audiences.)”, users will be unsubscribed from any level audiences they are subscribed to when they lose that level, assuming that audience is not a Non-Member audience as well. If set to “Yes (Old level and opt-in audiences.)”, users will also be unsubscribed from opt-in audiences when they lose their membership level (though they can re-subscribe by updating the setting on their profile).
  • Update on Profile Save: If set to “Yes”, PMPro will update Mailchimp audiences whenever a user’s profile page is saved. If set to “No”, PMPro will only update Mailchimp when a user’s membership level is changed, email is changed, or chosen opt-in audiences are changed.
  • Log API Calls?: If set to “Yes”, API calls to Mailchimp will be logged in the /pmpro-mailchimp/logs folder.
  • Membership Levels and Audiences: These are the audiences that users will automatically be subscribed to when they receive a membership level.

Screenshots

  • General Settings for plugin, including the non-member audiences opt-in rules, and unsubscribe rules.
  • Specific settings for Membership Levels and Audiences.

Installation

This plugin works with and without Paid Memberships Pro installed.

Download, Install and Activate!

  1. Upload the pmpro-mailchimp directory to the /wp-content/plugins/ directory of your site.
  2. Activate the plugin through the ‘Plugins’ menu in WordPress.
  3. Navigate to Settings > PMPro Mailchimp to proceed with setup.

Configuration and Settings

Enter your Mailchimp API Key: Your Mailchimp API key can be found within your Mailchimp account under Account > Extras > API keys. If you don’t have a Mailchimp account, you can create one here. Read our documentation for a video demonstrating how to locate your Mailchimp API key.

After entering your API Key, continue with the setup by assigning User or Member Audiences and reviewing the additional settings.

For full documentation on all settings, please visit the Mailchimp Integration Add On documentation page at Paid Memberships Pro.

Several action and filter hooks are available for developers that need to customize specific aspects of the integration. Please explore the plugin’s action and filter hooks here.

FAQ-e

I found a bug in the plugin.

Please post it in the issues section of GitHub and we’ll fix it as soon as we can. Thanks for helping. https://github.com/strangerstudios/pmpro-mailchimp/issues

I need help installing, configuring, or customizing the plugin.

Please visit our support site at https://www.paidmembershipspro.com for more documentation and our support forums.

Reviews

11 June 2024 1 reply
It works but with limitations. My main complaint is that it doesn’t support Mailchimp Tags or Groups for segmentation and only supports Audiences. Since segmentation through audiences is more costly in Mailchimp. If you have an audience per membership level it is a really great fit though. That said it does a decent job of adding users to the Audiences with a few options like optional opt in, automatic add to audience, double opt-in, and optional removal from audience on membership expiration or level change. Separately, I had a couple bugs with the addon where we saw a user added again to the audience after a simple login rather than registration or renewal. It only happened a couple of times and was not repeatable enough to figure out.
03 March 2024 1 reply
So far so good, didn’t find any issues at all. It seems that works perfectly fine.
31 January 2024 1 reply
This plugins is pretty nice and efficient ! worth it ! With many extensions or tips and tricks in the blog, snippets etc.. easy to set for non-developers. highly recommended
16 December 2023
I wanted to migrate my Patreon following onto my own website for various reasons. So I’m running the free version, and hope to upgrade to the paid version once I build a large enough membership to cover the cost. The leap from free to paid is pretty huge (the equivalent of multiplying my membership by 3x and my income by 25%), which creates a big barrier to upgrading. I spend so many hours managing workarounds for the limitations such as clunky front-end pages and a lack of multiple memberships that could be better spent marketing and building up my membership – but other than multiple memberships, the paid version doesn’t address any of the issues I have with the plugin, nor would it save me time. Despite having many new features on my website that Patreon couldn’t manage, I now realize that if I had stayed with Patreon’s registration and checkout process, my income would have keep growing, but it’s only dropped off since I switched to PMPro. Pros: After a year, this is working well enough, and I’ve only gotten into a few hiccups which were reasonably easy to help my members through. It’s free, which is great when you’re just starting out. Integrates with mailchimp (although not entirely – new members get added to MC, but cancelled members don’t get removed). Cons: After getting two fraudulent registrations and a charge-back, I’ve tried many times to set up google authentication and it doesn’t seem to work. Ended up having to make my checkout process overly-complicated (asking custom questions, requiring users enter full addresses and other unnecessary info) at checkout to avoid bots and scammers. This creates friction at checkout, and has cost me new memberships. I have two sites I plan to merge together one day. Only after setting up PMPro on both of my sites and running it for 6 months did I realize the ‘multiple-memberships add-on’ only works with the paid version. That’s fine, but the documentation was unclear a year ago (it’s since been updated). The lack of multiple membership levels means I have to spend a few hours every couple months reconfiguring things from the back end to allow some of my members to upgrade their membership. I wish I could use this time recruiting for new members instead, which would get me faster to being able to afford the paid version. Editing the front-end checkout pages is impossible. Maybe it’s my theme (Soledad, using Elementor) but there are some pages (such as the ‘this content is locked’ page) that I simply can’t figure out how to edit. This makes my membership pages look like trash, reflecting poorly on my content – and doesn’t inspire confidence in potential new members. I’m fairly certain this is a large reason why I can’t convert unpaid members into paid members from these pages. Does not integrate with substack. Good to know: Intimidatingly complicated back-end, and I needed someone who already uses it to walk me through the setup. (I have 25 years experience in web design, a bachelors in graphic design, and a couple years of software engineering undergrad, so I’m not completely new to this). If I hadn’t been short on time, I would have probably chosen a different plugin, but this was recommended to me by a friend and I had to settle.
15 October 2023 1 reply
No issues, running in a background without any further care – that’s what we need 😉
Read all 17 reviews

Contributors & Developers

“Paid Memberships Pro – Mailchimp Add On” is open source software. The following people have contributed to this plugin.

Contributors

“Paid Memberships Pro – Mailchimp Add On” has been translated into 2 locales. Thank you to the translators for their contributions.

Translate “Paid Memberships Pro – Mailchimp Add On” into your language.

Interested in development?

Browse the code, check out the SVN repository, or subscribe to the development log by RSS.

Changelog

2.3.6 – 2024-03-27

  • SECURITY: Now preparing SQL statements.
  • SECURITY: Improved escaping of strings.
  • ENHANCEMENT: Added translator comments for placeholders.

2.3.5 – 2024-03-08

  • SECURITY: Now adding a randomized suffix to the log file name to prevent unauthorized access. #138 (@dparker1005)
  • SECURITY: Now preventing access to the /log/ directory listing. #138 (@dparker1005)
  • ENHANCEMENT: Added a filter pmpromc_update_audience_members_data to allow modifying data sent to the /lists/{$audience} Mailchimp endpoint. #137 (@efc)

2.3.4 – 2023-11-15

  • SECURITY: Now obfuscating email domains in debug logs. #135 (@andrewlimaza)
  • ENHANCEMENT: Updating <h3> tags to <h2> tags for better accessibility. #133 (@kimwhite)
  • REFACTOR: No longer pulling the checkout level from the $_REQUEST variable. #132 (@dparker1005)

2.3.3 – 2023-03-01

  • ENHANCEMENT: Improved formatting of opt-in audience section on checkout page. (@mircobabini)
  • ENHANCEMENT: Added filter pmpromc_log_path to allow changing the path where API calls are logged. (@JarrydLong)
  • BUG FIX/ENHANCEMENT: Now using readfile() during CSV export if fpassthru() is not available. (@JarrydLong)
  • REFACTOR: Marking the set_user_interest() method as deprecated. (@dparker1005)

2.3.2 – 2021-03-02

  • ENHANCEMENT: Added setting to log API calls sent to Mailchimp in the pmpro-mailchimp/logs folder.
  • ENHANCEMENT: Added a pmpromc_user_data filter to filter user data taht is sent to Mailchimp.
  • ENHANCEMENT: Audience checkboxes are now shown as scrollable list on settings page if there are more than 5.
  • BUG FIX/ENHANCEMENT: Added CSS class for checkbox labels.
  • BUG FIX/ENHANCEMENT: Now passing a valid user object when generating CSV export file headers.
  • BUG FIX: Fixed undefined variable in pmpromc_user_register() (Thanks, x140l31 on GitHub).
  • BUG FIX: Fixed required parameter being included after optional parameters in add_merge_field().
  • BUG FIX: Fixed URL to PMPro support page (Thanks, majerus1223 on GitHub).

2.3.1 – 2020-04-28

  • ENHANCEMENT: Added support for Paid Memberships Pro v2.3+ front-end profile edit page.
  • ENHANCEMENT: Now using checkboxes to select audiences instead of fields

2.3 – 2020-03-25

  • FEATURE: Subscriptions/unsubscriptions in Mailchimp now carry over to PMPro for opt-in audiences
  • ENHANCEMENT: Added setting to update contact in Mailchimp whenever profile is saved
  • ENHANCEMENT: Included audience names in debug logs and improved error reporting
  • BUG FIX: Fixed issue where contacts may be created in an unsubscribed status in opt-in audiences they had not subscribed to
  • BUG FIX: Fixed issue where contacts would not be removed from non-member audiences when they are given a level
  • BUG FIX: Fixed strings using the incorrect text domain
  • BUG FIX: Fixed ampersands in names being encoded when sent to Mailchimp
  • BUG FIX: Resolved PHP warning in API function in_merge_fields()
  • BUG FIX/ENHANCEMENT: Contacts in Mailchimp are now updated when a user’s email is changed instead of being replaced
  • REFACTOR: Organized code into different files

2.2.1 – 2019-12-31

  • BUG FIX: Fixed merge fields not being sent during user profile updates
  • BUG FIX: Fixed logging for Mailchimp API calls
  • BUG FIX: Fixed Mailchimp updates not being sent during wp_redirect filter

2.2 – 2019-12-19

  • BUG FIX: Fixed email address updates via profile.
  • BUG FIX: Fixed “Invalid API Key” error that would sometimes occur with newer API keys.
  • ENHANCEMENT: Using “Audience” instead of “List” in strings throughout the plugin for consistency with Mailchimp’s name changes.
  • ENHANCEMENT: Using “Mailchimp” instead of “MailChimp” in strings throughout the plugin for consistency with Mailchimp’s name changes.
  • ENHANCEMENT: Removed default columns besides email from Mailchimp CSV export. Now using the pmpro_mailchimp_listsubscribe_fields filter instead.
  • ENHANCEMENT: Users are now unsubscribed from all opt-in audiences when they cancel membership.
  • BUG FIX/ENHANCEMENT: Mailchimp subscriber updates are processed using the /lists/ API endpoint to prevent rate limiting by Mailchimp. This fixes issues that would sometime occur when many members were expired on the same day.
  • BUG FIX/ENHANCEMENT: Users who cancel are now unsubscibed from audiences instead of being deleted from Mailchimp.
  • BUG FIX/ENHANCEMENT: Now using the Mailchimp member “status” property when unsubscribing members instead of deleting them.

2.1.2

  • BUG FIX: Checking for 204 status when unsubscribing. We were checking for 200 before and throwing an error incorrectly.
  • BUG FIX: Fixed bug where users weren’t unsubscribed from MailChimp when they expired. A further refactoring is needed to avoid hitting the MailChimp API limit if many users are processed at once.
  • BUG FIX/ENHANCEMENT: The “All Users” label was changed to “Non-member Users” to match how the setting is actually used.

2.1.1

  • BUG FIX: Fixed issues with error handling and the display of error messages. Specifically, entering an incorrect API key will no longer crash the settings page. (Thanks, Hugh Brock)

2.1

  • BUG: Fixed a variety of bugs related to the MailChimp API, including a bug introduced in v2.0.3 that sometimes kept the plugin from subscribing users to lists.
  • BUG/ENHANCEMENT: Doing a better job of limiting the number of API requests made to avoid API limits.
  • ENHANCEMENT: Supports the pmpro-multiple-memberships-per-user Add On.
  • ENHANCEMENT: Added localization support. (Now should be able to create language files via GlotPress)

2.0.3

  • BUG: Fixed issue with updating email addresses in MailChimp when email addresses are updated in WordPress.
  • ENHANCEMENT: Added a filter pmpromc_profile_update that you can set to __return_true to tell the addon to synchronize user data on every profile update. By default, PMPro MailChimp will only synchronize data if the email address has changed. Filter passes $update_user, $user_id, and $old_user_data and is documented in the code.

2.0.2

  • BUG: Fixed issue where the wrong subscriber id was being used for subsequent API calls when calls were made for more than one subscriber (e.g. when importing, bulk updating, or members are expiring).
  • BUG: Fixed other warnings, typos, and minor bugs.
  • ENHANCEMENT: Added filter (pmpro_addon_mc_api_timeout) to modify API connection timeout (default is 10 seconds which should be plenty!)

2.0.1

  • BUG: Fixed bug where “additional opt-in lists” were causing fatal errors at checkout if set.

2.0.0

  • FIX/ENHANCEMENT: Removed the v2 MailChimp API class and now using our own API class based on MailChimps v3 API.
  • FEATURE: Now adding PMPLEVEL and PMPLEVELID merge fields for users added to lists. These can be used to create segments and groups in MailChimp.
  • FEATURE: Added a link on the settings page to export a CSV file formatted specifically for importing into MailChimp. This can be used to import existing members into MailChimp as new subscribers or just to update the merge fields for existing subscribers.

1.2

  • Updated the MailChimp API used to have a $verify_ssl property that controls the CURLOPT_SSL_VERIFYPEER option of the CURL connection. This is set to false by default, avoiding some issues people have had connecting to the MailChimp API.

1.1

  • Added option for passing membership level to MailChimp as a custom field.

1.0.7

  • ENHANCEMENT: Mailing Lists section of edit profile page doesn’t show up if there are no lists set for “opt-in lists”.
  • BUG: Not showing the “additional lists” options on the review page when using PayPal Express/Standard/etc. (Thanks, Christopher Souser)
  • BUG: Fixed some warnings.

1.0.6

  • BUG: Avoiding warnings when unsubscribing. (Thanks, Adam Shaw)

1.0.5

  • ENHANCEMENT: Won’t try to subscribe/unsubscribe if the user doesn’t have an email address. Doesn’t come up often in WP, but can.
  • BUG: Fixed bug where if users unchecked all optional lists options, the plugin would not remove them from the lists. (Thanks, Darlene)

1.0.4

  • BUG: Avoiding warnings in some cases where levels have been deleted.

1.0.3

  • BUG: Removed add_settings_error call to avoid fatal error on front end. Wasn’t using it.

1.0.2

  • BUG: Better error handling when invalid API keys are entered.

1.0.1

  • BUG: Fixed some warnings and fatal errors if site is run with an empty or invalid API key.

1.0

  • Admitting that we’re officially released with a 1.0 version. 🙂
  • Now using Mailchimp v2.0 API.

.3.6.2

  • Updated code to make sure that when checking out, sub adds run on pmpro_after_checkout instead of pmpro_after_change_membership_level.

.3.6.1

  • Fixed some warnings that would show up if the plugin was not connected to the API yet.

.3.6

  • Now 3 options for the “Unsubscribe on Level Change” option. No, Yes (Only old level lists.), and Yes (All other lists.).
  • Fixed possibly issues introduced in the .3.5 version.

.3.5

  • Added the “Opt-in Lists” that will show up on the PMPro checkout page as checkboxes allowing the member to opt into one or more lists.
  • Instead of unsubscribing users from all lists when changing membership levels (before adding them back to lists for the new membership level), we only unsubscribe users from the lists that were selected for their old level. For example, if list #1 is given to a user for level 1, users changing away from level 1 will only be unsubscribed from list #1. They will remain on any other list they might have gotten outside of PMPro MailChimp.

.3.4

  • Fixing SQL warning when running PMPro Mailchimp without PMPro. (Thanks, kateM82)

.3.3

  • Added option to turn of unsubscribes entirely. If you manage multiple lists in MailChimp and have users subscribe outside of WordPress, you may want to choose No so contacts aren’t unsubscribed from other lists when they register on your site.

.3.2

  • Updated pmpro_mailchimp_listsubscribe_fields filter to pass the $list_user object along as well.

.3.1

  • Updating email addresses in MailChimp lists if a user’s email address is changed.

.3

  • Added pmpro_mailchimp_listsubscribe_fields filters to add fields passed the listSubscribe API call.
  • Changed some things to make sure that the user cache is clean and the listSubscribe call happens late enough so that first and last name are populated.

.2.2

  • First logged release with a readme.
  • Added a “Require Double Opt-in” setting that will determine if an additional opt in email is sent for confirmation before adding users to a list. Defaults to “No”.