Enrolment: Stripe Payment with SCA and Coupon

enrol_stripepayment
Maintained by Picture of DualCube TeamDualCube Team
Now avail the much-awaited coupon functionality while enrolling students in Moodle courses using a Stripe payment gateway for paid courses with Strong customer authentication (SCA). Stripe Receipt sent to customers for any successful transaction. This plugin will help the admins and webmasters to offer their students a percent-off or amount-off discount for the paid courses. This plugin helps admins and webmasters use Stripe as the payment gateway.
777 sites
788 downloads
42 fans
Current versions available: 2

Stripe Payment: 

Introducing the newest offering from Team Dualcube: Stripe Payment!

Now avail the much-awaited coupon functionality while enrolling students in Moodle courses using Stripe payment gateway for paid courses with Strong customer authentication (SCA).

This plugin will help the admins and webmasters to offer their students a percent-off or amount-off discount for the paid courses.


Stripe Payment:


1. Registered users can login to the Moodle site and happily apply the promo codes for a discount before payment. On successful payment, they can access the course.

2. Admins and Webmasters, now, can create, manage and keep track of all promotional codes directly in their Stripe dashboard.

3. Strong customer authentication (SCA) implemented with 4 layers of complex security to comply with EU Revised Directive on Payment Services (PSD2) on payment service providers within the European Economic Area.

4. The first of it's kind to use Payment intent method for Stripe-coupon. 

5. Works with all stable versions of Moodle till v 3.8.1

6. Latest Stripe SDK


Stripe Payment Documentation:



This plugin has all the settings for development as well as for production usage. Its easy to install, set up and effective.

Creating Merchant Account :

1) Create account at https://stripe.com.

2) Complete your merchant profile details from https://dashboard.stripe.com/account.

3) Now set up secret key and publishers key at https://dashboard.stripe.com/account/apikeys.

4) For test mode use test api keys and for live mode use live api keys.

Now you are done with merchant account set up.

Installation Guidance : 

Login to your moodle site as an “admin user” and follow the steps.

1) Upload the zip package from Site administration > Plugins > Install plugins. Choose Plugin type 'Enrolment method (enrol)'. Upload the ZIP package, check the acknowledgement and install.

2) Go to Enrolments > Manage enrol plugins > Enable 'Stripe' from list

3) Click 'Settings' which will lead to the settings page of the plugin

4) Provide merchant credentials for Stripe. Note that, you will get all the details from your merchant account. Now select the checkbox as per requirement. Save the settings.

5) Select any course from course listing page.

6) Go to Course administration > Users > Enrolment methods > Add method 'Stripe' from the dropdown. Set 'Custom instance name', 'Enrol cost' etc and add the method.

Adding coupons:

Go to your Stripe Dashboard >  Billing > Coupons > Create a coupon.

Type in the coupon’s name: it can be anything and for your reference only.
Type in the Coupon’s ID : This is the Coupon code which your students will need to enter if they want to avail the discount.

Choose Coupon Type: 
1. Percentage discount : offers % off on the course price 
2. Fixed amount discount : Offers a fixed amount off on the course price.

Duration: For duration, when using the value repeating, also specify duration in months as the number of months for which the coupon should repeatedly apply. Otherwise the coupon can be set to apply only to a single invoice or to them all.

Redemption : The max_redemptions and redeem_by values apply to the coupon across every customer you have. For example, you can restrict a coupon to the first 50 customers that use it, or you can make a coupon expire by a certain date. If you do the latter, this only impacts when the coupon can be applied to a customer. If you set a coupon to last forever when used by a customer, but have it expire on January 1st, any customer given that coupon will have that coupon’s discount forever, but no new customers can apply the coupon after January 1st.

If a coupon has a max_redemptions value of 50, it can only be applied among all your customers a total of 50 times, although there’s nothing preventing a single customer from using it multiple times. (You can always use logic on your end to prevent that from occurring.)


 

This completes all the steps from the administrator end. Now registered users can login to the Moodle site and view the course after a successful payment of the discounted price. 


Screenshots

Screenshot #0
Screenshot #1
Screenshot #2
Screenshot #3
Screenshot #4

Contributors

Picture of DualCube Team
DualCube Team (Lead maintainer)
Please login to view contributors details and/or to contact them

Comments RSS

Show comments
  • Picture of Chandra Kishor
    Fri, Jun 19, 2020, 2:18 AM
    I think, the exception handler class should be changed in validate-coupon.php, as , with wrong coupon code, it doesn't catch the error. In version , 2020052800, the class is Stripe_InvalidRequestError, however, exception comes under Stripe\Exception\InvalidRequestException
  • Picture of Steve Zielinski
    Sat, Jun 20, 2020, 6:12 AM
    Is there anyway to change the graphic that reads "stripe"? It would be much clearer to users if we could display the more well known "Visa, Mastercard, ..." graphic.
  • Picture of Steve Zielinski
    Sat, Jun 20, 2020, 7:40 AM
    I answered my own question. I replaced the stripe.png file with my own graphic. stripe.png is found in moodle>enrol>stripepayment. It is a 300x300 png.
  • Picture of DualCube Team
    Tue, Jun 23, 2020, 8:32 PM
    Dear Steve,
    Great! That is a good solution.

    Thank you.
  • Picture of DualCube Team
    Tue, Jun 23, 2020, 8:32 PM
    Dear Chandra,
    Thanks for the feedback. We will look into it.
    Thank you.
  • Picture of D. D
    Fri, Jun 26, 2020, 8:59 PM
    Hi Dualcube team, I have added the stripe plugin inside my moodle site,when I made the payments using Rupay cards It was not working...I have added the publishable key as well as secret key manage enrol plugins...It accepted only visa card..can you help me with it
  • Picture of DualCube Team
    Mon, Jun 29, 2020, 2:44 PM
    Dear DD,
    It uses Payment intent method. If Stripe supports this method for Rupay cards, it should work. Please contact Stripe.
    Thank you.
  • Picture of Ali Çakır
    Wed, Jul 22, 2020, 11:40 PM
    Hi!
    I did everything that you said. There is only a problem. "Submit payment" button isn't working.

    Please help me.
    Thank you.
  • Picture of DualCube Team
    Fri, Jul 24, 2020, 3:49 PM
    Dear Ali
    We will need to check that. Please send your Moodle credentials to admin@dualcube.com

    Thank you.
  • Picture of Ali Çakır
    Fri, Jul 24, 2020, 5:46 PM
    Thank you very much for your response. Moodle credentials? Is it my moodle address, my admin username and password?

    Thanks a lot.
  • Picture of Bordin Phayaphrom
    Thu, Jul 30, 2020, 12:29 PM
    I dose not work on Moodle 3.9
  • Picture of Manibhushan Dharmadhikari
    Fri, Aug 7, 2020, 12:29 PM
    DualCube Team thank you for the useful plugin. However the submit button is not working in Moodle 391. Nothing is happening when i press submit button after entering values in all fields. Please help.
  • Picture of DualCube Team
    Fri, Aug 7, 2020, 1:03 PM
    Dear Manibhushan,

    Please install the last update. Thank you.
  • Picture of Manibhushan Dharmadhikari
    Fri, Aug 7, 2020, 4:24 PM
    Thank you for the prompt reply. I installed the last update today itself but still the Submit Payment button is not working. The Coupon code button is however working perfectly fine
  • Picture of DualCube Team
    Fri, Aug 7, 2020, 5:12 PM
    Dear Manibhushan,
    Please share your site's details to admin@dualcube.com so that we can debug the issue.

    Thank you.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
Please login to post comments