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

:discourse2: Краткое описание Плагин 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. Настройте вебхуки и события в Stripe
  4. Добавьте ваши ключи Stripe (публичный, секретный, секрет вебхука) в разделе Администрирование > Плагины > Установленные > Подписки > Настройки /admin/site_settings/category/discourse_subscriptions?filter=plugin%3Adiscourse-subscriptions.
  5. Создайте группу, в которую будут вступать пользователи через покупку
  6. Создайте продукт и тариф в разделе Администрирование > Плагины > Подписки
  7. Получайте прибыль!

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

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

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

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

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

Адрес вебхука: [ваш адрес сервера]/s/hooks – где [ваш адрес сервера] — это URL вашего установочного файла Discourse.

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

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

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

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

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

Чтобы авторизовать вебхуки, добавьте ключи API и секрет вебхука из Stripe на страницу настроек (в разделе Developers).

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

В настройках аккаунта 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 и секреты вебхуков на продакшн-ключи. Вам потребуется создать новые продукты и тарифы в режиме реальных платежей.

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

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

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

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

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

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

  1. После создания продуктов в Discourse перейдите в Products > Product catalog
  2. Нажмите на продукт, который вы хотите включить в таблицу цен
  3. Нажмите Edit product
  4. More Options и введите следующее в разделе Metadata:
    • Key: group_name
    • Value: Название группы в Discourse (например, trust_level_0)
  5. Нажмите Update product, чтобы сохранить

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

Создание вашей таблицы цен Stripe

  1. Перейдите в Products > Pricing tables
  2. Создайте новую таблицу и добавьте созданные вами продукты
  3. После публикации таблицы скопируйте ID таблицы цен, найденный в коде встраивания (он начинается с prctbl_...)
  4. Вставьте ID таблицы цен в 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 Секрет вебхука 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 ID продукта Stripe, который будет отправлен сторонникам при нажатии кнопки на кампании. Если эта настройка пуста, сторонники будут перенаправлены на главную страницу продуктов.
discourse subscriptions campaign grant Предоставляет пользователю бесплатный месяц подписки
discourse subscriptions pricing table id 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
Discourse Category Lockdown
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
Multiple paywalls with common communication hub
How to move Topics in Category into their own Pinned Topic inside new Categories?
Any good Memberpress alternatives for wordpress?
Send an invite to a user but complete their profile programmatically
User Card Directory
Discourse subscriptions - changing price during recurring subscription
Subscription Access To Discourse
Add user to group after purchase
Discourse Subscriptions + btcpayserver
Do I need Wordpress? Or Discourse can be my solution to ALL?
Discourse Subscriptions - user not removed from group when subscription cancelled
Discourse Subscriptions - user not removed from group when subscription cancelled
Discourse vs Skool
Subscription Access To Discourse
Tax implication of funding a forum
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?
Allow option to open Stripe payment website
Embed a list of Discourse topics onto an external site
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
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
Hosting questions
Alternative sign up pathways
Control Category Visibility and Access by User Levels
Tighter integration of account-creation and subscriptions?
Blank page when resuming discourse app
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'
Why doesn't Discourse hosting include the Subscriptions plugin on the Starter plan?
Allow multiple ‘new topic’ drafts
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
Discourse Category Lockdown
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)
Discourse Unlock
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?
New site landing-page + discourse integration and marketing
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

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 это не имеет значения.

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