Plugin d'abonnements Discourse

:discourse2: Résumé Le plugin Discourse Subscriptions permet aux propriétaires de sites de vendre des abonnements récurrents et des achats uniques qui accordent l’accès à un groupe sur une instance Discourse.
:open_book: Guide d’installation Ce plugin est inclus dans le noyau de Discourse. Aucune installation séparée du plugin n’est nécessaire.

Le plugin Discourse Subscriptions vous permet de créer des abonnements uniques ainsi que récurrents que les utilisateurs peuvent payer pour accéder à du contenu restreint. Cela peut être un excellent moyen de financer les coûts d’hébergement de votre communauté.

Fonctionnalités

Le plugin Discourse Subscriptions prend en charge les fonctionnalités suivantes :

Le bouton « S’abonner » situé dans la barre de navigation supérieure vous mènera à la page d’abonnement /s, où sont répertoriés les abonnements que vous avez configurés pour votre site :

Une fois qu’un utilisateur clique sur le bouton « S’abonner » d’un plan spécifique, la page de paiement pour ce plan s’ouvre :

Après qu’un utilisateur a rempli ses informations de paiement et son adresse, puis cliqué sur « S’abonner », un message « Merci ! » s’affiche et il est redirigé vers sa page de facturation :

L’utilisateur est également automatiquement ajouté à un groupe de votre choix, ce qui vous permet de voir facilement quels utilisateurs se sont abonnés et de fournir du contenu restreint dans des catégories visibles uniquement par ce groupe.

Termes

  • Abonnement - Les abonnements sont des plans de paiement récurrents qui vous permettent de contrôler l’accès au contenu de votre communauté. Lorsqu’un abonnement est créé ou supprimé, un utilisateur est ajouté ou retiré du groupe d’utilisateurs associé à votre plan d’abonnement. Un abonnement est composé d’un produit et de plans.
  • Produit - Dans les termes de Stripe, un produit est ce que vous vendez. Un produit peut contenir un ou plusieurs plans.
    • Pour ajouter une description à votre produit, ajoutez un champ de métadonnées nommé « description » et utilisez celui-ci à la place. Vous pouvez utiliser Markdown.
  • Plan - Un plan contient un prix, un cycle récurrent et est associé à un groupe auquel vos abonnés ont accès.

:police_car_light: Soyez très prudent pour garder vos clés privées Stripe en sécurité en tout temps.

:warning: Si vous arrêtez votre instance Discourse, désinstallez ce plugin ou si votre site devient hors ligne, Stripe continuera de facturer vos clients pour votre service jusqu’à ce que l’abonnement soit annulé.

Configuration

  1. Installer et activer le plugin
  2. Configurer la passerelle de paiement (Stripe)
  3. Configurer les Webhooks et les événements dans Stripe
  4. Ajouter vos clés Stripe (publique, secrète, secret webhook) sous Admin > Plugins > Installés > Abonnements > Paramètres /admin/site_settings/category/discourse_subscriptions?filter=plugin%3Adiscourse-subscriptions.
  5. Créer un groupe auquel vos abonnés peuvent rejoindre via un achat
  6. Créer un produit et un plan sous Admin > Plugins > Abonnements
  7. Profit !

Configurer votre passerelle de paiement.

Tout d’abord, vous aurez besoin d’un compte auprès de la passerelle de paiement Stripe. Pour commencer, vous pouvez configurer un compte en mode test et voir comment tout fonctionne sans effectuer de vraies transactions ni avoir à configurer un compte bancaire. Il n’y a pas d’interrupteur de mode test dans le plugin ; assurez-vous plutôt d’utiliser vos clés de développement (elles commencent par pk_test, sk_test).

Configurer les Webhooks et les événements dans votre compte Stripe

:bomb: Les Webhooks sont nécessaires pour que les annulations d’abonnement fonctionnent pleinement. Assurez-vous qu’ils sont correctement configurés.

Une fois que vous avez un compte sur Stripe, vous devrez indiquer à Stripe l’adresse de votre site web afin qu’il puisse vous notifier de certaines transactions. Vous pouvez entrer cela dans votre tableau de bord Stripe sous Endpoints > URL.

Adresse du Webhook : [votre adresse de serveur]/s/hooks – où [votre adresse de serveur] est l’URL de votre installation Discourse.

Vous devrez également indiquer à Stripe quels événements il doit vous notifier via l’URL du webhook.

Actuellement, Discourse Subscriptions répond aux événements suivants :

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

Ajouter les clés API et Webhook de Stripe aux paramètres de votre plugin

Stripe doit être autorisé à communiquer avec votre site web. Pour ce faire, il publie une paire de clés API privées et publiques ainsi qu’un secret de signature pour vos webhooks.

Pour autoriser les webhooks, ajoutez les clés API et le secret webhook de Stripe à votre page de paramètres (sous Développeurs).

:warning: L’ajout de clés de production effectuera des paiements en direct. Si vous prévoyez de tester, assurez-vous de passer en mode Voir les données de test et d’obtenir les clés pk_test et sk_test sous Développeurs.

Dans les paramètres de votre compte Stripe, consultez :

Ajoutez ces clés dans les paramètres appropriés sous Admin > Plugins > Installés > Abonnements > Paramètres /admin/site_settings/category/discourse_subscriptions?filter=plugin%3Adiscourse-subscriptions.

Configurer vos groupes d’utilisateurs dans Discourse

Lorsqu’un utilisateur s’abonne avec succès à votre application Discourse, après le traitement de sa transaction par carte de crédit, il est ajouté à un groupe d’utilisateurs. En attribuant des utilisateurs à un groupe d’utilisateurs, vous pouvez gérer ce à quoi vos utilisateurs ont accès sur votre site web. Les groupes d’utilisateurs sont une fonctionnalité de base de Discourse et ce plugin ne fait rien avec eux, sauf ajouter et supprimer des utilisateurs du groupe que vous avez associé à votre Plan.

Créer un ou plusieurs produits avec des plans.

Sous Admin > Plugins > Abonnements, cliquez sur Ajouter un nouveau Produit. Une fois que vous avez enregistré un produit, vous pouvez y ajouter des plans. Gardez à l’esprit que les prix et les intervalles de facturation des plans ne peuvent pas être modifiés une fois qu’ils sont créés. Cela vise à éviter toute confusion dans la gestion des abonnements.

Si vous regardez votre Tableau de bord Stripe, vous verrez que tous ces produits et plans y sont répertoriés. Discourse Subscriptions ne les crée pas localement. Ils sont créés dans Stripe.

Tests

Testez avec ces numéros de carte de crédit :

  • 4242 4242 4242 4242
  • 4111 1111 1111 1111 (aucune authentification requise)
  • 4000 0027 6000 3184 (authentification requise)

Pour plus de numéros de cartes de test : Test card numbers | Stripe Documentation

Visitez /s et effectuez quelques transactions de test.

Passage en production

Lorsque vous êtes prêt à passer en production, remplacez vos clés API et votre secret webhook par des clés de production. Vous devrez créer de nouveaux produits et plans en mode live.

Sachez que si vous ne configurez pas correctement les webhooks Stripe et que les paiements récurrents échouent pour une raison quelconque (carte de crédit expirée, etc.), les utilisateurs auront toujours accès au groupe. Pour que Stripe annule automatiquement les abonnements, assurez-vous de configurer vos paramètres Gérer les paiements échoués comme sur l’image ci-dessous et de configurer les webhooks comme décrit ci-dessus.

Mise à jour des informations de paiement

Les utilisateurs peuvent mettre à jour la carte utilisée pour des abonnements individuels en visitant la page de facturation et en cliquant sur le bouton Modifier à côté de l’abonnement, ce qui ouvrira cet écran :

Stripe Checkout avec les tableaux de prix Stripe

Vous pouvez également choisir de remplacer les pages de produit et de paiement du plugin d’abonnement et utiliser à la place Stripe Checkout avec les Tableaux de prix Stripe.

Dans votre tableau de bord Stripe :

  1. Après avoir créé les produits sur Discourse, allez dans Produits > Catalogue de produits
  2. Cliquez sur le produit que vous souhaitez inclure dans le tableau de prix
  3. Cliquez sur Modifier le produit
  4. Plus d'options et saisissez les éléments suivants sous Métadonnées :
    • Clé : group_name
    • Valeur : Le nom du groupe sur Discourse (par exemple, trust_level_0)
  5. Cliquez sur Mettre à jour le produit pour enregistrer

:red_exclamation_mark: Assurez-vous que le nom du groupe correspond au groupe sélectionné sous User_Groups sur Discourse

Créez votre tableau de prix Stripe

  1. Allez dans Produits > Tableaux de prix
  2. Créez un nouveau tableau et ajoutez les produits que vous venez de créer
  3. Après avoir publié le tableau, copiez l’ID du tableau de prix trouvé dans le code d’intégration (il commence par prctbl_...)
  4. Collez l’ID du tableau de prix dans votre discourse_subscriptions_pricing_table_id et activez le paramètre du tableau de prix des abonnements.
  5. Cliquez sur les coches vertes pour enregistrer les deux paramètres.

Étape recommandée :

Lors de la configuration du Tableau de prix dans Stripe, il est recommandé de rediriger l’utilisateur vers votre site une fois le paiement terminé, sinon il restera sur une page de confirmation Stripe sans lien vers votre site.

Rediriger vers https://<votre-site>/my/billing/subscriptions est un bon choix pour les abonnements. Pour des paiements ponctuels, vous pourriez lier directement à https://<votre-site>/my/billing/payments.

Collecte automatique des taxes

Pour activer la collecte automatique des taxes, cochez la case du paramètre du site pour discourse_subscriptions_enable_automatic_tax.

Si vous l’activez, mais que vous n’avez pas correctement configuré votre instance Stripe pour collecter les taxes, les utilisateurs pourraient voir cette fenêtre contextuelle après avoir terminé le processus de paiement :

Il existe ce guide pour plus d’informations, mais il ne devrait pas y avoir grand-chose à faire puisque le plugin transmet désormais le paramètre approprié automatic_tax[enabled]=true (étape 5).

Assurez-vous également de configurer vos inscriptions (étape 4) :

Voici un exemple de transaction du plugin Discourse Subscription dans Stripe montrant que la taxe a été collectée automatiquement :

Paramètres

Nom Description
discourse subscriptions enabled Activer le plugin Discourse Subscriptions.
discourse subscriptions extra nav subscribe Afficher le bouton S’abonner dans la navigation principale
discourse subscriptions public key Clé publique Stripe
discourse subscriptions secret key Clé secrète Stripe
discourse subscriptions webhook secret Secret webhook Stripe
discourse subscriptions currency Code de devise par défaut. Cela peut être remplacé lors de la création d’un plan d’abonnement.
discourse subscriptions campaign enabled Active une bannière de campagne pour promouvoir le soutien financier de cette communauté.
discourse subscriptions campaign goal L’objectif numérique de votre campagne de soutien (abonnés ou montant recueilli).
discourse subscriptions campaign type Sélectionne le type de campagne à lancer (abonnés ou montant mensuel recueilli).
discourse subscriptions campaign banner location Sélectionne l’emplacement de la bannière de campagne (haut ou barre latérale).
discourse subscriptions campaign banner bg image Téléchargez une image personnalisée à utiliser comme arrière-plan de la bannière de campagne.
discourse subscriptions campaign banner shadow color Sélectionne la couleur de l’ombre portée de la bannière de campagne.
discourse subscriptions campaign show contributors Afficher les avatars des achats les plus récents de produits d’abonnement.
discourse subscriptions campaign product L’ID de produit Stripe à envoyer aux supporters lorsqu’ils cliquent sur le bouton de la campagne. Si ce paramètre est vide, les supporters seront redirigés vers la page principale des produits.
discourse subscriptions campaign grant Accorde à l’utilisateur un mois d’abonnement gratuit
discourse subscriptions pricing table id L’ID du tableau de prix Stripe issu du code d’intégration
discourse subscriptions pricing table enabled Active l’utilisation du tableau de prix Stripe et remplace la page d’abonnement existante
discourse_subscriptions_enable_automatic_tax Bascule si la taxe de vente sera collectée. Nécessite une configuration dans Stripe.
discourse_subscriptions_enable_verbose_logging Active une journalisation plus détaillée pour aider au débogage. Veuillez ne pas laisser activé en permanence en production.

:discourse2: Hébergé par nous ? Ce plugin est disponible sur nos plans d’hébergement Pro, Business et Enterprise Subscriptions | Discourse - Civilized Discussion

139 « J'aime »
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 messages ont été déplacées vers un nouveau sujet : Une erreur « Un objet similaire existe en mode test » s’est produite

Le réglage de Sidebar ne semble rien faire (dernière version de Discourse aeb3d717dc, dernier plugin cc43d32a).

1 « J'aime »

Je reçois également ce message de journal :

Avis de dépréciation : le nom de l'icône « donate » a été mis à jour en « circle-dollar-to-slot ». Veuillez utiliser le nouveau nom dans votre code. Les anciens noms seront supprimés au T2 2025. [deprecation id: discourse.fontawesome-6-upgrade] [info: https://meta.discourse.org/t/325349]

EDIT : J’ai créé une PR pour cela

3 « J'aime »

2 messages ont été fusionnées dans un sujet existant : Bannière « Soutenez-nous » ne se met pas à jour

Hmmm… localement, il s’affiche dans la barre latérale lorsque je le permute.

Si vous l’avez dans la barre latérale, nous avons ajouté cette classe CSS. Vous pouvez inspecter votre page et rechercher subscription-campain-sidebar.

Est-ce qu’il reste juste en haut pour vous ?

Je vois. J’avais la page de catégorie comme page par défaut. Elle ne s’y affiche pas, évidemment. Elle s’affiche sur la liste “Latest”. Donc, cela fonctionne bien. Merci !

3 « J'aime »

Cela devrait vraiment apparaître sur la page Catégories (ou d’autres pages par défaut), n’est-ce pas ?

1 « J'aime »

En raison des restrictions en Chine continentale, il est difficile pour Stripe de passer la revue. Pourriez-vous envisager d’intégrer les interfaces d’Alipay ou de WeChat Pay ?

2 « J'aime »

Des questions similaires par le passé ont reçu une réponse comme « la chose à faire serait de créer un plugin pour Alipay ou WeChat Pay ». discourse.org tire ses revenus de ceux qui paient pour l’hébergement et je ne pense pas qu’ils aient beaucoup de clients d’entreprise qui veulent Alipay ou WeChat Pay, vous devrez donc demander dans Marketplace ou le développer vous-même. Peut-être pourriez-vous intéresser Alipay ou WeChat Pay à financer le développement.

3 « J'aime »

J’ai terminé les étapes 1 à 5, mais je suppose que je suis stupide ou aveugle. Je n’arrive pas à trouver l’interface pour configurer les produits et les plans sur mon serveur.

Ugh, j’ai trouvé. La dernière pièce du puzzle est que je ne comprends pas ceci :

  • Pour ajouter une description à votre produit, ajoutez un champ de métadonnées nommé « description » et utilisez celui-ci à la place. Vous pouvez utiliser Markdown.

Je pense que j’ai tout configuré correctement. Si je vérifie le paramètre :
Le bouton S'abonner affichera le tableau des prix intégrés et Stripe Checkout sera utilisé.
Alors les achats fonctionnent correctement, cependant, si je décoche cela et que j’utilise l’interface intégrée, j’obtiens des boîtes d’erreur telles que :

Un moyen de paiement de type carte était attendu, mais cet PaymentIntent n’a pas de moyen de paiement et aucun n’a été fourni. Réessayez en fournissant les paramètres payment_method ou payment_method_data.

ou

Ce client n’a pas de source de paiement ou de moyen de paiement par défaut. Veuillez envisager d’ajouter un moyen de paiement par défaut. Pour plus d’informations, visitez https://stripe.com/docs/billing/subscriptions/payment-methods-setting#payment-method-priority.

L’erreur principale concerne un plan non récurrent, l’erreur du bas concerne un plan récurrent.
Des indices sur la façon de résoudre ce problème ? Je préfère l’interface intégrée.

J’ai résolu ce problème, il semble que pendant que je jouais avec les utilisateurs dans l’environnement de test, Stripe n’a pas apprécié que j’utilise le même utilisateur Discourse avec différents « utilisateurs d’abonnement ».

De plus, l’OP devrait clarifier que

Pour ajouter une description à votre produit, ajoutez un champ de métadonnées nommé « description » et utilisez celui-ci à la place. Vous pouvez utiliser Markdown.

Allez sur le tableau de bord Stripe, cliquez sur Catalogue de produits, cliquez sur un Produit, puis cliquez sur un Prix. C’est là que vous trouverez les champs de métadonnées auxquels vous pouvez ajouter une description.

Cependant, cela ne semble pas avoir fonctionné pour moi. J’ai ajouté une description de test et rien n’a changé, que ce soit en utilisant le tableau Stripe ou la disposition intégrée.

6 messages ont été fusionnés à un sujet existant : Ajouter différentes méthodes de paiement à l’abonnement Discourse

Un message a été fusionné dans un sujet existant : Ajouter différentes méthodes de paiement à l’abonnement Discourse

Lorsque j’essaie de créer un produit, j’obtiens une erreur « 500 ». Je configure cela sur une configuration de test. Que puis-je vérifier pour savoir pourquoi j’ai cette erreur serveur ?

Chose similaire sur les coupons

Une entrée a-t-elle été créée en même temps dans {YOURFORUM}/logs ?

2 « J'aime »

Oh wow… je ne savais pas qu’une telle page existait. Indique une clé API invalide. J’ai mis n’importe quoi pour la clé secrète afin de continuer et de configurer les offres d’abonnement pour l’instant et de revenir aux clés plus tard lorsque je serai prêt à tester.

1 « J'aime »

J’ai pu configurer le plugin sans problème, mais j’ai ensuite réalisé que ce plugin ne permet que les abonnements récurrents. Pas les abonnements uniques qui expirent après la période définie.

Par exemple, facturer X montant pendant 30 jours. Après 30 jours, l’utilisateur est retiré du groupe premium. Il peut le racheter s’il le souhaite. Habituellement, je propose des adhésions de 1 mois, 3 mois et 12 mois.

Stripe exige que je m’enregistre en tant qu’entreprise pour pouvoir prendre en charge les paiements récurrents. Je prends des paiements uniques sur XenForo et la fonctionnalité native de XenForo gère l’expiration de l’abonnement et le retrait de l’adhésion au groupe.

Cela anéantit complètement mon projet de passer à Discourse d’ici un mois. :cry:

J’ai une solution. Je peux vous aider à créer une action github qui extraira les données de l’explorateur de données, y compris le nom d’utilisateur et l’ID du groupe à supprimer, puis modifiera leur groupe en conséquence.

Je le fais pour un client qui migre vers Discourse et qui a un champ personnalisé avec des dates. Nous devons donc déplacer les utilisateurs vers un groupe espérant-bientôt pour leur donner une bannière, puis un autre pour les supprimer du groupe payant lorsque le délai est écoulé.

Si vous avez un budget, vous pouvez me contacter ou poser votre question dans Marketplace. Je prévois un article de blog à ce sujet avec un exemple à usage général, si jamais j’ai une pause.

6 « J'aime »

Bonjour, les abonnements fonctionnent bien jusqu’au moment où le rappel de Stripe arrive. J’utilise la table de prix Stripe.

Je peux voir que l’abonnement a été enregistré avec succès sur la page admin/plugins/discourse-subscriptions/subscriptions.

Cependant, l’utilisateur n’a pas été déplacé vers le groupe d’utilisateurs requis.

J’ai configuré le produit avec le même nom de produit que sur Stripe et j’ai également créé un plan de tarification avec le groupe sélectionné. J’ai laissé le prix à zéro dans le plan de tarification car je suppose que cela est sans importance pour la configuration de la table de prix Stripe.

Qu’est-ce qui me manque ?