Плагин подписок 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