jpush 3.1.1 → 3.2.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/jpush.rb +10 -0
- data/lib/jpush/api_connection_exception.rb +11 -0
- data/lib/jpush/device_client.rb +84 -0
- data/lib/jpush/http_client.rb +32 -18
- data/lib/jpush/jpush_client.rb +81 -7
- data/lib/jpush/model/alias_uids_result.rb +32 -0
- data/lib/jpush/model/exist_result.rb +33 -0
- data/lib/jpush/model/get_messages_result.rb +30 -0
- data/lib/jpush/model/notification/ios_notification.rb +6 -2
- data/lib/jpush/model/options.rb +15 -4
- data/lib/jpush/model/push_payload.rb +6 -0
- data/lib/jpush/model/push_result.rb +4 -4
- data/lib/jpush/model/receiveds_result.rb +3 -3
- data/lib/jpush/model/tag_alias.rb +62 -0
- data/lib/jpush/model/tag_alias_result.rb +32 -0
- data/lib/jpush/model/tag_list_result.rb +32 -0
- data/lib/jpush/model/tag_manager.rb +44 -0
- data/lib/jpush/model/user_result.rb +40 -0
- data/lib/jpush/push_client.rb +18 -4
- data/lib/jpush/report_client.rb +11 -6
- data/lib/jpush/response_wrapper.rb +2 -1
- data/lib/jpush/util/service_helper.rb +3 -2
- metadata +13 -26
- data/.gitignore +0 -18
- data/.project +0 -18
- data/Gemfile +0 -4
- data/LICENSE.txt +0 -339
- data/README.md +0 -75
- data/Rakefile +0 -1
- data/example/push_example.rb +0 -101
- data/example/report_example.rb +0 -18
- data/jpush.gemspec +0 -24
- data/test/alert_override_tests.rb +0 -62
- data/test/audience_tests.rb +0 -169
- data/test/base_remote_tests.rb +0 -27
- data/test/message_tests.rb +0 -49
- data/test/notification_tests.rb +0 -52
- data/test/push_payload_test.rb +0 -58
- data/test/report_function_tests.rb +0 -40
@@ -1,6 +1,6 @@
|
|
1
1
|
module JPush
|
2
2
|
class IOSNotification
|
3
|
-
attr_accessor :alert, :sound, :badge, :extras, :content_available
|
3
|
+
attr_accessor :alert, :sound, :badge, :extras, :content_available, :category
|
4
4
|
def initialize(opts = {})
|
5
5
|
if opts[:badge] != nil
|
6
6
|
@badge = opts[:badge]
|
@@ -15,6 +15,7 @@ module JPush
|
|
15
15
|
@alert = opts[:alert]
|
16
16
|
@extras = opts[:extras]
|
17
17
|
@content_available = opts[:content_available]
|
18
|
+
@category = opts[:category]
|
18
19
|
end
|
19
20
|
|
20
21
|
def toJSON
|
@@ -32,7 +33,10 @@ module JPush
|
|
32
33
|
array['extras'] = @extras
|
33
34
|
end
|
34
35
|
if @content_available != nil then
|
35
|
-
array['content-available'] = content_available
|
36
|
+
array['content-available'] = @content_available
|
37
|
+
end
|
38
|
+
if @category != nil then
|
39
|
+
array['category'] = @category
|
36
40
|
end
|
37
41
|
return array
|
38
42
|
end
|
data/lib/jpush/model/options.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
module JPush
|
2
2
|
class Options
|
3
|
-
attr_accessor :sendno, :time_to_live, :override_msg_id, :apns_production
|
3
|
+
attr_accessor :sendno, :time_to_live, :override_msg_id, :apns_production, :big_push_duration
|
4
4
|
def initialize(opts = {})
|
5
5
|
if opts[:apns_production] != nil
|
6
6
|
@apns_production = opts[:apns_production]
|
@@ -16,6 +16,7 @@ module JPush
|
|
16
16
|
@time_to_live = 86400
|
17
17
|
end
|
18
18
|
@overrride_msg_id = opts[:override_msg_id]
|
19
|
+
@big_push_duration = opts[:big_push_duration]
|
19
20
|
end
|
20
21
|
|
21
22
|
def toJSON
|
@@ -32,20 +33,30 @@ module JPush
|
|
32
33
|
if @apns_production != nil then
|
33
34
|
array['apns_production'] = @apns_production
|
34
35
|
end
|
36
|
+
if @big_push_duration != nil then
|
37
|
+
array['big_push_duration'] = @big_push_duration
|
38
|
+
end
|
35
39
|
return array
|
36
40
|
end
|
37
41
|
|
38
42
|
def self.build(opts = {})
|
39
43
|
options = JPush::Options.new(opts)
|
40
|
-
if options.sendno != nil&&options.sendno < 0
|
44
|
+
if options.sendno != nil && options.sendno < 0
|
41
45
|
raise ArgumentError.new('sendno should be greater than 0.')
|
42
46
|
end
|
43
|
-
if options.override_msg_id != nil&&options.override_msg_id < 0
|
47
|
+
if options.override_msg_id != nil && options.override_msg_id < 0
|
44
48
|
raise ArgumentError.new(' override_msg_id should be greater than 0.')
|
45
49
|
end
|
46
|
-
if options.time_to_live != nil&&options.time_to_live < 0
|
50
|
+
if options.time_to_live != nil && options.time_to_live < 0
|
47
51
|
raise ArgumentError.new('time_to_live should be greater than 0.')
|
48
52
|
end
|
53
|
+
if options.big_push_duration != nil && options.big_push_duration > 1440
|
54
|
+
raise ArgumentError.new('big_push_duration should be less than 1440.')
|
55
|
+
end
|
56
|
+
|
57
|
+
if options.big_push_duration != nil && options.big_push_duration <= 0
|
58
|
+
raise ArgumentError.new('big_push_duration should be greater than 0.')
|
59
|
+
end
|
49
60
|
return options
|
50
61
|
end
|
51
62
|
|
@@ -45,6 +45,12 @@ The object you should build for sending a push.
|
|
45
45
|
if payload.notification.to_s.bytesize + payload.message.to_s.bytesize > 1200
|
46
46
|
raise ArgumentError.new('notfication and message size is longer than 1200 ')
|
47
47
|
end
|
48
|
+
if payload.options == nil
|
49
|
+
options = JPush::Options.build(
|
50
|
+
:time_to_live=> 86400,
|
51
|
+
:apns_production=> false)
|
52
|
+
payload.options = options
|
53
|
+
end
|
48
54
|
return payload
|
49
55
|
end
|
50
56
|
|
@@ -10,9 +10,9 @@ module JPush
|
|
10
10
|
if wrapper.code != 200
|
11
11
|
logger = Logger.new(STDOUT)
|
12
12
|
logger.error('Error response from JPush server. Should review and fix it. ')
|
13
|
-
logger.info(
|
14
|
-
logger.info(
|
15
|
-
raise
|
13
|
+
logger.info("HTTP Status: #{wrapper.code.to_s}")
|
14
|
+
logger.info("Error Message: #{wrapper.error.to_s}")
|
15
|
+
raise JPush::ApiConnectionException.new(wrapper)
|
16
16
|
end
|
17
17
|
content = wrapper.getResponseContent
|
18
18
|
hash = JSON.parse(content)
|
@@ -29,4 +29,4 @@ module JPush
|
|
29
29
|
return array.to_json
|
30
30
|
end
|
31
31
|
end
|
32
|
-
end
|
32
|
+
end
|
@@ -11,9 +11,9 @@ module JPush
|
|
11
11
|
if wrapper.code != 200
|
12
12
|
logger = Logger.new(STDOUT)
|
13
13
|
logger.error('Error response from JPush server. Should review and fix it. ')
|
14
|
-
logger.info('HTTP Status:'
|
15
|
-
logger.info('Error Message'
|
16
|
-
raise
|
14
|
+
logger.info('HTTP Status:' + wrapper.code.to_s)
|
15
|
+
logger.info('Error Message' + wrapper.error.to_s)
|
16
|
+
raise JPush::ApiConnectionException.new(wrapper)
|
17
17
|
end
|
18
18
|
content = wrapper.getResponseContent
|
19
19
|
hash = JSON.parse(content)
|
@@ -0,0 +1,62 @@
|
|
1
|
+
module JPush
|
2
|
+
class TagAlias
|
3
|
+
attr_accessor :add, :remove, :alias ,:tags
|
4
|
+
def initialize(opts = {})
|
5
|
+
if opts[:add] != nil
|
6
|
+
if opts[:add].class == Array
|
7
|
+
@add = opts[:add]
|
8
|
+
else
|
9
|
+
raise ArgumentError.new('add should be array.')
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
if opts[:remove] != nil
|
14
|
+
if opts[:remove].class == Array
|
15
|
+
@remove = opts[:remove]
|
16
|
+
else
|
17
|
+
raise ArgumentError.new('add should be array.')
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
if opts[:alias] != nil
|
22
|
+
@alias = opts[:alias]
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
def toJSON
|
27
|
+
hash = {}
|
28
|
+
tags = {}
|
29
|
+
if @add != nil
|
30
|
+
tags['add'] = @add
|
31
|
+
end
|
32
|
+
if @remove != nil
|
33
|
+
tags['remove'] = @remove
|
34
|
+
end
|
35
|
+
if @alias != nil
|
36
|
+
hash['alias'] = @alias
|
37
|
+
end
|
38
|
+
if @tags == ''
|
39
|
+
hash['tags'] = @tags
|
40
|
+
else
|
41
|
+
hash['tags'] = tags
|
42
|
+
end
|
43
|
+
|
44
|
+
return hash
|
45
|
+
end
|
46
|
+
|
47
|
+
|
48
|
+
|
49
|
+
|
50
|
+
def self.clear
|
51
|
+
tags = JPush::TagAlias.new
|
52
|
+
tags.tags = ''
|
53
|
+
tags.alias = ''
|
54
|
+
return tags;
|
55
|
+
end
|
56
|
+
|
57
|
+
def self.build(opts = {})
|
58
|
+
tagAlias = JPush::TagAlias.new(opts)
|
59
|
+
return tagAlias
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
require 'json'
|
2
|
+
|
3
|
+
module JPush
|
4
|
+
class TagAliasResult
|
5
|
+
attr_accessor :tags, :alias, :isok
|
6
|
+
def initialize
|
7
|
+
@isok=false
|
8
|
+
end
|
9
|
+
def fromResponse(wrapper)
|
10
|
+
if wrapper.code != 200
|
11
|
+
logger = Logger.new(STDOUT)
|
12
|
+
logger.error('Error response from JPush server. Should review and fix it. ')
|
13
|
+
logger.info('HTTP Status:' + wrapper.code.to_s)
|
14
|
+
logger.info('Error Message:' + wrapper.error.to_s)
|
15
|
+
raise JPush::ApiConnectionException.new(wrapper)
|
16
|
+
end
|
17
|
+
content = wrapper.getResponseContent
|
18
|
+
hash = JSON.parse(content)
|
19
|
+
@tags = hash['tags']
|
20
|
+
@alias = hash['alias']
|
21
|
+
@isok=true
|
22
|
+
return self
|
23
|
+
end
|
24
|
+
|
25
|
+
def toJSON
|
26
|
+
array={}
|
27
|
+
array['tags'] = @tags
|
28
|
+
array['alias'] = @alias
|
29
|
+
return array
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
require 'json'
|
2
|
+
|
3
|
+
module JPush
|
4
|
+
class TagListResult
|
5
|
+
attr_accessor :tags, :isok
|
6
|
+
|
7
|
+
def initialize
|
8
|
+
@isok=false
|
9
|
+
end
|
10
|
+
def fromResponse(wrapper)
|
11
|
+
if wrapper.code != 200
|
12
|
+
logger = Logger.new(STDOUT)
|
13
|
+
logger.error('Error response from JPush server. Should review and fix it. ')
|
14
|
+
logger.info('HTTP Status:' + wrapper.code.to_s)
|
15
|
+
logger.info('Error Message:' + wrapper.error.to_s)
|
16
|
+
raise JPush::ApiConnectionException.new(wrapper)
|
17
|
+
end
|
18
|
+
content = wrapper.getResponseContent
|
19
|
+
hash = JSON.parse(content)
|
20
|
+
@tags = hash['tags']
|
21
|
+
@isok=true
|
22
|
+
return self
|
23
|
+
end
|
24
|
+
|
25
|
+
def toJSON
|
26
|
+
array={}
|
27
|
+
array['tags'] = @tags
|
28
|
+
return array
|
29
|
+
end
|
30
|
+
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
module JPush
|
2
|
+
class TagManager
|
3
|
+
attr_accessor :add, :remove
|
4
|
+
|
5
|
+
def initialize(opts = {})
|
6
|
+
if opts[:add] != nil
|
7
|
+
if opts[:add].class == Array && opts[:add].length <= 1000
|
8
|
+
@add = opts[:add]
|
9
|
+
else
|
10
|
+
raise ArgumentError.new('add should be array and size <= 1000.')
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
if opts[:remove] != nil
|
15
|
+
if opts[:remove].class == Array && opts[:remove].length <= 1000
|
16
|
+
@remove = opts[:remove]
|
17
|
+
else
|
18
|
+
raise ArgumentError.new('add should be array and size <= 1000.')
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
end
|
23
|
+
|
24
|
+
def toJSON
|
25
|
+
hash = {}
|
26
|
+
registration_ids = {}
|
27
|
+
if @add != nil
|
28
|
+
registration_ids['add'] = @add
|
29
|
+
end
|
30
|
+
if @remove != nil
|
31
|
+
registration_ids['remove'] = @remove
|
32
|
+
end
|
33
|
+
|
34
|
+
hash['registration_ids'] = registration_ids
|
35
|
+
return hash
|
36
|
+
end
|
37
|
+
|
38
|
+
def self.build(opts = {})
|
39
|
+
tm = JPush::TagManager.new(opts)
|
40
|
+
return tm
|
41
|
+
end
|
42
|
+
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
require 'json'
|
2
|
+
|
3
|
+
module JPush
|
4
|
+
class UserResult
|
5
|
+
attr_accessor :isok, :time_unit, :start, :duration, :items
|
6
|
+
def initialize
|
7
|
+
@isok = false
|
8
|
+
end
|
9
|
+
|
10
|
+
def fromResponse(wrapper)
|
11
|
+
if wrapper.code != 200
|
12
|
+
logger = Logger.new(STDOUT)
|
13
|
+
logger.error('Error response from JPush server. Should review and fix it. ')
|
14
|
+
logger.info('HTTP Status:' + wrapper.code.to_s)
|
15
|
+
logger.info('Error Message' + wrapper.error.to_s)
|
16
|
+
raise JPush::ApiConnectionException.new(wrapper)
|
17
|
+
end
|
18
|
+
content = wrapper.getResponseContent
|
19
|
+
hash = JSON.parse(content)
|
20
|
+
@time_unit = hash['time_unit']
|
21
|
+
@start = hash['start']
|
22
|
+
@duration = hash['duration']
|
23
|
+
@itmes = hash['items']
|
24
|
+
@isok = true
|
25
|
+
return self
|
26
|
+
end
|
27
|
+
|
28
|
+
def toJSON
|
29
|
+
array = {}
|
30
|
+
array['time_unit'] = @time_unit
|
31
|
+
array['start'] = @start
|
32
|
+
array['duration'] = @duration
|
33
|
+
array['items'] = @items
|
34
|
+
return array.to_json
|
35
|
+
end
|
36
|
+
|
37
|
+
end
|
38
|
+
|
39
|
+
|
40
|
+
end
|
data/lib/jpush/push_client.rb
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
path= File.expand_path('../', __FILE__)
|
1
|
+
path = File.expand_path('../', __FILE__)
|
2
2
|
require File.join(path, 'http_client.rb')
|
3
3
|
require File.join(path, 'model/push_result.rb')
|
4
4
|
require 'json'
|
@@ -10,6 +10,7 @@ timeToLive If not present, the default is 86400(s) (one day).
|
|
10
10
|
module JPush
|
11
11
|
class PushClient
|
12
12
|
@@PUSH_API_URL = 'https://api.jpush.cn/v3/push'
|
13
|
+
@@VALIDATE = '/validate'
|
13
14
|
@@_timeToLive = 60 * 60 * 24
|
14
15
|
def initialize(maxRetryTimes)
|
15
16
|
@httpclient = JPush::NativeHttpClient.new(maxRetryTimes)
|
@@ -17,15 +18,28 @@ module JPush
|
|
17
18
|
|
18
19
|
=begin
|
19
20
|
@param payload is the instance of PushPayload
|
20
|
-
@autoCode
|
21
21
|
=end
|
22
|
-
def sendPush(payload
|
22
|
+
def sendPush(payload)
|
23
23
|
json_data = JSON.generate(payload.toJSON)
|
24
24
|
result = JPush::PushResult.new
|
25
|
-
wrapper = @httpclient.sendPost(@@PUSH_API_URL, json_data
|
25
|
+
wrapper = @httpclient.sendPost(@@PUSH_API_URL, json_data)
|
26
26
|
result.fromResponse(wrapper)
|
27
27
|
return result
|
28
28
|
end
|
29
29
|
|
30
|
+
=begin
|
31
|
+
The API is used only to verify push call whether can succeed,
|
32
|
+
lies in the difference with the push of API: not to send any message to user.
|
33
|
+
@param payload is the instance of PushPayload
|
34
|
+
=end
|
35
|
+
def validate(payload)
|
36
|
+
json_data = JSON.generate(payload.toJSON)
|
37
|
+
result = JPush::PushResult.new
|
38
|
+
wrapper = @httpclient.sendPost(@@PUSH_API_URL + @@VALIDATE, json_data)
|
39
|
+
result.fromResponse(wrapper)
|
40
|
+
return result
|
41
|
+
end
|
42
|
+
|
43
|
+
|
30
44
|
end
|
31
45
|
end
|
data/lib/jpush/report_client.rb
CHANGED
@@ -14,23 +14,28 @@ module JPush
|
|
14
14
|
end
|
15
15
|
|
16
16
|
|
17
|
-
def getReceiveds(msg_ids
|
17
|
+
def getReceiveds(msg_ids)
|
18
18
|
msg_ids = checkMsgids(msg_ids)
|
19
19
|
@url = @@REPORT_HOST_NAME + @@REPORT_RECEIVE_PATH + '?msg_ids=' + msg_ids
|
20
20
|
result = JPush::ReceivedsResult.new
|
21
|
-
wrapper = @httpclient.sendGet(@url, nil
|
21
|
+
wrapper = @httpclient.sendGet(@url, nil)
|
22
22
|
return result.fromResponse(wrapper)
|
23
23
|
end
|
24
24
|
|
25
|
-
def getMessages(msg_ids
|
25
|
+
def getMessages(msg_ids)
|
26
26
|
msg_ids = checkMsgids(msg_ids)
|
27
27
|
@url = @@REPORT_HOST_NAME + @@REPORT_MESSAGE_PATH + '?msg_ids=' + msg_ids
|
28
|
-
|
28
|
+
result = JPush::GetMessagesResult.new
|
29
|
+
wrapper = @httpclient.sendGet(@url, nil)
|
30
|
+
return result.fromResponse(wrapper)
|
29
31
|
end
|
30
32
|
|
31
|
-
def getUsers(timeUnit, start, duration
|
33
|
+
def getUsers(timeUnit, start, duration)
|
32
34
|
@url = @@REPORT_HOST_NAME + @@REPORT_USER_PATH + '?time_unit=' + timeUnit + '&start=' + start + '&duration=' + duration.to_s
|
33
|
-
|
35
|
+
result = JPush::UserResult.new
|
36
|
+
puts @url
|
37
|
+
wrapper = @httpclient.sendGet(@url, nil)
|
38
|
+
return result.fromResponse(wrapper)
|
34
39
|
end
|
35
40
|
|
36
41
|
def checkMsgids(msg_ids)
|
@@ -4,7 +4,8 @@ class ServiceHelper
|
|
4
4
|
|
5
5
|
def self.getAuthorizationBase64(appKey, masterSecret)
|
6
6
|
encodeKey = appKey + ":" + masterSecret
|
7
|
-
|
8
|
-
|
7
|
+
value = @@BASIC_PREFIX + " " + Base64.encode64(encodeKey)
|
8
|
+
value.gsub!("\n", '')
|
9
|
+
return value
|
9
10
|
end
|
10
11
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: jpush
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.
|
4
|
+
version: 3.2.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- JPush Offical
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2015-02-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rspec
|
@@ -32,19 +32,15 @@ executables: []
|
|
32
32
|
extensions: []
|
33
33
|
extra_rdoc_files: []
|
34
34
|
files:
|
35
|
-
- ".gitignore"
|
36
|
-
- ".project"
|
37
|
-
- Gemfile
|
38
|
-
- LICENSE.txt
|
39
|
-
- README.md
|
40
|
-
- Rakefile
|
41
|
-
- example/push_example.rb
|
42
|
-
- example/report_example.rb
|
43
|
-
- jpush.gemspec
|
44
35
|
- lib/jpush.rb
|
36
|
+
- lib/jpush/api_connection_exception.rb
|
37
|
+
- lib/jpush/device_client.rb
|
45
38
|
- lib/jpush/http_client.rb
|
46
39
|
- lib/jpush/jpush_client.rb
|
40
|
+
- lib/jpush/model/alias_uids_result.rb
|
47
41
|
- lib/jpush/model/audience.rb
|
42
|
+
- lib/jpush/model/exist_result.rb
|
43
|
+
- lib/jpush/model/get_messages_result.rb
|
48
44
|
- lib/jpush/model/message.rb
|
49
45
|
- lib/jpush/model/messages_result.rb
|
50
46
|
- lib/jpush/model/notification/android_notification.rb
|
@@ -56,17 +52,15 @@ files:
|
|
56
52
|
- lib/jpush/model/push_payload.rb
|
57
53
|
- lib/jpush/model/push_result.rb
|
58
54
|
- lib/jpush/model/receiveds_result.rb
|
55
|
+
- lib/jpush/model/tag_alias.rb
|
56
|
+
- lib/jpush/model/tag_alias_result.rb
|
57
|
+
- lib/jpush/model/tag_list_result.rb
|
58
|
+
- lib/jpush/model/tag_manager.rb
|
59
|
+
- lib/jpush/model/user_result.rb
|
59
60
|
- lib/jpush/push_client.rb
|
60
61
|
- lib/jpush/report_client.rb
|
61
62
|
- lib/jpush/response_wrapper.rb
|
62
63
|
- lib/jpush/util/service_helper.rb
|
63
|
-
- test/alert_override_tests.rb
|
64
|
-
- test/audience_tests.rb
|
65
|
-
- test/base_remote_tests.rb
|
66
|
-
- test/message_tests.rb
|
67
|
-
- test/notification_tests.rb
|
68
|
-
- test/push_payload_test.rb
|
69
|
-
- test/report_function_tests.rb
|
70
64
|
homepage: https://github.com/jpush/jpush-api-ruby-client
|
71
65
|
licenses:
|
72
66
|
- GNU
|
@@ -91,11 +85,4 @@ rubygems_version: 2.2.2
|
|
91
85
|
signing_key:
|
92
86
|
specification_version: 4
|
93
87
|
summary: JPush's officially supported Ruby client library for accessing JPush APIs.
|
94
|
-
test_files:
|
95
|
-
- test/alert_override_tests.rb
|
96
|
-
- test/audience_tests.rb
|
97
|
-
- test/base_remote_tests.rb
|
98
|
-
- test/message_tests.rb
|
99
|
-
- test/notification_tests.rb
|
100
|
-
- test/push_payload_test.rb
|
101
|
-
- test/report_function_tests.rb
|
88
|
+
test_files: []
|