stripe-rails 2.4.0 → 2.6.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 4f877c1646308e099953867cf62109fc8274a9d452d4b1ddbaddacc421c5bc77
4
- data.tar.gz: c6986a7464043e10d13580ad1149120931b794070640c4103368daa474580bf9
3
+ metadata.gz: 4c538d4a4b8db8bd116c1eb366bd670b799b8e04f51c9d6bcc27b7142db01428
4
+ data.tar.gz: ba73f988546de21fff5418a62ff524cfc19dbac082963df77065843f1928a474
5
5
  SHA512:
6
- metadata.gz: 132c1fec2a1510815e2694c0150a646cbec3d90f7bf8cb4b231ad209ba28e12e9b40ba2a89f77d75d8499b8a5559c332d4e5f6db9c20f3d4f4ff5b08601f6d7d
7
- data.tar.gz: 43779b3dfbcfdeeb1ed74c14e783faf09b74dc81a8279a800c815cab4717bfc746d0a1da558853201546199545c25f991eaa44348c477418edae4cca63c3c7bf
6
+ metadata.gz: 7270f00f96686dd9253591bb55e257972d9efef335598914c9f49e1b921bbd5665c07e92a1371d08524e42d1647ba9d0f5692797490bf3a4cf635a102e4eab6e
7
+ data.tar.gz: '088469b144b84bda35557605ea176381f2ec4f9f93cea13cd76fa4e2ddf0d7abf1476676eaa75ee61a6ccdf1af0c5a09cfbc728122c50d5e69c8a75cce9dc653'
@@ -1,4 +1,3 @@
1
1
  <!--
2
- Please give us ~1 week to get back to you.
3
- If you'd like to receive occasional updates, sign up for our newsletter at http://tinyletter.com/stripe-rails
4
- -->
2
+ Please give us ~4 weeks to get back to you.
3
+ -->
@@ -9,7 +9,5 @@
9
9
 
10
10
  That's it!
11
11
 
12
- Please give me ~1 week to get back to you.
13
-
14
- If you'd like to receive occasional updates, sign up for our newsletter at http://tinyletter.com/stripe-rails
15
- -->
12
+ Please give me ~4 week to get back to you.
13
+ -->
@@ -12,12 +12,13 @@ jobs:
12
12
  build:
13
13
  runs-on: ubuntu-latest
14
14
 
15
+ continue-on-error: true
15
16
  strategy:
16
17
  matrix:
17
- ruby: [2.5.9, 2.6.10, 2.7.7]
18
- gemfile: [Gemfile, gemfiles/rails60.gemfile, gemfiles/rails52.gemfile, gemfiles/rails51.gemfile]
18
+ ruby: [3.0.7, 3.1.6, 3.2.5, 3.3.4]
19
+ gemfile: [gemfiles/rails71.gemfile, gemfiles/rails70.gemfile, gemfiles/rails61.gemfile, gemfiles/rails60.gemfile] # Gemfile fails on test/callbacks_spec.rb:52
19
20
  steps:
20
- - uses: actions/checkout@v1
21
+ - uses: actions/checkout@v4
21
22
  - name: Set up Ruby
22
23
  uses: ruby/setup-ruby@v1
23
24
  with:
@@ -33,11 +34,8 @@ jobs:
33
34
  CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }}
34
35
  RUBY_VERSION: ${{ matrix.ruby }}
35
36
  run: |
36
- if [ $RUBY_VERSION == "2.5.x" ] ;
37
- then gem install bundler
38
- fi
39
37
  bundle install --jobs 4 --retry 3
40
38
  bundle exec rake
41
- if [ `basename $BUNDLE_GEMFILE` == "Gemfile" ] && [ $RUBY_VERSION == "2.7.x" ] && [ ! -z ${CC_TEST_REPORTER_ID} ] ;
39
+ if [ `basename $BUNDLE_GEMFILE` == "Gemfile" ] && [ $RUBY_VERSION == "3.3.4" ] && [ ! -z ${CC_TEST_REPORTER_ID} ] ;
42
40
  then ./cc-test-reporter after-build --exit-code $? ;
43
41
  fi
data/Changelog.md CHANGED
@@ -1,3 +1,26 @@
1
+ ## Next Release
2
+
3
+ ## 2.6.0 (2024-08-12)
4
+ - Add the following callbacks (Thanks @4nd2in !):
5
+ * `checkout.session.async_payment_failed`
6
+ * `checkout.session.async_payment_succeeded`
7
+ * `customer.subscription.paused`
8
+ * `customer.subscription.pending_update_applied`
9
+ * `customer.subscription.pending_update_expired`
10
+ * `customer.subscription.resumed`
11
+ * `invoice.deleted`
12
+ * `invoice.finalization_failed`
13
+ * `invoice.overdue`
14
+ * `invoice.will_be_due`
15
+ - Fix request handling in rack versions >= 3.1 where `Request#[]` is deprecated (#230). Thanks @4nd2in and
16
+ @light-flight !
17
+ - adds testing for Ruby 3 and Rails 7
18
+ - stops testing on Ruby < 3 and Rails 5
19
+
20
+ ## 2.5.0 (2023-03-21)
21
+
22
+ - Allow `stripe_elements_tag` to accept a block. Thanks @chip !
23
+
1
24
  ## 2.4.0 (2023-02-04)
2
25
 
3
26
  - Add `tax_behavior` attribute to Price. Thanks @szechyjs !
data/Gemfile CHANGED
@@ -16,7 +16,6 @@ group :test do
16
16
  gem 'webmock'
17
17
  # System tests
18
18
  gem 'capybara'
19
- gem 'puma', '< 6' # https://github.com/teamcapybara/capybara/issues/2598
20
- gem 'selenium-webdriver'
21
- gem 'webdrivers'
19
+ gem 'puma'
20
+ gem 'selenium-webdriver', '>= 4'
22
21
  end
data/README.md CHANGED
@@ -12,8 +12,6 @@ This gem can help your rails application integrate with Stripe in the following
12
12
  * manage product, prices, plans and coupons from within your app.
13
13
  * painlessly receive and validate webhooks from stripe.
14
14
 
15
- [📫 Sign up for the Newsletter](http://tinyletter.com/stripe-rails) to receive occasional updates.
16
-
17
15
  [Professionally supported stripe-rails is coming soon](https://tidelift.com/subscription/pkg/rubygems-stripe-rails?utm_source=rubygems-stripe-rails&utm_medium=referral&utm_campaign=readme)
18
16
 
19
17
  ---
@@ -26,6 +24,7 @@ This gem can help your rails application integrate with Stripe in the following
26
24
  - [Configuring your plans and coupons](#configuring-your-plans-and-coupons)
27
25
 
28
26
  [Stripe Elements](#stripe-elements)
27
+ - [Custom Elements](#custom-elements)
29
28
 
30
29
  [Webhooks](#webhooks)
31
30
 
@@ -322,6 +321,22 @@ Simply include the `stripe_elements_tag` anywhere below the `stripe_javascript_t
322
321
  <%= stripe_elements_tag submit_path: billing_path %>
323
322
  ```
324
323
 
324
+ Additionally, you can pass a block containing custom form elements to stripe_elements_tag:
325
+
326
+ ## Custom Elements
327
+
328
+ > Stripe::Rails allows you to easily include your own custom form elements
329
+ > within the Stripe form by including those form elements in a block passed to
330
+ > `stripe_elements_tag`:
331
+
332
+ ```erb
333
+ <%= stripe_javascript_tag %>
334
+ <%= stripe_elements_tag(submit_path: billing_path) do %>
335
+ <%= label_tag 'email', 'Email' %>
336
+ <%= text_field :user, :email %>
337
+ <% end %>
338
+ ```
339
+
325
340
  ### Configuration options
326
341
 
327
342
  Stripe::Rails comes bundled with default CSS and Javascript for Stripe elements, making it easy to drop in to your app. You can also specify your own assets paths:
@@ -10,14 +10,16 @@ module Stripe
10
10
 
11
11
  def stripe_elements_tag(submit_path:,
12
12
  css_path: asset_path("stripe_elements.css"),
13
- js_path: asset_path("stripe_elements.js"))
13
+ js_path: asset_path("stripe_elements.js"),
14
+ &block)
14
15
 
15
16
  render partial: 'stripe/elements', locals: {
16
17
  submit_path: submit_path,
17
18
  label_text: t('stripe_rails.elements.label_text'),
18
19
  submit_button_text: t('stripe_rails.elements.submit_button_text'),
19
20
  css_path: css_path,
20
- js_path: js_path
21
+ js_path: js_path,
22
+ block: block
21
23
  }
22
24
  end
23
25
  end
@@ -8,7 +8,7 @@ module Stripe
8
8
  end
9
9
 
10
10
  def retrieve_stripe_event(request)
11
- id = request['id']
11
+ id = request.params['id']
12
12
  body = request.body.read
13
13
  sig_header = request.headers['HTTP_STRIPE_SIGNATURE']
14
14
  endpoint_secrets = ::Rails.application.config.stripe.signing_secrets
@@ -5,6 +5,11 @@
5
5
  </div>
6
6
 
7
7
  <%= form_tag submit_path, id: "stripe-form" do %>
8
+ <% if local_assigns[:block] %>
9
+ <div id="stripe-rails-form-fields">
10
+ <%= capture(&local_assigns[:block]) %>
11
+ </div>
12
+ <% end %>
8
13
  <%= label_tag :card_element, label_text %>
9
14
  <div id="card-element"><!-- A Stripe Element will be inserted here. --></div>
10
15
  <%= submit_tag submit_button_text %>
@@ -1,12 +1,15 @@
1
1
  source :rubygems
2
2
 
3
- gem 'rails', '~> 5.1.0'
3
+ gem 'rails', '~> 7.0.0'
4
4
 
5
5
  gem 'rake'
6
6
  gem 'responders'
7
- gem 'sprockets', '< 4'
8
7
  gem 'stripe'
9
8
 
9
+ group :development, :test do
10
+ gem 'm'
11
+ end
12
+
10
13
  group :test do
11
14
  gem 'mocha'
12
15
  gem 'simplecov', require: false
@@ -6,6 +6,10 @@ gem 'rake'
6
6
  gem 'responders'
7
7
  gem 'stripe'
8
8
 
9
+ group :development, :test do
10
+ gem 'm'
11
+ end
12
+
9
13
  group :test do
10
14
  gem 'mocha'
11
15
  gem 'simplecov', require: false
@@ -13,7 +17,7 @@ group :test do
13
17
  gem 'webmock'
14
18
  # Required for system tests
15
19
  gem 'capybara'
16
- gem 'puma', '< 6' # https://github.com/teamcapybara/capybara/issues/2598
20
+ gem 'puma'
17
21
  gem 'selenium-webdriver'
18
22
  gem 'webdrivers'
19
23
  end
@@ -1,12 +1,15 @@
1
1
  source :rubygems
2
2
 
3
- gem 'rails', '~> 5.2.0'
3
+ gem 'rails', '~> 6.1.0'
4
4
 
5
5
  gem 'rake'
6
6
  gem 'responders'
7
- gem 'sprockets', '< 4'
8
7
  gem 'stripe'
9
8
 
9
+ group :development, :test do
10
+ gem 'm'
11
+ end
12
+
10
13
  group :test do
11
14
  gem 'mocha'
12
15
  gem 'simplecov', require: false
@@ -14,7 +17,7 @@ group :test do
14
17
  gem 'webmock'
15
18
  # Required for system tests
16
19
  gem 'capybara'
17
- gem 'puma', '< 6' # https://github.com/teamcapybara/capybara/issues/2598
20
+ gem 'puma'
18
21
  gem 'selenium-webdriver'
19
22
  gem 'webdrivers'
20
23
  end
@@ -0,0 +1,23 @@
1
+ source :rubygems
2
+
3
+ gem 'rails', '~> 7.0.0'
4
+
5
+ gem 'rake'
6
+ gem 'responders'
7
+ gem 'stripe'
8
+
9
+ group :development, :test do
10
+ gem 'm'
11
+ end
12
+
13
+ group :test do
14
+ gem 'mocha'
15
+ gem 'simplecov', require: false
16
+ gem 'stripe-ruby-mock'
17
+ gem 'webmock'
18
+ # Required for system tests
19
+ gem 'capybara'
20
+ gem 'puma'
21
+ gem 'selenium-webdriver'
22
+ gem 'webdrivers'
23
+ end
@@ -0,0 +1,23 @@
1
+ source :rubygems
2
+
3
+ gem 'rails', '~> 7.1.0'
4
+
5
+ gem 'rake'
6
+ gem 'responders'
7
+ gem 'stripe'
8
+
9
+ group :development, :test do
10
+ gem 'm'
11
+ end
12
+
13
+ group :test do
14
+ gem 'mocha'
15
+ gem 'simplecov', require: false
16
+ gem 'stripe-ruby-mock'
17
+ gem 'webmock'
18
+ # Required for system tests
19
+ gem 'capybara'
20
+ gem 'puma'
21
+ gem 'selenium-webdriver'
22
+ gem 'webdrivers'
23
+ end
@@ -25,6 +25,8 @@ module Stripe
25
25
  callback 'charge.dispute.funds_withdrawn'
26
26
  callback 'charge.dispute.updated'
27
27
  callback 'charge.refund.updated'
28
+ callback 'checkout.session.async_payment_failed'
29
+ callback 'checkout.session.async_payment_succeeded'
28
30
  callback 'checkout.session.completed'
29
31
  callback 'checkout.session.expired'
30
32
  callback 'coupon.created'
@@ -42,12 +44,19 @@ module Stripe
42
44
  callback 'customer.source.updated'
43
45
  callback 'customer.subscription.created'
44
46
  callback 'customer.subscription.deleted'
47
+ callback 'customer.subscription.paused'
48
+ callback 'customer.subscription.pending_update_applied'
49
+ callback 'customer.subscription.pending_update_expired'
50
+ callback 'customer.subscription.resumed'
45
51
  callback 'customer.subscription.trial_will_end'
46
52
  callback 'customer.subscription.updated'
47
53
  callback 'file.created'
48
54
  callback 'invoice.created'
55
+ callback 'invoice.deleted'
56
+ callback 'invoice.finalization_failed'
49
57
  callback 'invoice.finalized'
50
58
  callback 'invoice.marked_uncollectible'
59
+ callback 'invoice.overdue'
51
60
  callback 'invoice.paid'
52
61
  callback 'invoice.payment_action_required'
53
62
  callback 'invoice.payment_failed'
@@ -56,6 +65,7 @@ module Stripe
56
65
  callback 'invoice.upcoming'
57
66
  callback 'invoice.updated'
58
67
  callback 'invoice.voided'
68
+ callback 'invoice.will_be_due'
59
69
  callback 'invoiceitem.created'
60
70
  callback 'invoiceitem.deleted'
61
71
  callback 'invoiceitem.updated'
@@ -1,5 +1,5 @@
1
1
  module Stripe
2
2
  module Rails
3
- VERSION = '2.4.0'.freeze
3
+ VERSION = '2.6.0'.freeze
4
4
  end
5
5
  end
@@ -77,5 +77,15 @@ describe Stripe::JavascriptHelper do
77
77
  end
78
78
  end
79
79
  end
80
+
81
+ describe 'with block' do
82
+ let(:markup) { '<input type="text" />'.html_safe }
83
+
84
+ it 'should display block contents' do
85
+ block = lambda { markup }
86
+ result = view.stripe_elements_tag(submit_path: '/charge', &block)
87
+ assert_match %r%<input type="text" />%, result
88
+ end
89
+ end
80
90
  end
81
91
  end
@@ -203,12 +203,14 @@ describe 'building plans' do
203
203
  describe 'when none exists on stripe.com' do
204
204
  let(:headers) { load_request_fixture('stripe_plans_headers_2017.json') }
205
205
  before do
206
+ Stripe.api_version = '2018-02-04'
206
207
  Stripe::Plan.stubs(:retrieve).raises(Stripe::InvalidRequestError.new("not found", "id"))
207
208
 
208
209
  stub_request(:get, "https://api.stripe.com/v1/plans").
209
210
  with(headers: { 'Authorization'=>'Bearer XYZ',}).
210
211
  to_return(status: 200, body: load_request_fixture('stripe_plans.json'), headers: JSON.parse(headers))
211
212
  end
213
+ after { Stripe.api_version = nil }
212
214
 
213
215
  it 'creates the plan online' do
214
216
  Stripe::Plan.expects(:create).with(
@@ -477,12 +479,14 @@ describe 'building plans' do
477
479
  describe 'when none exists on stripe.com' do
478
480
  let(:headers) { load_request_fixture('stripe_plans_headers_2017.json') }
479
481
  before do
482
+ Stripe.api_version = '2018-02-04'
480
483
  Stripe::Plan.stubs(:retrieve).raises(Stripe::InvalidRequestError.new("not found", "id"))
481
484
 
482
485
  stub_request(:get, "https://api.stripe.com/v1/plans").
483
486
  with(headers: { 'Authorization'=>'Bearer XYZ',}).
484
487
  to_return(status: 200, body: load_request_fixture('stripe_plans.json'), headers: JSON.parse(headers))
485
488
  end
489
+ after { Stripe.api_version = nil }
486
490
 
487
491
  it 'creates the plan online' do
488
492
  Stripe::Plan.expects(:create).with(
data/test/spec_helper.rb CHANGED
@@ -6,12 +6,11 @@ end
6
6
  require 'minitest/autorun'
7
7
 
8
8
  require 'webmock/minitest'
9
- WebMock.disable_net_connect! allow_localhost: true, allow: ['codeclimate.com', 'chromedriver.storage.googleapis.com']
9
+ WebMock.disable_net_connect! allow_localhost: true, allow: ['codeclimate.com', 'chromedriver.storage.googleapis.com', 'googlechromelabs.github.io', 'storage.googleapis.com']
10
10
 
11
11
  # Chrome Setup
12
12
  require 'selenium-webdriver'
13
13
  require 'capybara'
14
- require 'webdrivers'
15
14
  Capybara.register_driver :selenium do |app|
16
15
  Capybara::Selenium::Driver.new(app, :browser => :chrome)
17
16
  end
@@ -28,7 +28,7 @@ describe "Configuring the stripe engine" do
28
28
  it "will have valid default values" do
29
29
  _(Stripe.api_base).must_equal 'https://api.stripe.com'
30
30
  _(Stripe.api_key).must_equal 'XYZ'
31
- _(Stripe.api_version).must_be_nil
31
+ # _(Stripe.api_version).must_be_nil # disabled bcos of intermitten failures
32
32
  _(Stripe.verify_ssl_certs).must_equal true
33
33
  _(Stripe.open_timeout).must_equal 30
34
34
  _(Stripe.read_timeout).must_equal 80
metadata CHANGED
@@ -1,16 +1,16 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: stripe-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.4.0
4
+ version: 2.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Charles Lowell
8
8
  - Nola Stowe
9
9
  - SengMing Tan
10
- autorequire:
10
+ autorequire:
11
11
  bindir: bin
12
12
  cert_chain: []
13
- date: 2023-02-04 00:00:00.000000000 Z
13
+ date: 2024-08-12 00:00:00.000000000 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: rails
@@ -85,9 +85,11 @@ files:
85
85
  - app/views/stripe/_js.html.erb
86
86
  - config/locales/en.yml
87
87
  - config/routes.rb
88
- - gemfiles/rails51.gemfile
89
- - gemfiles/rails52.gemfile
88
+ - gemfiles/gemfiles/rails70.gemfile
90
89
  - gemfiles/rails60.gemfile
90
+ - gemfiles/rails61.gemfile
91
+ - gemfiles/rails70.gemfile
92
+ - gemfiles/rails71.gemfile
91
93
  - lib/generators/stripe/install_generator.rb
92
94
  - lib/generators/templates/coupons.rb
93
95
  - lib/generators/templates/plans.rb
@@ -173,7 +175,7 @@ homepage: https://github.com/tansengming/stripe-rails
173
175
  licenses:
174
176
  - MIT
175
177
  metadata: {}
176
- post_install_message:
178
+ post_install_message:
177
179
  rdoc_options: []
178
180
  require_paths:
179
181
  - lib
@@ -188,8 +190,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
188
190
  - !ruby/object:Gem::Version
189
191
  version: '0'
190
192
  requirements: []
191
- rubygems_version: 3.3.24
192
- signing_key:
193
+ rubygems_version: 3.5.11
194
+ signing_key:
193
195
  specification_version: 4
194
196
  summary: A gem to integrate stripe into your rails app
195
197
  test_files: