livefyre 2.0.1 → 2.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG +4 -0
- data/lib/livefyre/api/personalized_stream.rb +6 -6
- data/lib/livefyre/core/network.rb +5 -3
- data/livefyre.gemspec +3 -5
- data/spec/livefyre/core/collection_spec.rb +2 -2
- metadata +10 -11
- data/lib/livefyre/version.rb +0 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: fd28a1df6805abeda6fa8cfb9b0f1c9a9a4733c8
|
4
|
+
data.tar.gz: 54d3b9c90d625514667abff650bda773e541b88a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 2c964de771667b816846aebf5382f63542d4891e69ed7116ed3b9f79117ce365520a3537167311484d84ad5ab7c8702a6c939163591d17ef398ec66fc5b9c463
|
7
|
+
data.tar.gz: 443685c1978d7feb3f6cdcfc0d0d9fb3efbbddc6841f20061786e14d2be160a727348f4a226d61339cf467a2fa3e81eb7df8d6a5fa862b4e73d9e887226613a8
|
data/CHANGELOG
CHANGED
@@ -146,8 +146,8 @@ module Livefyre
|
|
146
146
|
end
|
147
147
|
|
148
148
|
def self.add_subscriptions(network, user_token, topics)
|
149
|
-
|
150
|
-
user_urn = network.get_urn_for_user(user_id)
|
149
|
+
claims, _ = JWT.decode(user_token, network.data.key)
|
150
|
+
user_urn = network.get_urn_for_user(claims['user_id'])
|
151
151
|
|
152
152
|
url = self.base_url(network) + self.user_subscription_path(user_urn)
|
153
153
|
headers = self.get_headers(network, user_token)
|
@@ -161,8 +161,8 @@ module Livefyre
|
|
161
161
|
end
|
162
162
|
|
163
163
|
def self.replace_subscriptions(network, user_token, topics)
|
164
|
-
|
165
|
-
user_urn = network.get_urn_for_user(user_id)
|
164
|
+
claims, _ = JWT.decode(user_token, network.data.key)
|
165
|
+
user_urn = network.get_urn_for_user(claims['user_id'])
|
166
166
|
|
167
167
|
url = self.base_url(network) + self.user_subscription_path(user_urn)
|
168
168
|
headers = self.get_headers(network, user_token)
|
@@ -176,8 +176,8 @@ module Livefyre
|
|
176
176
|
end
|
177
177
|
|
178
178
|
def self.remove_subscriptions(network, user_token, topics)
|
179
|
-
|
180
|
-
user_urn = network.get_urn_for_user(user_id)
|
179
|
+
claims, _ = JWT.decode(user_token, network.data.key)
|
180
|
+
user_urn = network.get_urn_for_user(claims['user_id'])
|
181
181
|
|
182
182
|
url = self.base_url(network) + self.user_subscription_path(user_urn)
|
183
183
|
headers = self.get_headers(network, user_token)
|
@@ -9,6 +9,7 @@ require 'livefyre/validator/network_validator'
|
|
9
9
|
|
10
10
|
module Livefyre
|
11
11
|
class Network
|
12
|
+
ALPHA_DASH_UNDER_DOT_REGEX = /^[a-zZA-Z0-9_\.-]+$/
|
12
13
|
DEFAULT_USER = 'system'
|
13
14
|
DEFAULT_EXPIRES = 86400
|
14
15
|
|
@@ -47,8 +48,9 @@ module Livefyre
|
|
47
48
|
build_user_auth_token(DEFAULT_USER, DEFAULT_USER, DEFAULT_EXPIRES)
|
48
49
|
end
|
49
50
|
|
51
|
+
|
50
52
|
def build_user_auth_token(user_id, display_name, expires)
|
51
|
-
raise ArgumentError,
|
53
|
+
raise ArgumentError, "userId is not alphanumeric. Ensure the following regex pattern is respected #{ALPHA_DASH_UNDER_DOT_REGEX}" if !(user_id =~ ALPHA_DASH_UNDER_DOT_REGEX)
|
52
54
|
raise ArgumentError, 'expires must be a number' if !expires.is_a? Numeric
|
53
55
|
|
54
56
|
JWT.encode({
|
@@ -60,8 +62,8 @@ module Livefyre
|
|
60
62
|
end
|
61
63
|
|
62
64
|
def validate_livefyre_token(lf_token)
|
63
|
-
|
64
|
-
|
65
|
+
claims, _ = JWT.decode(lf_token, @data.key)
|
66
|
+
claims['domain'] == @data.name && claims['user_id'] == DEFAULT_USER && claims['expires'] >= Time.new.to_i
|
65
67
|
end
|
66
68
|
|
67
69
|
def get_site(site_id, site_key)
|
data/livefyre.gemspec
CHANGED
@@ -1,9 +1,7 @@
|
|
1
1
|
# coding: utf-8
|
2
|
-
require File.expand_path('../lib/livefyre/version', __FILE__)
|
3
|
-
|
4
2
|
Gem::Specification.new do |spec|
|
5
3
|
spec.name = 'livefyre'
|
6
|
-
spec.version =
|
4
|
+
spec.version = '2.0.2'
|
7
5
|
spec.authors = ['Livefyre']
|
8
6
|
spec.email = ['tools@livefyre.com']
|
9
7
|
spec.description = %q{Livefyre Ruby utility classes}
|
@@ -22,8 +20,8 @@ Gem::Specification.new do |spec|
|
|
22
20
|
spec.require_paths = ['lib']
|
23
21
|
|
24
22
|
spec.add_runtime_dependency 'rake'
|
25
|
-
spec.add_runtime_dependency 'rest-client', '~> 1.
|
26
|
-
spec.add_runtime_dependency 'jwt', '~>
|
23
|
+
spec.add_runtime_dependency 'rest-client', '~> 1.8', '>= 1.8.0'
|
24
|
+
spec.add_runtime_dependency 'jwt', '~> 1.4', '>= 1.4.1'
|
27
25
|
spec.add_runtime_dependency 'addressable', '~> 2.3', '>= 2.3.6'
|
28
26
|
spec.add_development_dependency 'bundler', '~> 1.7', '>= 1.7.4'
|
29
27
|
spec.add_development_dependency 'rspec', '~> 3.1', '>= 3.1'
|
@@ -33,12 +33,12 @@ describe Livefyre::Collection do
|
|
33
33
|
|
34
34
|
it 'should check type and assign them to the correct field in the collection meta token' do
|
35
35
|
@token = @site.build_reviews_collection(TITLE, ARTICLE_ID, URL).build_collection_meta_token
|
36
|
-
@decoded = JWT.decode(@token, SITE_KEY)
|
36
|
+
@decoded, _ = JWT.decode(@token, SITE_KEY)
|
37
37
|
|
38
38
|
expect(@decoded['type']).to eq('reviews')
|
39
39
|
|
40
40
|
@token = @site.build_blog_collection(TITLE, ARTICLE_ID, URL).build_collection_meta_token
|
41
|
-
@decoded = JWT.decode(@token, SITE_KEY)
|
41
|
+
@decoded, _ = JWT.decode(@token, SITE_KEY)
|
42
42
|
|
43
43
|
expect(@decoded['type']).to eq('liveblog')
|
44
44
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: livefyre
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.0.
|
4
|
+
version: 2.0.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Livefyre
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2015-05-12 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rake
|
@@ -30,40 +30,40 @@ dependencies:
|
|
30
30
|
requirements:
|
31
31
|
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '1.
|
33
|
+
version: '1.8'
|
34
34
|
- - ">="
|
35
35
|
- !ruby/object:Gem::Version
|
36
|
-
version: 1.
|
36
|
+
version: 1.8.0
|
37
37
|
type: :runtime
|
38
38
|
prerelease: false
|
39
39
|
version_requirements: !ruby/object:Gem::Requirement
|
40
40
|
requirements:
|
41
41
|
- - "~>"
|
42
42
|
- !ruby/object:Gem::Version
|
43
|
-
version: '1.
|
43
|
+
version: '1.8'
|
44
44
|
- - ">="
|
45
45
|
- !ruby/object:Gem::Version
|
46
|
-
version: 1.
|
46
|
+
version: 1.8.0
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: jwt
|
49
49
|
requirement: !ruby/object:Gem::Requirement
|
50
50
|
requirements:
|
51
51
|
- - "~>"
|
52
52
|
- !ruby/object:Gem::Version
|
53
|
-
version: '
|
53
|
+
version: '1.4'
|
54
54
|
- - ">="
|
55
55
|
- !ruby/object:Gem::Version
|
56
|
-
version:
|
56
|
+
version: 1.4.1
|
57
57
|
type: :runtime
|
58
58
|
prerelease: false
|
59
59
|
version_requirements: !ruby/object:Gem::Requirement
|
60
60
|
requirements:
|
61
61
|
- - "~>"
|
62
62
|
- !ruby/object:Gem::Version
|
63
|
-
version: '
|
63
|
+
version: '1.4'
|
64
64
|
- - ">="
|
65
65
|
- !ruby/object:Gem::Version
|
66
|
-
version:
|
66
|
+
version: 1.4.1
|
67
67
|
- !ruby/object:Gem::Dependency
|
68
68
|
name: addressable
|
69
69
|
requirement: !ruby/object:Gem::Requirement
|
@@ -196,7 +196,6 @@ files:
|
|
196
196
|
- lib/livefyre/validator/cursor_validator.rb
|
197
197
|
- lib/livefyre/validator/network_validator.rb
|
198
198
|
- lib/livefyre/validator/site_validator.rb
|
199
|
-
- lib/livefyre/version.rb
|
200
199
|
- livefyre.gemspec
|
201
200
|
- spec/livefyre/api/domain_spec.rb
|
202
201
|
- spec/livefyre/api/personalized_stream_spec.rb
|
data/lib/livefyre/version.rb
DELETED