Плагин подписок Discourse

:discourse: Краткое описание Плагин Discourse Subscriptions позволяет владельцам сайтов продавать подписки с периодической оплатой и разовые покупки, которые предоставляют доступ к группе на сайте Discourse.
:open_book: Руководство по установке Этот плагин входит в состав ядра Discourse. Отдельная установка плагина не требуется.

Плагин Discourse Subscriptions позволяет создавать разовые и периодические подписки, за которые пользователи могут платить для доступа к закрытому контенту. Это отличный способ покрыть расходы на хостинг вашего сообщества.

Возможности

Плагин Discourse Subscriptions поддерживает следующие функции:

Кнопка «Подписаться» в верхней панели навигации перенаправит вас на страницу подписки /s, где будут перечислены подписки, которые вы настроили для своего сайта:

Когда пользователь нажимает на кнопку «Подписаться» для конкретного тарифа, открывается страница оплаты для этого тарифа:

После того как пользователь заполнит данные для оплаты и адрес и нажмет «Подписаться», ему будет показано сообщение «Спасибо!» и он будет перенаправлен на свою страницу выставления счетов:

Пользователь также автоматически добавляется в выбранную вами группу, чтобы вы могли легко видеть, кто из пользователей подписался, а также предоставлять закрытый контент в категориях, доступных только для этой группы.

Условия

  • Подписка — Подписки представляют собой план периодических платежей, который позволяет вам контролировать доступ к контенту в вашем сообществе. При создании или удалении подписки пользователь добавляется или удаляется из группы пользователей, связанной с вашим тарифным планом. Подписка состоит из продукта и планов.
  • Продукт — В терминах Stripe продукт — это то, что вы продаете. Продукт может содержать один или несколько планов.
    • Чтобы добавить описание к вашему продукту, добавьте поле метаданных с именем «description» и используйте его. Вы можете использовать Markdown.
  • План — План содержит цену, периодичность платежей и связан с группой, к которой получают доступ ваши подписчики.

:police_car_light: Будьте очень осторожны и всегда храните свои закрытые ключи Stripe в безопасности.

:warning: Если вы выключите свой экземпляр Discourse, удалите этот плагин или ваш сайт станет недоступен, Stripe будет продолжать выставлять счета вашим клиентам за вашу услугу до тех пор, пока подписка не будет отменена.

Конфигурация

  1. Установите и включите плагин
  2. Настройте платежный шлюз (Stripe)
  3. Настройте Webhooks и события в Stripe
  4. Добавьте свои ключи Stripe (публичный, секретный, секрет webhooks) в разделе Администратор > Плагины > Установленные > Подписки > Настройки /admin/site_settings/category/discourse_subscriptions?filter=plugin%3Adiscourse-subscriptions.
  5. Создайте группу для подписчиков, которые присоединятся после покупки
  6. Создайте продукт и план в разделе Администратор > Плагины > Подписки
  7. Прибыль!

Настройте свой платежный шлюз.

Сначала вам понадобится аккаунт в платежном шлюзе Stripe. Чтобы начать, вы можете создать аккаунт в тестовом режиме и посмотреть, как все работает, не совершая реальных транзакций и не настраивая банковский счет. В плагине нет переключателя тестового режима; вместо этого обязательно используйте свои ключи разработчика (они начинаются с pk_test, sk_test)

Настройте Webhooks и события в вашем аккаунте Stripe

:bomb: Webhooks необходимы для полной работы отмены подписок. Убедитесь, что они настроены правильно.

После создания аккаунта в Stripe вам нужно сообщить Stripe адрес вашего сайта, чтобы он мог уведомлять вас о определенных транзакциях. Вы можете ввести это в панели управления Stripe в разделе Конечные точки > URL.

Адрес Webhooks: [адрес вашего сервера]/s/hooks — где [адрес вашего сервера] — это URL вашего сайта Discourse.

Вам также нужно сообщить Stripe, о каких событиях он должен уведомлять вас через URL webhooks.

В настоящее время Discourse Subscriptions реагирует на следующие события:

  • customer.subscription.deleted
  • customer.subscription.updated
  • checkout.session.completed

Добавьте ключи API и Webhooks Stripe в настройки вашего плагина

Stripe необходимо авторизовать для связи с вашим сайтом. Для этого он публикует пару закрытых и открытых ключей API и секрет подписи для ваших webhooks.

Для авторизации webhooks добавьте ключи API и секрет webhook из Stripe на страницу настроек (в разделе Разработчики).

:warning: Добавление ключей для продакшена приведет к реальным платежам. Если вы планируете тестирование, обязательно переключитесь в режим View test data и получите ключи pk_test и sk_test в разделе Разработчики.

В настройках вашего аккаунта Stripe см.:

Добавьте эти ключи в соответствующие настройки в разделе Администратор > Плагины > Установленные > Подписки > Настройки /admin/site_settings/category/discourse_subscriptions?filter=plugin%3Adiscourse-subscriptions.

Настройте группы пользователей в Discourse

Когда пользователь успешно подписывается на ваше приложение Discourse, после обработки транзакции с его кредитной картой он добавляется в Группу пользователей. Назначая пользователей в Группу пользователей, вы можете управлять тем, к чему ваши пользователи имеют доступ на вашем веб-сайте. Группы пользователей являются основной функцией Discourse, и этот плагин не делает с ними ничего, кроме добавления и удаления пользователей из группы, которую вы связали со своим Планом.

Создайте один или несколько продуктов с планами.

В разделе Администратор > Плагины > Подписки нажмите «Добавить новый продукт». После сохранения продукта вы можете добавить к нему планы. Имейте в виду, что цены и интервалы выставления счетов для планов нельзя изменить после их создания. Это сделано для избежания путаницы в управлении подписками.

Если вы заглянете в свою панель управления Stripe, вы увидите, что все эти продукты и планы перечислены. Discourse Subscriptions не создает их локально. Они создаются в Stripe.

Тестирование

Тестируйте с помощью этих номеров кредитных карт:

  • 4242 4242 4242 4242
  • 4111 1111 1111 1111 (аутентификация не требуется)
  • 4000 0027 6000 3184 (требуется аутентификация)

Для получения дополнительных тестовых номеров карт: Test card numbers | Stripe Documentation

Посетите /s и совершите несколько тестовых транзакций.

Переход в продакшен

Когда вы будете готовы перейти в продакшен, измените ключи API и секреты webhook на ключи для продакшена. Вам нужно будет создать новые продукты и планы в режиме реального времени.

Обратите внимание, что если вы неправильно настроите вебхуки Stripe и периодические платежи не будут обрабатываться по какой-либо причине (истекшая кредитная карта и т. д.), пользователи все равно будут иметь доступ к группе. Чтобы Stripe автоматически отменял подписки, обязательно настройте свои Управление неудачными платежами аналогично изображению ниже и настройте вебхуки, как описано выше.

Обновление платежной информации

Пользователи могут обновить карту, используемую для отдельных подписок, посетив страницу выставления счетов и нажав кнопку «Изменить» рядом с подпиской, что откроет этот экран:

Stripe Checkout с таблицами цен Stripe

Вы также можете отказаться от использования страниц продуктов и оформления заказа плагина Subscriptions и вместо этого использовать Stripe Checkout с Таблицами цен Stripe.

В вашей панели управления Stripe:

  1. После создания продуктов на Discourse перейдите в Продукты > Каталог продуктов
  2. Нажмите на продукт, который хотите включить в таблицу цен
  3. Нажмите Изменить продукт
  4. Дополнительные опции и введите следующее в разделе Метаданные:
    • Ключ: group_name
    • Значение: Имя группы в Discourse (например, trust_level_0)
  5. Нажмите Обновить продукт, чтобы сохранить

:red_exclamation_mark: Убедитесь, что имя группы совпадает с группой, выбранной в User_Groups в Discourse

Создайте таблицу цен Stripe

  1. Перейдите в Продукты > Таблицы цен
  2. Создайте новую таблицу и добавьте созданные вами продукты
  3. После публикации таблицы скопируйте идентификатор таблицы цен, найденный в коде встраивания (он начинается с prctbl_...)
  4. Вставьте идентификатор таблицы цен в ваш discourse_subscriptions_pricing_table_id и включите настройку таблицы цен подписок.
  5. Нажмите зеленые галочки, чтобы сохранить обе настройки.

Рекомендуемый шаг:

При настройке Таблицы цен внутри Stripe рекомендуется перенаправлять пользователя на ваш сайт после завершения оформления заказа, в противном случае они останутся на странице подтверждения Stripe без ссылки на ваш сайт.

Перенаправление на https://<your-site>/my/billing/subscriptions — хороший выбор для подписок. Для разовых платежей вы можете перенаправить напрямую на https://<your-site>/my/billing/payments.

Автоматический сбор налогов

Чтобы включить автоматический сбор налогов, установите флажок настройки сайта discourse_subscriptions_enable_automatic_tax.

Если вы включите его, но не настроите свой экземпляр Stripe для сбора налогов, пользователи могут увидеть это всплывающее окно после завершения процесса оформления заказа:

Существует это руководство для получения дополнительной информации, но, поскольку плагин теперь передает соответствующий параметр automatic_tax[enabled]=true (шаг 5), делать нужно не так много.

Обязательно настройте свои регистрации (шаг 4) также:

Вот пример транзакции плагина Discourse Subscription в Stripe, показывающий, что налог был собран автоматически:

Настройки

Имя Описание
discourse subscriptions enabled Включить плагин Discourse Subscriptions.
discourse subscriptions extra nav subscribe Показать кнопку подписки в основной навигации
discourse subscriptions public key Публичный ключ Stripe
discourse subscriptions secret key Секретный ключ Stripe
discourse subscriptions webhook secret Секрет webhook Stripe
discourse subscriptions currency Код валюты по умолчанию. Может быть переопределен при создании плана подписки.
discourse subscriptions campaign enabled Включает баннер кампании для продвижения финансовой поддержки этого сообщества.
discourse subscriptions campaign goal Числовая цель вашей кампании поддержки (количество подписчиков или собранная сумма).
discourse subscriptions campaign type Выбирает тип кампании (подписчики или ежемесячная собранная сумма).
discourse subscriptions campaign banner location Выбирает расположение баннера кампании (верхняя часть или боковая панель).
discourse subscriptions campaign banner bg image Загрузите пользовательское изображение для использования в качестве фона баннера кампании.
discourse subscriptions campaign banner shadow color Выберите цвет тени баннера кампании.
discourse subscriptions campaign show contributors Показать аватары последних покупателей продуктов подписки.
discourse subscriptions campaign product Идентификатор продукта Stripe для отправки сторонников при нажатии кнопки на кампании. Если эта настройка пуста, сторонники будут перенаправлены на главную страницу продуктов.
discourse subscriptions campaign grant Предоставляет пользователю бесплатный месяц подписок
discourse subscriptions pricing table id Идентификатор таблицы цен Stripe из кода встраивания
discourse subscriptions pricing table enabled Включает использование таблицы цен Stripe и заменяет существующую страницу подписки
discourse_subscriptions_enable_automatic_tax Включает сбор налога с продаж. Требует некоторой настройки в Stripe.
discourse_subscriptions_enable_verbose_logging Включает более подробное логирование для помощи в отладке. Пожалуйста, не оставляйте включенным постоянно в продакшене.

:discourse2: Хостится нами? Этот плагин доступен в наших планах хостинга Pro, Business и Enterprise Subscriptions | Discourse - Civilized Discussion

139 лайков
Steady plugin for community funding
ProCourse Memberships :money_with_wings:
Group membership subscriptions with profit split
Email drip campaign
How to give unpaid users limited access without making Discourse private?
Super simple Discourse-Wordpress-membership integration
Discourse for Membership Association Members?
Please suggest a good Discourse Plugin for Membership that supports Indian Payment Gateway
Allow users to donate to pay hosting fees for a site
Login required after some days of free access
User can't repurchase a subscription product after canceling
User Card Directory
Subscription Access To Discourse
Multiple paywalls with common communication hub
Discourse Subscriptions + btcpayserver
Do I need Wordpress? Or Discourse can be my solution to ALL?
Send an invite to a user but complete their profile programmatically
Discourse subscriptions - changing price during recurring subscription
Any good Memberpress alternatives for wordpress?
Add user to group after purchase
How to move Topics in Category into their own Pinned Topic inside new Categories?
Discourse vs Skool
Subscription Access To Discourse
Tax implication of funding a forum
Discourse Unlock
Tick badge for username?
Subscription update problem
Setting up a subscription group
How would I install a cryptocurrency paywall?
Charging a membership fee
Discourse Subscriptions with Thrive Cart
Admin creating subscription for user
Plugin for charity donations?
Allow subscription of predetermined length
Link Sign Up to Subscriptions Plugin
User monetization with group access?
Discourse Category Lockdown
Allow option to open Stripe payment website
Is it possible to use the subscription plugin to limit creating topics in a category to subscribers?
Best approach to a landing page/payment front end
Managing consumable AI costs
Allow multiple ‘new topic’ drafts
Stripe iframe causes a blank page on my print layout
No 'deleted' event in Stripe?
Tell us how you manage subscriptions on Discourse
Addding a paid group who can reply to topics but not create them
Integration with WP membership Pro
Alternative sign up pathways
Control Category Visibility and Access by User Levels
Tighter integration of account-creation and subscriptions?
Does the Subscriptions plugin work with "one-off" payment pricing tables?
Subscriber group automation (Remove and Add users to specific group with subscription)
"Support Us" Banner Not Updating
Tip or Pay Button - for user post/content, does it exist already?
May I or can I monetize my forum?
May I or can I monetize my forum?
Bundling more popular plugins with Discourse core
Guest Gate Theme Component
Error loading route Caused by plugin 'discourse-subscriptions'
Embed a list of Discourse topics onto an external site
Blank page when resuming discourse app
Why doesn't Discourse hosting include the Subscriptions plugin on the Starter plan?
Hosting questions
Discourse Category Lockdown
Rebuild fails when these plugins are present
Changing excerpt length
Installing discourse for free?
Options to manage payments for paid Discourse communities
Using a plug-in to monetize my Discourse
ProCourse Memberships :money_with_wings:
UX: Add metadata to subscription page to improve SEO and link UI design
A feature request related to this plugin. Pointed questions or rewarded questions
Plugin to use Discourse for classified ads or as a job board?
Subscription Plugin not working (Error)
How to set message limits for user groups?
API POST for New User
ProCourse Memberships :money_with_wings:
Steady plugin for community funding
New customer setup
Making group joins automatic to an external pricing plan
Platform integration - videos
Any way to accept paypal or stripe payment at signup?
Looking for feedback on Discourse Subscriptons
WooCommerce Discourse Website newbie help
Switching to Discourse Subscriptions from WordPress Subscriptions
Integration with Wix.com membership to only let the paid member can access to Discourse
2020: The Year in Review
Managing Subscriptions through Wordpress (Ultimate Member + Paid Memberships Pro)
How does uninstalling the Subscriptions plugin affect Stripe billing?
Memberful opinions?
Is there an E-commerce plugin for Discourse?
Memberful opinions?
Prefill custom html with user's email address?
Can't make the subscription plugin work
How to charge members for my Discourse website?
Pay or Play usage?
Latest topics on homepage with only members to read in detail?
Banner text customization for Subscriptions plugin
Subscriptions: Change User's Plan
Donation Bar for House Ad
Can I use the Subscriptions plugin on my own server?
Limiting Subscription Length
Discourse Subscriptions - use API to find out product, plan and renewal date
Discourse Subscriptions - user not removed from group when subscription cancelled
Discourse Subscriptions - user not removed from group when subscription cancelled

5 сообщений были перенесены в новую тему: Ошибка «Похожий объект существует в тестовом режиме»

Настройка Sidebar кажется не имеющей эффекта (последняя версия Discourse aeb3d717dc, последний плагин cc43d32a).

1 лайк

Я тоже получаю это сообщение в логе:

Уведомление об устаревании: имя иконки "donate" было изменено на "circle-dollar-to-slot". Пожалуйста, используйте новое имя в вашем коде. Старые имена будут удалены во втором квартале 2025 года. [id устаревания: discourse.fontawesome-6-upgrade] [инфо: https://meta.discourse.org/t/325349]

РЕДАКТИРОВАНИЕ: Создал PR по этому вопросу

3 лайка

2 сообщения были объединены с существующей темой: “Поддержите нас” Баннер не обновляется

Хм… у меня локально оно появляется в боковой панели, когда я переключаю режим.

Если у вас включена боковая панель, мы добавляем этот CSS-класс. Вы можете проверить страницу и поискать subscription-campain-sidebar.

У вас оно просто остаётся вверху?

Теперь я понял. У меня по умолчанию была установлена страница Категорий. Там, очевидно, это не отображается. А в списке «Последние» — да. Так что всё работает отлично. Спасибо!

3 лайка

Это действительно должно отображаться на странице «Категории» (или других страницах по умолчанию), не так ли?

1 лайк

Из-за ограничений в материковом Китае Stripe испытывает трудности с прохождением проверки. Не могли бы вы рассмотреть возможность интеграции интерфейсов Alipay или WeChat Pay?

2 лайка

В прошлом на подобные вопросы отвечали так: «Правильным решением будет создание плагина для Alipay или WeChat Pay». discourse.org зарабатывает на тех, кто платит за хостинг, и, думаю, у них не так много корпоративных клиентов, которым нужны Alipay или WeChat Pay, поэтому вам стоит задать вопрос в канале Marketplace или разработать решение самостоятельно. Возможно, вы сможете заинтересовать Alipay или WeChat Pay финансированием разработки.

3 лайка

Я выполнил шаги с 1 по 5, но, видимо, я тупой или слепой. Не могу найти интерфейс для настройки продуктов и тарифных планов на моём сервере.

Ах, ладно… Нашёл. Последний кусок головоломки — я не понимаю этого:

  • Чтобы добавить описание к вашему продукту, добавьте поле метаданных с именем «description» и используйте его. Вы можете использовать Markdown.

Я считаю, что всё настроено правильно. Если я проверяю настройку:
Кнопка «Подписаться» будет показывать встроенную таблицу цен, и будет использоваться Stripe Checkout.
Тогда покупки работают корректно, однако, если я снимаю эту галочку и использую встроенный интерфейс, я получаю сообщения об ошибках, такие как:

Ожидалось наличие способа оплаты типа «card», но у этого PaymentIntent нет способа оплаты, и он не был предоставлен. Попробуйте снова, указав либо параметр payment_method, либо payment_method_data.

или

У этого клиента нет привязанного источника оплаты или способа оплаты по умолчанию. Пожалуйста, рассмотрите возможность добавления способа оплаты по умолчанию. Для получения дополнительной информации посетите https://stripe.com/docs/billing/subscriptions/payment-methods-setting#payment-method-priority.

Верхняя ошибка относится к плану без периодических платежей, нижняя — к плану с периодическими платежами.
Есть какие-либо идеи, как это исправить? Мне больше нравится встроенный интерфейс.

Я разобрался в этом. Похоже, что когда я экспериментировал с пользователями в тестовой среде, Stripe не принял использование одного и того же пользователя Discourse с разными «пользователями подписки».

Кроме того, автор оригинального поста должен уточнить, что

Чтобы добавить описание к вашему продукту, добавьте поле метаданных с именем «description» и используйте его. Вы можете использовать Markdown.

Перейдите в панель управления Stripe, нажмите на «Каталог продуктов», выберите продукт, затем нажмите на цену. Именно здесь вы найдете поля метаданных, к которым можно добавить описание.

Однако, это, похоже, не сработало для меня. Я добавил тестовое описание, но ничего не изменилось — ни при использовании таблицы Stripe, ни при использовании встроенного макета.

6 сообщений были объединены в существующую тему: Добавить разные способы оплаты к подписке Discourse

Пост был объединен с существующей темой: Добавить различные способы оплаты к подписке Discourse

При попытке создать товар я получаю ошибку «500». Я настраиваю это в тестовой среде. Что можно проверить, чтобы выяснить причину ошибки сервера?

Аналогичная проблема возникает с купонами.

Создан ли в то же время какой-либо запись в {YOURFORUM}/logs?

2 лайка

Ого, я даже не знал, что такая страница существует. Выдает ошибку «неверный ключ API». Я пока ввел какой-то мусор в поле секретного ключа, чтобы перейти дальше и настроить пакеты подписки, а к ключам вернусь позже, когда буду готов к тестированию.

1 лайк

Мне удалось успешно настроить плагин, но затем я понял, что он поддерживает только повторяющиеся подписки, а не разовые, которые истекают по истечении заданного периода.

Например, списывать сумму X за 30 дней. По прошествии 30 дней пользователь удаляется из премиум-группы. При желании он может купить подписку снова. Обычно я предлагаю членства сроком на 1, 3 или 12 месяцев.

Stripe требует регистрации в качестве юридического лица для поддержки повторяющихся платежей. Я принимаю разовые платежи на XenForo, где встроенная функция XenForo автоматически обрабатывает истечение подписки и удаление пользователя из группы.

Это полностью разрушает мои планы по переходу на Discourse в течение месяца. :cry:

У меня есть решение. Я могу помочь вам создать GitHub Action, которая будет извлекать данные из Data Explorer, включая имя пользователя и идентификатор группы, из которой нужно удалить пользователя, а затем изменять его группу соответствующим образом.

Я делаю это для клиента, который переходит на Discourse и имеет пользовательское поле с датами. Нам нужно перемещать пользователей в группу «исчезает скоро», чтобы показать им баннер, а затем перемещать их в другую группу, чтобы удалить из платной группы, когда время истечет.

Если у вас есть бюджет, вы можете связаться со мной или задать вопрос в Marketplace. Я планирую написать статью об этом с общим примером, если когда-нибудь найду время.

6 лайков

Здравствуйте, подписки работают корректно до момента получения обратного вызова от Stripe. Я использую таблицу цен Stripe.

Я вижу, что подписка успешно зарегистрирована на странице admin/plugins/discourse-subscriptions/subscriptions.

Однако пользователь не был добавлен в требуемую группу.

Я настроил продукт с точно таким же названием, как в Stripe, и также создал тарифный план с выбранной группой. Цену в тарифном плане я установил равной нулю, предполагая, что для конфигурации таблицы цен Stripe это не имеет значения.

Что я упускаю?