gon 5.0.4 → 5.1.0

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of gon might be problematic. Click here for more details.

checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 4c821696b6d4a8ba7c715ac87e8fc7e34e7696fa
4
- data.tar.gz: 0cd052df88b75160786d86929a13d62947c5b10f
3
+ metadata.gz: c117fb1e03d8437b1cb22592a559d8c230bffdd6
4
+ data.tar.gz: e20b61c0441603d5328c54c00b7b16b69edba560
5
5
  SHA512:
6
- metadata.gz: bf0d8b204ab3c103289c89338f7b98534f2c8da68fb18af90ebd9c69497afef02bddedca4865fdccea8cc32395f4464b41d475d37941143e76257285f8ab2e91
7
- data.tar.gz: ba5a6cd137050b52b066261e756ff6176ba1285d393a0d1291a33e464e1928576897131ce8e9a1fdb29afb09c772aa22c0be7b821f57646dd36eced63fb13785
6
+ metadata.gz: eeb234b14c08b522304e7dc5578b9ac1b4d900f594dd64ad12b35475d8700132b81caec1b534250d41974b891773f32ed93af0cadcc08a781c78d8334946bbeb
7
+ data.tar.gz: a17e689b89609a7fd35202d3c3d9c306cc88792da71632c6b9423a651a1232652cd493d27760287b45f779fc123f459730434a283a0ed53967451f16b1490ff4
@@ -3,6 +3,7 @@ rvm:
3
3
  - 1.9.3
4
4
  - 2.0.0
5
5
  - 2.1.0
6
+ - 2.1.1
6
7
  - jruby-19mode # JRuby in 1.9 mode
7
8
  - rbx
8
9
  matrix:
@@ -1,5 +1,10 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## 5.1.0
4
+
5
+ * Many fixes https://github.com/gazay/gon/compare/91845f3f0debd0cb8fa569aad65f5dc40a7e28e5...8dc7400fbb83ba5a086bd36c76342a393690d53f
6
+ * Thanks to @Silex, @kilefritz, @irobayna, @kyrylo, @randoum, @jackquack, @tuvistavie, @Strech for awesome commits and help!
7
+
3
8
  ## 5.0.4
4
9
 
5
10
  * Fix check for get and assign variables for Gon.global
data/README.md CHANGED
@@ -59,10 +59,9 @@ gem line to your Gemfile and do the following:
59
59
 
60
60
  3. profit?
61
61
 
62
- With `gon.watch` feature you can easily renew data in gon variables!
63
- Just pass option `:watch => true` to `include_gon` method and call
64
- `gon.watch` from your js file. It's super useful in modern web
65
- applications!
62
+ With the `gon.watch` feature you can easily renew data in gon variables!
63
+ Simply call `gon.watch` from your js file. It's super useful
64
+ in modern web applications!
66
65
 
67
66
  ## Usage
68
67
 
@@ -114,8 +113,7 @@ alert(gon.your_hash)
114
113
  ## gon.watch - renew your data easily!
115
114
 
116
115
  You can use gon for renewing your data without reloading pages and
117
- writing long js functions! It's really
118
- great for some live values.
116
+ writing long js functions! It's really great for some live values.
119
117
 
120
118
  Supports `gon.watch.rabl` and `gon.watch.jbuilder` usage.
121
119
 
@@ -1,4 +1,3 @@
1
- # -*- encoding: utf-8 -*-
2
1
  lib = File.expand_path('../lib', __FILE__)
3
2
  $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
3
  require 'gon/version'
@@ -21,7 +20,9 @@ Gem::Specification.new do |s|
21
20
  s.executables = `git ls-files -- bin/*`.split("\n").map { |f| File.basename(f) }
22
21
  s.require_paths = ['lib']
23
22
  s.add_dependency 'actionpack', '>= 2.3.0'
23
+ s.add_dependency 'request_store', '>= 1.0.5'
24
24
  s.add_dependency 'json'
25
+ s.add_dependency 'oj' unless RUBY_PLATFORM =~ /java/
25
26
  s.add_development_dependency 'rabl'
26
27
  s.add_development_dependency 'rabl-rails'
27
28
  s.add_development_dependency 'rspec'
data/lib/gon.rb CHANGED
@@ -1,5 +1,7 @@
1
+ require 'request_store'
1
2
  require 'action_view'
2
3
  require 'action_controller'
4
+
3
5
  require 'gon/base'
4
6
  require 'gon/global'
5
7
  require 'gon/watch'
@@ -8,6 +10,19 @@ require 'gon/helpers'
8
10
  require 'gon/escaper'
9
11
  require 'gon/rabl'
10
12
  require 'gon/jbuilder'
13
+ require 'gon/json_dumper'
14
+
15
+ # NOTE : JRuby greater than 1.7 doesn't support C-extensions
16
+ if RUBY_PLATFORM =~ /java/
17
+ require 'gon/json_dumper/active_support'
18
+ else
19
+ require 'gon/json_dumper/oj'
20
+ end
21
+
22
+ # NOTE : ActionDispatch::Request#uuid appears only in Rails 3.2.1
23
+ unless ActionDispatch::Request.public_instance_methods.include?(:uuid)
24
+ require 'gon/compatibility/old_rails'
25
+ end
11
26
 
12
27
  class Gon
13
28
  class << self
@@ -77,7 +92,7 @@ class Gon
77
92
  private
78
93
 
79
94
  def current_gon
80
- Thread.current['gon']
95
+ RequestStore.store[:gon]
81
96
  end
82
97
 
83
98
  def store_builder_data(builder, data, options)
@@ -41,7 +41,7 @@ class Gon
41
41
  private
42
42
 
43
43
  def current_gon
44
- Thread.current[:gon]
44
+ RequestStore.store[:gon]
45
45
  end
46
46
 
47
47
  def parse_options(options)
@@ -49,7 +49,7 @@ class Gon
49
49
  need_tag = options[:need_tag].nil? || options[:need_tag]
50
50
  cameled = options[:camel_case]
51
51
  camel_depth = options[:camel_depth] || 1
52
- watch = options[:watch]
52
+ watch = options[:watch] || !Gon.watch.all_variables.empty?
53
53
  tag = need_tag
54
54
  type = options[:type].nil? || options[:type]
55
55
  cdata = options[:cdata].nil? || options[:cdata]
@@ -73,17 +73,23 @@ class Gon
73
73
  end
74
74
 
75
75
  def to_json(value, camel_depth)
76
- # starts at two because 1 is the root key which is converted in the formatted_data method
77
- convert_hash_keys(value, 2, camel_depth).to_json
76
+ # starts at 2 because 1 is the root key which is converted in the formatted_data method
77
+ Gon::JsonDumper.dump convert_hash_keys(value, 2, camel_depth)
78
78
  end
79
79
 
80
80
  def convert_hash_keys(value, current_depth, max_depth)
81
81
  return value if current_depth > (max_depth.is_a?(Symbol) ? 1000 : max_depth)
82
- return value unless value.is_a? Hash
83
82
 
84
- Hash[value.map { |k, v|
85
- [ k.to_s.camelize(:lower), convert_hash_keys(v, current_depth + 1, max_depth) ]
86
- }]
83
+ case value
84
+ when Hash
85
+ Hash[value.map { |k, v|
86
+ [ k.to_s.camelize(:lower), convert_hash_keys(v, current_depth + 1, max_depth) ]
87
+ }]
88
+ when Enumerable
89
+ value.map { |v| convert_hash_keys(v, current_depth + 1, max_depth) }
90
+ else
91
+ value
92
+ end
87
93
  end
88
94
 
89
95
  def gon_variables
@@ -0,0 +1,11 @@
1
+ require 'securerandom'
2
+
3
+ class Gon
4
+ module GonHelpers
5
+ private
6
+
7
+ def gon_request_uuid
8
+ @gon_request_uuid ||= SecureRandom.uuid
9
+ end
10
+ end
11
+ end
@@ -7,7 +7,7 @@ class Gon
7
7
 
8
8
  def escape_unicode(javascript)
9
9
  if javascript
10
- result = javascript.gsub(/\\u2028/u, '&#x2028;').gsub(/(<\/)/u, '\u003C/')
10
+ result = escape_line_separator(escape_special_chars javascript)
11
11
  javascript.html_safe? ? result.html_safe : result
12
12
  end
13
13
  end
@@ -25,6 +25,16 @@ class Gon
25
25
  end
26
26
  end
27
27
 
28
+ private
29
+
30
+ def escape_line_separator(javascript)
31
+ javascript.gsub(/\\u2028/u, '&#x2028;')
32
+ end
33
+
34
+ def escape_special_chars(javascript)
35
+ javascript.gsub(/(\<)/u, '\u003c').gsub(/(\>)/u, '\u003e')
36
+ end
37
+
28
38
  end
29
39
  end
30
40
  end
@@ -28,7 +28,7 @@ class Gon
28
28
  end
29
29
 
30
30
  def current_gon
31
- Thread.current['gon']
31
+ RequestStore.store[:gon]
32
32
  end
33
33
 
34
34
  end
@@ -36,32 +36,29 @@ class Gon
36
36
 
37
37
  module GonHelpers
38
38
 
39
- def self.included base
40
- base.send(:include, InstanceMethods)
39
+ def gon
40
+ if wrong_gon_request?
41
+ gon_request = Request.new(env)
42
+ gon_request.id = gon_request_uuid
43
+ RequestStore.store[:gon] = gon_request
44
+ end
45
+ Gon
41
46
  end
42
47
 
43
- module InstanceMethods
44
-
45
- def gon
46
- if wrong_gon_request?
47
- gon_request = Request.new(env)
48
- gon_request.id = request.uuid
49
- Thread.current['gon'] = gon_request
50
- end
51
- Gon
52
- end
48
+ private
53
49
 
54
- private
55
-
56
- def wrong_gon_request?
57
- current_gon.blank? || current_gon.id != request.uuid
58
- end
50
+ def wrong_gon_request?
51
+ current_gon.blank? || current_gon.id != gon_request_uuid
52
+ end
59
53
 
60
- def current_gon
61
- Thread.current['gon']
62
- end
54
+ def current_gon
55
+ RequestStore.store[:gon]
56
+ end
63
57
 
58
+ def gon_request_uuid
59
+ request.uuid
64
60
  end
61
+
65
62
  end
66
63
  end
67
64
 
@@ -0,0 +1,7 @@
1
+ class Gon
2
+ module JsonDumper
3
+ def self.dump(object)
4
+ raise NotImplementedError
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,7 @@
1
+ class Gon
2
+ module JsonDumper
3
+ def self.dump(object)
4
+ object.to_json
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,16 @@
1
+ require 'oj'
2
+
3
+ class Gon
4
+ module JsonDumper
5
+ def self.dump(object)
6
+ Oj.dump(object, mode: :compat, time_format: :ruby)
7
+ end
8
+ end
9
+
10
+ # NOTE : If we are using Oj, gsub works only with \u, not \\u
11
+ module Escaper
12
+ def self.escape_line_separator(javascript)
13
+ javascript.gsub(/\u2028/u, '&#x2028;')
14
+ end
15
+ end
16
+ end
@@ -43,7 +43,7 @@ class Gon
43
43
  locals ||= {}
44
44
  source = File.read(rabl_path)
45
45
  include_helpers
46
- rabl_engine = ::Rabl::Engine.new(source, :format => 'json')
46
+ rabl_engine = ::Rabl::Engine.new(source, :format => 'json', :template => rabl_path)
47
47
  output = rabl_engine.render(controller, locals)
48
48
  JSON.parse(output)
49
49
  end
@@ -6,11 +6,11 @@ class Gon
6
6
  end
7
7
 
8
8
  def env
9
- @request_env if defined? @request_env
9
+ @request_env
10
10
  end
11
11
 
12
12
  def id
13
- @request_id if defined? @request_id
13
+ @request_id
14
14
  end
15
15
 
16
16
  def id=(request_id)
@@ -1,3 +1,3 @@
1
1
  class Gon
2
- VERSION = '5.0.4'
2
+ VERSION = '5.1.0'
3
3
  end
@@ -5,7 +5,7 @@ class Gon
5
5
  JS_FUNCTION = File.read(File.expand_path('../../../js/watch.js', __FILE__))
6
6
 
7
7
  def render
8
- JS_FUNCTION + "window.gon.watchedVariables=#{all_variables.to_json};"
8
+ JS_FUNCTION + "window.gon.watchedVariables=#{Gon::JsonDumper.dump all_variables};"
9
9
  end
10
10
 
11
11
  def all_variables
@@ -98,10 +98,11 @@ describe Gon do
98
98
 
99
99
  it 'outputs correct js with a script string' do
100
100
  Gon.str = %q(</script><script>alert('!')</script>)
101
+ escaped_str = "\\u003c/script\\u003e\\u003cscript\\u003ealert('!')\\u003c/script\\u003e"
101
102
  expect(@base.include_gon).to eq('<script type="text/javascript">' +
102
103
  "\n//<![CDATA[\n" +
103
104
  'window.gon={};' +
104
- %q(gon.str="\u003C/script><script>alert('!')\u003C/script>";) +
105
+ %Q(gon.str="#{escaped_str}";) +
105
106
  "\n//]]>\n" +
106
107
  '</script>')
107
108
  end
@@ -142,6 +143,18 @@ describe Gon do
142
143
  )
143
144
  end
144
145
 
146
+ it 'outputs correct js for an array with camel_depth = :recursive' do
147
+ Gon.test_hash = { test_depth_one: [{ test_depth_two: 1 }, { test_depth_two: 2 }] }
148
+ expect(@base.include_gon(camel_case: true, camel_depth: :recursive)).to eq( \
149
+ '<script type="text/javascript">' +
150
+ "\n//<![CDATA[\n" +
151
+ 'window.gon={};' +
152
+ 'gon.testHash={"testDepthOne":[{"testDepthTwo":1},{"testDepthTwo":2}]};' +
153
+ "\n//]]>\n" +
154
+ '</script>'
155
+ )
156
+ end
157
+
145
158
  it 'outputs correct js with an integer and without tag' do
146
159
  Gon.int = 1
147
160
  expect(@base.include_gon(need_tag: false)).to eq( \
@@ -77,10 +77,11 @@ describe Gon::Global do
77
77
 
78
78
  it 'outputs correct js with a script string' do
79
79
  Gon.global.str = %q(</script><script>alert('!')</script>)
80
+ escaped_str = "\"\\u003c/script\\u003e\\u003cscript\\u003ealert('!')\\u003c/script\\u003e\""
80
81
  expect(@base.include_gon).to eq("<script type=\"text/javascript\">" +
81
82
  "\n//<![CDATA[\n" +
82
83
  "window.gon={};" +
83
- "gon.global={\"str\":\"\\u003C/script><script>alert('!')\\u003C/script>\"};" +
84
+ "gon.global={\"str\":#{escaped_str}};" +
84
85
  "\n//]]>\n" +
85
86
  "</script>")
86
87
  end
@@ -40,7 +40,8 @@ end
40
40
 
41
41
  RSpec.configure do |config|
42
42
  config.before(:each) do
43
- @request = Thread.current['gon'] = Gon::Request.new({})
43
+ RequestStore.store[:gon] = Gon::Request.new({})
44
+ @request = RequestStore.store[:gon]
44
45
  allow(Gon).to receive(:current_gon).and_return(@request)
45
46
  end
46
47
  end
metadata CHANGED
@@ -1,111 +1,139 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: gon
3
3
  version: !ruby/object:Gem::Version
4
- version: 5.0.4
4
+ version: 5.1.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - gazay
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2014-02-14 00:00:00.000000000 Z
11
+ date: 2014-06-30 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: actionpack
15
15
  requirement: !ruby/object:Gem::Requirement
16
16
  requirements:
17
- - - ">="
17
+ - - '>='
18
18
  - !ruby/object:Gem::Version
19
19
  version: 2.3.0
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
- - - ">="
24
+ - - '>='
25
25
  - !ruby/object:Gem::Version
26
26
  version: 2.3.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: request_store
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: 1.0.5
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: 1.0.5
27
41
  - !ruby/object:Gem::Dependency
28
42
  name: json
29
43
  requirement: !ruby/object:Gem::Requirement
30
44
  requirements:
31
- - - ">="
45
+ - - '>='
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - '>='
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: oj
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - '>='
32
60
  - !ruby/object:Gem::Version
33
61
  version: '0'
34
62
  type: :runtime
35
63
  prerelease: false
36
64
  version_requirements: !ruby/object:Gem::Requirement
37
65
  requirements:
38
- - - ">="
66
+ - - '>='
39
67
  - !ruby/object:Gem::Version
40
68
  version: '0'
41
69
  - !ruby/object:Gem::Dependency
42
70
  name: rabl
43
71
  requirement: !ruby/object:Gem::Requirement
44
72
  requirements:
45
- - - ">="
73
+ - - '>='
46
74
  - !ruby/object:Gem::Version
47
75
  version: '0'
48
76
  type: :development
49
77
  prerelease: false
50
78
  version_requirements: !ruby/object:Gem::Requirement
51
79
  requirements:
52
- - - ">="
80
+ - - '>='
53
81
  - !ruby/object:Gem::Version
54
82
  version: '0'
55
83
  - !ruby/object:Gem::Dependency
56
84
  name: rabl-rails
57
85
  requirement: !ruby/object:Gem::Requirement
58
86
  requirements:
59
- - - ">="
87
+ - - '>='
60
88
  - !ruby/object:Gem::Version
61
89
  version: '0'
62
90
  type: :development
63
91
  prerelease: false
64
92
  version_requirements: !ruby/object:Gem::Requirement
65
93
  requirements:
66
- - - ">="
94
+ - - '>='
67
95
  - !ruby/object:Gem::Version
68
96
  version: '0'
69
97
  - !ruby/object:Gem::Dependency
70
98
  name: rspec
71
99
  requirement: !ruby/object:Gem::Requirement
72
100
  requirements:
73
- - - ">="
101
+ - - '>='
74
102
  - !ruby/object:Gem::Version
75
103
  version: '0'
76
104
  type: :development
77
105
  prerelease: false
78
106
  version_requirements: !ruby/object:Gem::Requirement
79
107
  requirements:
80
- - - ">="
108
+ - - '>='
81
109
  - !ruby/object:Gem::Version
82
110
  version: '0'
83
111
  - !ruby/object:Gem::Dependency
84
112
  name: jbuilder
85
113
  requirement: !ruby/object:Gem::Requirement
86
114
  requirements:
87
- - - ">="
115
+ - - '>='
88
116
  - !ruby/object:Gem::Version
89
117
  version: '0'
90
118
  type: :development
91
119
  prerelease: false
92
120
  version_requirements: !ruby/object:Gem::Requirement
93
121
  requirements:
94
- - - ">="
122
+ - - '>='
95
123
  - !ruby/object:Gem::Version
96
124
  version: '0'
97
125
  - !ruby/object:Gem::Dependency
98
126
  name: rake
99
127
  requirement: !ruby/object:Gem::Requirement
100
128
  requirements:
101
- - - ">="
129
+ - - '>='
102
130
  - !ruby/object:Gem::Version
103
131
  version: '0'
104
132
  type: :development
105
133
  prerelease: false
106
134
  version_requirements: !ruby/object:Gem::Requirement
107
135
  requirements:
108
- - - ">="
136
+ - - '>='
109
137
  - !ruby/object:Gem::Version
110
138
  version: '0'
111
139
  description: If you need to send some data to your js files and you don't want to
@@ -116,8 +144,8 @@ executables: []
116
144
  extensions: []
117
145
  extra_rdoc_files: []
118
146
  files:
119
- - ".gitignore"
120
- - ".travis.yml"
147
+ - .gitignore
148
+ - .travis.yml
121
149
  - CHANGELOG.md
122
150
  - Gemfile
123
151
  - LICENSE
@@ -131,10 +159,14 @@ files:
131
159
  - js/watch.js
132
160
  - lib/gon.rb
133
161
  - lib/gon/base.rb
162
+ - lib/gon/compatibility/old_rails.rb
134
163
  - lib/gon/escaper.rb
135
164
  - lib/gon/global.rb
136
165
  - lib/gon/helpers.rb
137
166
  - lib/gon/jbuilder.rb
167
+ - lib/gon/json_dumper.rb
168
+ - lib/gon/json_dumper/active_support.rb
169
+ - lib/gon/json_dumper/oj.rb
138
170
  - lib/gon/rabl.rb
139
171
  - lib/gon/request.rb
140
172
  - lib/gon/version.rb
@@ -168,17 +200,17 @@ require_paths:
168
200
  - lib
169
201
  required_ruby_version: !ruby/object:Gem::Requirement
170
202
  requirements:
171
- - - ">="
203
+ - - '>='
172
204
  - !ruby/object:Gem::Version
173
205
  version: '0'
174
206
  required_rubygems_version: !ruby/object:Gem::Requirement
175
207
  requirements:
176
- - - ">="
208
+ - - '>='
177
209
  - !ruby/object:Gem::Version
178
210
  version: '0'
179
211
  requirements: []
180
212
  rubyforge_project: gon
181
- rubygems_version: 2.2.0
213
+ rubygems_version: 2.0.14
182
214
  signing_key:
183
215
  specification_version: 4
184
216
  summary: Get your Rails variables in your JS