repost 0.2.9 → 0.3.4

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: c596318ae45ed6b77e768fc7eb3db94c21af30e4f92878421ac984ea7da664ee
4
- data.tar.gz: 990b52812aa4e79247eaf99180535925cd4cf9cbd9a962fdcba96afb8693b47e
3
+ metadata.gz: b3f86c0a5b05ecd0335c0a471d9bfb6bc838c290c2cfbab6f1d2c4e411c60a5c
4
+ data.tar.gz: 9f2e280d22ee448a6f99e30fe410e576af78c96966877d0be90df7e441ae53ac
5
5
  SHA512:
6
- metadata.gz: 761da6f4e436e85a1dc62c8446010a8465a18e7584df595b19176b85624a1459a38cda391b7aee2363b26509bcfbd04c15468bd7e0c832edb960d730b0d0d2c5
7
- data.tar.gz: ed1c4a2c9350388846f9bafac08aac3439f98fa2802a69d6dc92e53d8a16b463d1823ffd57eee2bee0242f21e4a1818149139689031d91388cadbe666e09584c
6
+ metadata.gz: 45d255fb124026befb181c204c7914b260f5f9cfbc1f149072d5063e70e89d3e26d20861fd410a437edec30adc3d8e1066ff7149a3ac63c78b731cb9d958f9c2
7
+ data.tar.gz: ab0c1712df4aabf366ebf02c0067459d5102db5231ca06b5b96af72735dadc4b6ceed8ca525b04788a5593ed8124e0c943baccc60f959dbaff68eaef353e1b6f
@@ -1,16 +1,22 @@
1
- if defined?(Rails)
2
- class ::ActionController::Base
1
+ if defined?(Rails) && defined?(ActiveSupport)
2
+ ActiveSupport.on_load(:action_controller) do
3
+ class ::ActionController::Base
3
4
 
4
- def repost(url, params: {}, options: {})
5
- render html: Repost::Senpai.perform(
6
- url,
7
- params: params,
8
- options: options.reverse_merge(authenticity_token: form_authenticity_token)
9
- ).html_safe
10
- end
5
+ def repost(url, params: {}, options: {})
6
+ authenticity_token = form_authenticity_token if ['auto', :auto].include?(options[:authenticity_token])
7
+ render html: Repost::Senpai.perform(
8
+ url,
9
+ params: params,
10
+ options: options.merge({
11
+ authenticity_token: authenticity_token,
12
+ autosubmit_nonce: content_security_policy_nonce,
13
+ }.compact)
14
+ ).html_safe
15
+ end
11
16
 
12
- alias :redirect_post :repost
17
+ alias :redirect_post :repost
13
18
 
19
+ end
14
20
  end
15
21
  end
16
22
 
@@ -12,6 +12,7 @@ module Repost
12
12
  @charset = options.fetch(:charset, DEFAULT_CHARSET)
13
13
  @form_id = options.fetch(:form_id, generated_form_id)
14
14
  @autosubmit = options.fetch(:autosubmit, true)
15
+ @autosubmit_nonce = options.fetch(:autosubmit_nonce, nil)
15
16
  @section_classes = options.dig(:decor, :section, :classes)
16
17
  @section_html = options.dig(:decor, :section, :html)
17
18
  @submit_classes = options.dig(:decor, :submit, :classes)
@@ -31,7 +32,7 @@ module Repost
31
32
 
32
33
  attr_reader :url, :params, :options, :method, :form_id, :autosubmit,
33
34
  :section_classes, :section_html, :submit_classes,
34
- :submit_text, :authenticity_token, :charset
35
+ :submit_text, :authenticity_token, :charset, :autosubmit_nonce
35
36
 
36
37
  def form_head
37
38
  "<form id='#{form_id}' action='#{url}' method='#{method}' accept-charset='#{charset}'>"
@@ -39,12 +40,22 @@ module Repost
39
40
 
40
41
  def form_body
41
42
  inputs = params.map do |key, value|
42
- "<input type='hidden' name='#{key}' value='#{value}'>"
43
+ form_input(key, value)
43
44
  end
44
45
  inputs.unshift(csrf_token) if authenticity_token
45
46
  inputs.join
46
47
  end
47
48
 
49
+ def form_input(key, value)
50
+ if value.is_a?(Hash)
51
+ value.map do |inner_key, inner_value|
52
+ form_input("#{key}[#{inner_key}]", inner_value)
53
+ end.join
54
+ else
55
+ "<input type='hidden' name='#{key}' value='#{value}'>"
56
+ end
57
+ end
58
+
48
59
  def form_footer
49
60
  "</form>"
50
61
  end
@@ -71,7 +82,8 @@ module Repost
71
82
  end
72
83
 
73
84
  def auto_submit_script
74
- "<script>
85
+ nonce_attr = %Q( nonce="#{autosubmit_nonce}") if autosubmit_nonce
86
+ "<script#{nonce_attr}>
75
87
  document.getElementById('#{form_id}').submit();
76
88
  </script>"
77
89
  end
@@ -1,3 +1,3 @@
1
1
  module Repost
2
- VERSION = "0.2.9"
2
+ VERSION = "0.3.4"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: repost
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.9
4
+ version: 0.3.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - YaroslavO
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2019-08-14 00:00:00.000000000 Z
11
+ date: 2020-11-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -30,14 +30,14 @@ dependencies:
30
30
  requirements:
31
31
  - - "~>"
32
32
  - !ruby/object:Gem::Version
33
- version: '10.0'
33
+ version: '13.0'
34
34
  type: :development
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
38
  - - "~>"
39
39
  - !ruby/object:Gem::Version
40
- version: '10.0'
40
+ version: '13.0'
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: rspec
43
43
  requirement: !ruby/object:Gem::Requirement
@@ -86,7 +86,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
86
86
  - !ruby/object:Gem::Version
87
87
  version: '0'
88
88
  requirements: []
89
- rubygems_version: 3.0.1
89
+ rubygems_version: 3.0.8
90
90
  signing_key:
91
91
  specification_version: 4
92
92
  summary: Gem implements Redirect using POST method