rhoconnect 3.3.1.beta4 → 3.3.1
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG.md +6 -0
- data/CREDITS +16 -0
- data/Gemfile.lock +2 -2
- data/bench/lib/bench/test_data.rb +26 -26
- data/bench/scripts/cud_script.rb +1 -1
- data/bench/scripts/test_query_script.rb +13 -7
- data/doc/bulk-sync.txt +11 -0
- data/doc/supported-platforms.txt +3 -3
- data/generators/templates/application/Gemfile +2 -2
- data/lib/rhoconnect/api/app/bulk_data.rb +1 -1
- data/lib/rhoconnect/api/client/list_client_docs.rb +11 -9
- data/lib/rhoconnect/api/system/get_license_info.rb +5 -5
- data/lib/rhoconnect/bulk_data/bulk_data.rb +3 -1
- data/lib/rhoconnect/client_sync.rb +4 -2
- data/lib/rhoconnect/graph_helper.rb +170 -88
- data/lib/rhoconnect/jobs/bulk_data_job.rb +2 -2
- data/lib/rhoconnect/server.rb +1 -1
- data/lib/rhoconnect/version.rb +1 -1
- data/lib/rhoconnect/web-console/models/stats.js +66 -2
- data/lib/rhoconnect/web-console/public/bootstrap-collapse.js +157 -0
- data/lib/rhoconnect/web-console/public/jquery-1.7.1.min.js +4 -154
- data/lib/rhoconnect/web-console/server.rb +26 -1
- data/lib/rhoconnect/web-console/templates/index.erb +4 -2
- data/lib/rhoconnect/web-console/templates/jqplot.erb +13 -13
- data/lib/rhoconnect/web-console/views/new_ping.js +9 -2
- data/lib/rhoconnect/web-console/views/stats.js +69 -25
- data/spec/async_spec.rb +1 -1
- data/spec/bulk_data/bulk_data_spec.rb +17 -2
- data/spec/jobs/bulk_data_job_spec.rb +37 -1
- data/spec/spec_helper.rb +2 -2
- metadata +636 -625
- data/examples/simple/Gemfile.lock +0 -101
- data/examples/simple/dump.rdb +0 -0
data/CHANGELOG.md
CHANGED
@@ -1,3 +1,9 @@
|
|
1
|
+
## 3.3.1 (2012-07-19)
|
2
|
+
* #33021139 - ping test page doesn't send sound parameter
|
3
|
+
* disable sqlite3 dependency by default so applications deploy on heroku without modification
|
4
|
+
* #28696971 - select which models to bulk sync
|
5
|
+
* cleaner layout on statistics page
|
6
|
+
|
1
7
|
## 3.3.1.beta4 (2012-07-17)
|
2
8
|
* #32952425/EMBPD00067402/EMBPD00067382 - rhoconnect startbg fails on windows
|
3
9
|
|
data/CREDITS
CHANGED
@@ -2375,3 +2375,19 @@ RhoConnect uses or references the following open source software:
|
|
2375
2375
|
|
2376
2376
|
warbler 1.3.5 (https://github.com/jruby/warbler)
|
2377
2377
|
License: MIT license (http://caldersphere.rubyforge.org/warbler/LICENSE_txt.html)
|
2378
|
+
|
2379
|
+
nodejs 0.8.1 http://nodejs.org/
|
2380
|
+
License: MIT License (https://github.com/joyent/node/blob/master/LICENSE)
|
2381
|
+
|
2382
|
+
node_redis 0.7.1 http://search.npmjs.org/#/redis
|
2383
|
+
License: MIT License (https://github.com/mranney/node_redis#license---mit-license)
|
2384
|
+
|
2385
|
+
redis-url 0.1.0 http://search.npmjs.org/#/redis-url
|
2386
|
+
License: MIT License (https://github.com/ddollar/redis-url#license)
|
2387
|
+
|
2388
|
+
npm 1.1.30 http://npmjs.org/
|
2389
|
+
License: MIT License (https://github.com/isaacs/npm/blob/master/LICENSE)
|
2390
|
+
|
2391
|
+
commander.js 1.0.0 http://visionmedia.github.com/commander.js/
|
2392
|
+
License: MIT License (https://github.com/visionmedia/commander.js/#license)
|
2393
|
+
|
data/Gemfile.lock
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
rhoconnect (3.3.1
|
4
|
+
rhoconnect (3.3.1)
|
5
5
|
bundler (~> 1.0)
|
6
6
|
json (~> 1.6.0)
|
7
7
|
rake (~> 0.9.2.2)
|
@@ -117,7 +117,7 @@ GEM
|
|
117
117
|
rspec-mocks (2.10.1)
|
118
118
|
ruby-hmac (0.4.0)
|
119
119
|
rubyzip (0.9.9)
|
120
|
-
selenium-webdriver (2.
|
120
|
+
selenium-webdriver (2.25.0)
|
121
121
|
childprocess (>= 0.2.5)
|
122
122
|
libwebsocket (~> 0.1.3)
|
123
123
|
multi_json (~> 1.0)
|
@@ -39,32 +39,7 @@ module Bench
|
|
39
39
|
end
|
40
40
|
users
|
41
41
|
end
|
42
|
-
|
43
|
-
private
|
44
|
-
|
45
|
-
PREFIX = ["Account", "Administrative", "Advertising", "Assistant", "Banking", "Business Systems",
|
46
|
-
"Computer", "Distribution", "IT", "Electronics", "Environmental", "Financial", "General", "Head",
|
47
|
-
"Laboratory", "Maintenance", "Medical", "Production", "Quality Assurance", "Software", "Technical",
|
48
|
-
"Chief", "Senior"] unless defined? PREFIX
|
49
|
-
SUFFIX = ["Clerk", "Analyst", "Manager", "Supervisor", "Plant Manager", "Mechanic", "Technician", "Engineer",
|
50
|
-
"Director", "Superintendent", "Specialist", "Technologist", "Estimator", "Scientist", "Foreman", "Nurse",
|
51
|
-
"Worker", "Helper", "Intern", "Sales", "Mechanic", "Planner", "Recruiter", "Officer", "Superintendent",
|
52
|
-
"Vice President", "Buyer", "Production Supervisor", "Chef", "Accountant", "Executive"] unless defined? SUFFIX
|
53
|
-
|
54
|
-
IMAGE_FILES = %w{
|
55
|
-
icon.ico loading-LandscapeLeft.png loading-PortraitUpsideDown.png
|
56
|
-
icon.png loading-LandscapeRight.png loading.png
|
57
|
-
loading-Landscape.png loading-Portrait.png loading@2x.png }
|
58
|
-
|
59
|
-
EXCLUDE_LIST = %w{ id mock_id img_file-rhoblob img_file_size filename }
|
60
|
-
|
61
|
-
def title
|
62
|
-
prefix = PREFIX[rand(PREFIX.length)]
|
63
|
-
suffix = SUFFIX[rand(SUFFIX.length)]
|
64
|
-
|
65
|
-
"#{prefix} #{suffix}"
|
66
|
-
end
|
67
|
-
|
42
|
+
|
68
43
|
def generate_fake_data(num, generate_blob)
|
69
44
|
res = {}
|
70
45
|
num.times do |n|
|
@@ -94,5 +69,30 @@ module Bench
|
|
94
69
|
end
|
95
70
|
res
|
96
71
|
end
|
72
|
+
|
73
|
+
private
|
74
|
+
|
75
|
+
PREFIX = ["Account", "Administrative", "Advertising", "Assistant", "Banking", "Business Systems",
|
76
|
+
"Computer", "Distribution", "IT", "Electronics", "Environmental", "Financial", "General", "Head",
|
77
|
+
"Laboratory", "Maintenance", "Medical", "Production", "Quality Assurance", "Software", "Technical",
|
78
|
+
"Chief", "Senior"] unless defined? PREFIX
|
79
|
+
SUFFIX = ["Clerk", "Analyst", "Manager", "Supervisor", "Plant Manager", "Mechanic", "Technician", "Engineer",
|
80
|
+
"Director", "Superintendent", "Specialist", "Technologist", "Estimator", "Scientist", "Foreman", "Nurse",
|
81
|
+
"Worker", "Helper", "Intern", "Sales", "Mechanic", "Planner", "Recruiter", "Officer", "Superintendent",
|
82
|
+
"Vice President", "Buyer", "Production Supervisor", "Chef", "Accountant", "Executive"] unless defined? SUFFIX
|
83
|
+
|
84
|
+
IMAGE_FILES = %w{
|
85
|
+
icon.ico loading-LandscapeLeft.png loading-PortraitUpsideDown.png
|
86
|
+
icon.png loading-LandscapeRight.png loading.png
|
87
|
+
loading-Landscape.png loading-Portrait.png loading@2x.png }
|
88
|
+
|
89
|
+
EXCLUDE_LIST = %w{ id mock_id img_file-rhoblob img_file_size filename }
|
90
|
+
|
91
|
+
def title
|
92
|
+
prefix = PREFIX[rand(PREFIX.length)]
|
93
|
+
suffix = SUFFIX[rand(SUFFIX.length)]
|
94
|
+
|
95
|
+
"#{prefix} #{suffix}"
|
96
|
+
end
|
97
97
|
end
|
98
98
|
end
|
data/bench/scripts/cud_script.rb
CHANGED
@@ -48,7 +48,7 @@ Bench.test do |config,session|
|
|
48
48
|
session.client_id = JSON.parse(session.last_result.body)['client']['client_id']
|
49
49
|
create_objs = @create_objects[session.thread_id][session.iteration]
|
50
50
|
session.post "create-object",
|
51
|
-
"#{config.host}/app/#{Rhoconnect::API_VERSION}/#{config.adapter_name}
|
51
|
+
"#{config.host}/app/#{Rhoconnect::API_VERSION}/#{config.adapter_name}",
|
52
52
|
{:content_type => :json, 'X-RhoConnect-CLIENT-ID' => session.client_id} do
|
53
53
|
{:create => create_objs}.to_json
|
54
54
|
end
|
@@ -69,18 +69,24 @@ Bench.test do |config,session|
|
|
69
69
|
token = JSON.parse(session.last_result.body)[1]['token']
|
70
70
|
session.last_result.verify_code(200)
|
71
71
|
end
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
72
|
+
|
73
|
+
# now , create 2 records and then, delete them
|
74
|
+
# we also generate 2 random records for CUD calls
|
75
|
+
expected_for_cud = Bench.generate_fake_data(2, false)
|
76
|
+
session.post "create-object",
|
77
|
+
"#{config.host}/app/#{Rhoconnect::API_VERSION}/RhoInternalBenchmarkAdapter",
|
78
|
+
{:content_type => :json, 'X-RhoConnect-CLIENT-ID' => session.client_id} do
|
79
|
+
{:create => expected_for_cud}.to_json
|
80
|
+
end
|
81
|
+
session.last_result.verify_code(200)
|
82
|
+
|
83
|
+
obj_to_delete = expected_for_cud.keys[0]
|
76
84
|
session.delete "delete_object",
|
77
85
|
"#{config.host}/app/#{Rhoconnect::API_VERSION}/RhoInternalBenchmarkAdapter/#{obj_to_delete}",
|
78
86
|
{'X-RhoConnect-CLIENT-ID' => session.client_id}
|
79
87
|
session.last_result.verify_code(200)
|
80
88
|
|
81
|
-
obj_to_delete =
|
82
|
-
@expected.delete(obj_to_delete)
|
83
|
-
@datasize = @datasize - 1
|
89
|
+
obj_to_delete = expected_for_cud.keys[1]
|
84
90
|
session.post "push_deletes",
|
85
91
|
"#{config.host}/app/#{Rhoconnect::API_VERSION}/RhoInternalBenchmarkAdapter/push_deletes",
|
86
92
|
{'X-RhoConnect-API-TOKEN' => config.token, :content_type => :json} do
|
data/doc/bulk-sync.txt
CHANGED
@@ -30,6 +30,17 @@ For example, your settings/settings.yml might have:
|
|
30
30
|
|
31
31
|
## Setup
|
32
32
|
|
33
|
+
### Setup DB Library
|
34
|
+
Bulk sync prepares database files inside of a job, therefore it needs access to sqlite3's ruby library. To enable this library, uncomment or add the following line to your RhoConnect app's Gemfile:
|
35
|
+
|
36
|
+
:::ruby
|
37
|
+
gem 'sqlite3', ">= 1.3.3", :platforms => [:ruby, :mswin, :mingw]
|
38
|
+
|
39
|
+
Then install the gem:
|
40
|
+
|
41
|
+
:::term
|
42
|
+
$ bundle install
|
43
|
+
|
33
44
|
### Enabling Bulk Sync in Rhodes
|
34
45
|
In the device rhodes application, setting `bulksync_state` to 0 in rhoconfig.txt will trigger bulk sync next time sync is performed:
|
35
46
|
|
data/doc/supported-platforms.txt
CHANGED
@@ -16,7 +16,7 @@ Supported Platforms
|
|
16
16
|
<tr>
|
17
17
|
<td class='cap'>Linux</td>
|
18
18
|
<td> CentOS / RHEL 5 & 6,<br/>Ubuntu 11,<br/>Amazon Linux</td>
|
19
|
-
<td> ruby-1.8.7-
|
19
|
+
<td> ruby-1.8.7-p370 </td>
|
20
20
|
<td> ree-1.8.7-2012.02 </td>
|
21
21
|
<td> ruby-1.9.2-p320 </td>
|
22
22
|
<td> ruby-1.9.3-p194 </td>
|
@@ -26,7 +26,7 @@ Supported Platforms
|
|
26
26
|
<tr>
|
27
27
|
<td class='cap'>Mac OS </td>
|
28
28
|
<td> Mac OS X 10.6/10.7 </td>
|
29
|
-
<td> ruby-1.8.7-
|
29
|
+
<td> ruby-1.8.7-p370 </td>
|
30
30
|
<td> ree-1.8.7-2012.02 </td>
|
31
31
|
<td> ruby-1.9.2-p320 </td>
|
32
32
|
<td> ruby-1.9.3-p194 </td>
|
@@ -36,7 +36,7 @@ Supported Platforms
|
|
36
36
|
<tr>
|
37
37
|
<td class='cap'>Windows</td>
|
38
38
|
<td> Windows 7 </td>
|
39
|
-
<td> ruby-1.8.7-
|
39
|
+
<td> ruby-1.8.7-p370 </td>
|
40
40
|
<td class='tbd'> TBD </td>
|
41
41
|
<td class='tbd'> TBD </td>
|
42
42
|
<td> ruby-1.9.3-p194 </td>
|
@@ -4,7 +4,6 @@ gem 'rhoconnect', '<%=gem_version%>'
|
|
4
4
|
|
5
5
|
# Helps with some of the limitations of green threads, not needed in ruby 1.9.x
|
6
6
|
gem 'SystemTimer', '~> 1.2.3', :platforms => :ruby_18
|
7
|
-
gem 'windows-pr', '1.2.1', :platforms => [:mswin, :mingw]
|
8
7
|
gem 'win32-process', :platforms => [:mswin, :mingw]
|
9
8
|
|
10
9
|
# use thin and eventmachine everywhere except JRuby
|
@@ -30,7 +29,8 @@ platforms :jruby do
|
|
30
29
|
gem 'warbler'
|
31
30
|
end
|
32
31
|
|
33
|
-
|
32
|
+
# uncomment the line below to use bulk sync: http://docs.rhomobile.com/rhoconnect/bulk-sync
|
33
|
+
# gem 'sqlite3', ">= 1.3.3", :platforms => [:ruby, :mswin, :mingw]
|
34
34
|
|
35
35
|
group :development do
|
36
36
|
gem 'rhomobile-debug', ">= 1.0.2"
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Server.api4 :bulk_data, :post, "/rc/#{Rhoconnect::API_VERSION}/app/bulk_data", \
|
2
2
|
false, {:verb => :get, :url => ['/application/bulk_data', '/api/application/bulk_data']} do |params,user,server|
|
3
3
|
server.content_type :json
|
4
|
-
data = ClientSync.bulk_data(params[:partition].to_sym,server.current_client)
|
4
|
+
data = ClientSync.bulk_data(params[:partition].to_sym,server.current_client, params[:sources])
|
5
5
|
data.to_json
|
6
6
|
end
|
@@ -1,13 +1,15 @@
|
|
1
1
|
Server.api4 :list_client_docs, :get, "/rc/#{Rhoconnect::API_VERSION}/clients/:client_id/sources/:source_id/docnames", \
|
2
2
|
true, {:verb => :post, :url => ['/api/list_client_docs', '/api/client/list_client_docs']} do |params,user|
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
3
|
+
Rhoconnect::Stats::Record.update('clientdocs') do
|
4
|
+
c = Client.load(params[:client_id],{:source_name => params[:source_id]})
|
5
|
+
res = {}
|
6
|
+
[:cd,:cd_size,:create,:update,:delete,
|
7
|
+
:page,:delete_page,:create_links,:create_links_page,:page_token,
|
8
|
+
:create_errors,:update_errors,:delete_errors,:login_error,:logoff_error,
|
9
|
+
:search,:search_token,:search_errors].each do |doc|
|
10
|
+
db_key = c.docname(doc)
|
11
|
+
res.merge!(doc => db_key)
|
12
|
+
end
|
13
|
+
res.to_json
|
11
14
|
end
|
12
|
-
res.to_json
|
13
15
|
end
|
@@ -1,9 +1,9 @@
|
|
1
1
|
Server.api4 :get_license_info, :get, "/rc/#{Rhoconnect::API_VERSION}/system/license", \
|
2
2
|
true, {:verb => :post, :url => ['/api/get_license_info', '/api/admin/get_license_info']} do |params,user|
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
3
|
+
{:rhoconnect_version => Rhoconnect.license.rhoconnect_version,
|
4
|
+
:licensee => Rhoconnect.license.licensee,
|
5
|
+
:seats => Rhoconnect.license.seats,
|
6
|
+
:issued => Rhoconnect.license.issued,
|
7
|
+
:available => Rhoconnect.license.available }.to_json
|
8
8
|
end
|
9
9
|
|
@@ -10,7 +10,8 @@ module Rhoconnect
|
|
10
10
|
field :refresh_time, :integer
|
11
11
|
field :dbfile,:string
|
12
12
|
list :sources, :string
|
13
|
-
|
13
|
+
list :partition_sources, :string
|
14
|
+
validates_presence_of :app_id, :user_id, :sources, :partition_sources
|
14
15
|
|
15
16
|
def completed?
|
16
17
|
if state.to_sym == :completed
|
@@ -64,6 +65,7 @@ module Rhoconnect
|
|
64
65
|
fields[:id] = fields[:name]
|
65
66
|
fields[:state] ||= :inprogress
|
66
67
|
fields[:sources] ||= []
|
68
|
+
fields[:partition_sources] ||= []
|
67
69
|
super(fields)
|
68
70
|
end
|
69
71
|
|
@@ -262,12 +262,13 @@ module Rhoconnect
|
|
262
262
|
res
|
263
263
|
end
|
264
264
|
|
265
|
-
def bulk_data(partition,client)
|
265
|
+
def bulk_data(partition,client,sources=nil)
|
266
266
|
raise ArgumentError.new(UNKNOWN_CLIENT) unless client
|
267
267
|
name = BulkData.get_name(partition,client.user_id)
|
268
268
|
data = BulkData.load(name)
|
269
269
|
|
270
|
-
|
270
|
+
partition_sources = client.app.partition_sources(partition,client.user_id)
|
271
|
+
sources ||= partition_sources
|
271
272
|
return {:result => :nop} if sources.length <= 0
|
272
273
|
|
273
274
|
do_bd_sync = data.nil?
|
@@ -279,6 +280,7 @@ module Rhoconnect
|
|
279
280
|
data = BulkData.create(:name => name,
|
280
281
|
:app_id => client.app_id,
|
281
282
|
:user_id => client.user_id,
|
283
|
+
:partition_sources => partition_sources,
|
282
284
|
:sources => sources,
|
283
285
|
:refresh_time => Time.now.to_i + Rhoconnect.bulk_sync_poll_interval)
|
284
286
|
BulkData.enqueue("data_name" => name)
|
@@ -1,15 +1,16 @@
|
|
1
1
|
module GraphHelper
|
2
2
|
|
3
|
+
|
3
4
|
def source_timing(params)
|
4
5
|
#name,data,options
|
5
|
-
puts "display is #{params}"
|
6
6
|
@displayname = params['display_name']
|
7
7
|
names = []
|
8
|
-
begin
|
9
|
-
|
10
|
-
rescue Exception => e
|
11
|
-
|
12
|
-
end
|
8
|
+
# begin
|
9
|
+
# names = get_sources('all')
|
10
|
+
# rescue Exception => e
|
11
|
+
# puts "errror #{e.message}"
|
12
|
+
# end
|
13
|
+
names = [params['display_name']]
|
13
14
|
@sources = []
|
14
15
|
|
15
16
|
names.each do |name|
|
@@ -18,18 +19,21 @@ module GraphHelper
|
|
18
19
|
series = []
|
19
20
|
options = { :legend => { :show => true }, :title => name }
|
20
21
|
s['name'] = name
|
22
|
+
s['data'] = []
|
21
23
|
|
22
|
-
keys = get_user_count("source:*:#{name}")
|
23
|
-
|
24
|
+
@keys = get_user_count("source:*:#{name}")
|
25
|
+
@keyname = params['key'] || @keys.first
|
26
|
+
|
24
27
|
xmin = 9999999999999999
|
25
28
|
xmax = -1
|
26
29
|
ymin = 9999999999999999
|
27
30
|
ymax = -1
|
28
|
-
|
29
|
-
|
31
|
+
|
32
|
+
if @keyname
|
33
|
+
method = @keyname.gsub(/source:/,"").gsub(/:.*/,"")
|
30
34
|
series << {:showLabel => true, :label => method }
|
31
|
-
|
32
|
-
range = get_user_count(nil,
|
35
|
+
|
36
|
+
range = get_user_count(nil,@keyname,0,-1)
|
33
37
|
thisdata = []
|
34
38
|
range.each do |value|
|
35
39
|
count = value.split(',')[0]
|
@@ -46,98 +50,177 @@ module GraphHelper
|
|
46
50
|
data << thisdata
|
47
51
|
xmin = thisdata[0][0].to_i if thisdata[0] && thisdata[0][0].to_i < xmin
|
48
52
|
xmax = thisdata[-1][0].to_i if thisdata[-1] && thisdata[-1][0].to_i > xmax
|
49
|
-
|
53
|
+
|
50
54
|
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
s['data'] = data
|
58
|
-
options[:series] = series
|
59
|
-
options[:cursor] = {:zoom => true, :showTooltip => true}
|
55
|
+
options[:axes] = {
|
56
|
+
:yaxis => { :tickOptions => { :formatString =>'%.3f'}, :autoscale => true, :min => 0, :max => ymax + (ymax * 0.05), :label => 'Seconds', :labelRenderer => '$.jqplot.CanvasAxisLabelRenderer' },
|
57
|
+
:xaxis => { :autoscale => true, :renderer=>'$.jqplot.DateAxisRenderer',
|
58
|
+
:tickOptions => {:formatString => '%m/%d/%y'}}
|
59
|
+
}
|
60
60
|
|
61
|
-
|
61
|
+
s['data'] = data
|
62
|
+
options[:series] = series
|
63
|
+
options[:cursor] = {:zoom => true, :showTooltip => true}
|
62
64
|
|
65
|
+
s['options'] = options
|
66
|
+
end
|
67
|
+
|
63
68
|
@sources << s
|
64
69
|
end
|
65
70
|
@graph_t = 'source'
|
66
71
|
@data = [[[1,2],[3,4],[5,6]]].to_json
|
67
72
|
erb :jqplot, :layout => false
|
68
|
-
|
69
|
-
|
73
|
+
end
|
70
74
|
|
71
|
-
def http_timing(params)
|
72
|
-
@uri = 'timing/httptiming'
|
73
75
|
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
76
|
+
def http_timing_key(params)
|
77
|
+
@uri = 'timing/httptiming'
|
78
|
+
|
79
|
+
#name,data,options
|
80
|
+
@displayname = params['display_name']
|
81
|
+
#names = ["GET","POST"]
|
82
|
+
# begin
|
83
|
+
# names = get_sources('all')
|
84
|
+
# rescue Exception => e
|
85
|
+
# puts "errror #{e.message}"
|
86
|
+
# end
|
87
|
+
@sources = []
|
88
|
+
name = key = params['display_name']
|
89
|
+
|
90
|
+
s = {}
|
91
|
+
data = []
|
92
|
+
series = []
|
93
|
+
options = { :legend => { :show => true, :location => 'ne' }, :title => name }
|
94
|
+
s['name'] = name
|
95
|
+
|
96
|
+
xmin = 9999999999999999
|
97
|
+
xmax = -1
|
98
|
+
ymin = 9999999999999999
|
99
|
+
ymax = -1
|
100
|
+
|
101
|
+
method = key.gsub(/http:.*?:/,"")
|
102
|
+
#method.gsub!(/:.*/,"")
|
103
|
+
series << {:showLabel => true, :label => method}
|
104
|
+
range = get_user_count(nil,key,0,-1)
|
105
|
+
thisdata = []
|
106
|
+
range.each do |value|
|
107
|
+
count = value.split(',')[0]
|
108
|
+
value.gsub!(/.*,/,"")
|
109
|
+
thisdata << value.split(":").reverse
|
110
|
+
thisdata[-1][0] = thisdata[-1][0].to_i * 1000
|
111
|
+
thisdata[-1][1] = thisdata[-1][1].to_f
|
112
|
+
thisdata[-1][1] /= count.to_f
|
84
113
|
|
85
|
-
|
86
|
-
|
87
|
-
data = []
|
88
|
-
series = []
|
89
|
-
options = { :legend => { :show => true }, :title => name }
|
90
|
-
s['name'] = name
|
114
|
+
ymin = thisdata[-1][1].to_f if thisdata[-1][1] && thisdata[-1][1].to_f < ymin
|
115
|
+
ymax = thisdata[-1][1].to_f if thisdata[-1][1] && thisdata[-1][1].to_f > ymax
|
91
116
|
|
92
|
-
|
93
|
-
|
117
|
+
end
|
118
|
+
data << thisdata
|
119
|
+
xmin = thisdata[0][0].to_i if thisdata[0] && thisdata[0][0].to_i < xmin
|
120
|
+
xmax = thisdata[-1][0].to_i if thisdata[-1] && thisdata[-1][0].to_i > xmax
|
94
121
|
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
122
|
+
|
123
|
+
options[:axes] = {
|
124
|
+
:yaxis => { :tickOptions => { :formatString =>'%.3f'}, :autoscale => true, :min => 0, :max => ymax + (ymax * 0.05), :label => 'Seconds', :labelRenderer => '$.jqplot.CanvasAxisLabelRenderer' },
|
125
|
+
:xaxis => { :autoscale => true, :renderer=>'$.jqplot.DateAxisRenderer',
|
126
|
+
:tickOptions => {:formatString => '%m/%d/%y'}}
|
127
|
+
}
|
128
|
+
|
129
|
+
s['data'] = data
|
130
|
+
options[:series] = series
|
131
|
+
options[:cursor] = {:zoom => true, :showTooltip => true}
|
132
|
+
s['options'] = options
|
133
|
+
|
134
|
+
@sources << s
|
135
|
+
|
136
|
+
@graph_t = 'http'
|
137
|
+
@data = [[[1,2],[3,4],[5,6]]].to_json
|
138
|
+
erb :jqplot, :layout => false
|
139
|
+
end
|
140
|
+
|
141
|
+
def http_timing(params)
|
142
|
+
@uri = 'timing/httptiming'
|
113
143
|
|
114
|
-
|
115
|
-
|
144
|
+
#name,data,options
|
145
|
+
|
146
|
+
@displayname = params['display_name']
|
147
|
+
names = ["GET","POST"]
|
148
|
+
|
149
|
+
@sources = []
|
150
|
+
names = [params['display_name']]
|
116
151
|
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
152
|
+
names.each do |name|
|
153
|
+
s = {}
|
154
|
+
data = []
|
155
|
+
series = []
|
156
|
+
options = { :legend => { :show => true, :location => 'ne' }, :title => name }
|
157
|
+
s['name'] = name
|
122
158
|
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
159
|
+
name = "*" if name == "ALL"
|
160
|
+
keys = get_user_count("http:*:#{name}")
|
161
|
+
xmin = 9999999999999999
|
162
|
+
xmax = -1
|
163
|
+
ymin = 9999999999999999
|
164
|
+
ymax = -1
|
165
|
+
keys.each_with_index do |key,index|
|
166
|
+
method = key.gsub(/http:.*?:/,"")
|
167
|
+
method.gsub!(/:.*/,"") unless name == "*"
|
168
|
+
series << {:showLabel => true, :label => method}
|
128
169
|
|
129
|
-
|
130
|
-
|
131
|
-
|
170
|
+
range = get_user_count(nil,key,0,-1)
|
171
|
+
thisdata = []
|
172
|
+
range.each do |value|
|
173
|
+
count = value.split(',')[0]
|
174
|
+
value.gsub!(/.*,/,"")
|
175
|
+
thisdata << value.split(":").reverse
|
176
|
+
thisdata[-1][0] = thisdata[-1][0].to_i * 1000
|
177
|
+
thisdata[-1][1] = thisdata[-1][1].to_f
|
178
|
+
thisdata[-1][1] /= count.to_f
|
132
179
|
|
133
|
-
|
180
|
+
ymin = thisdata[-1][1].to_f if thisdata[-1][1] && thisdata[-1][1].to_f < ymin
|
181
|
+
ymax = thisdata[-1][1].to_f if thisdata[-1][1] && thisdata[-1][1].to_f > ymax
|
134
182
|
|
135
|
-
|
183
|
+
end
|
184
|
+
data << thisdata
|
185
|
+
xmin = thisdata[0][0].to_i if thisdata[0] && thisdata[0][0].to_i < xmin
|
186
|
+
xmax = thisdata[-1][0].to_i if thisdata[-1] && thisdata[-1][0].to_i > xmax
|
136
187
|
end
|
137
|
-
|
138
|
-
|
139
|
-
|
188
|
+
|
189
|
+
options[:axes] = {
|
190
|
+
:yaxis => { :tickOptions => { :formatString =>'%.3f'}, :autoscale => true, :min => 0, :max => ymax + (ymax * 0.05), :label => 'Seconds', :labelRenderer => '$.jqplot.CanvasAxisLabelRenderer' },
|
191
|
+
:xaxis => { :autoscale => true, :renderer=>'$.jqplot.DateAxisRenderer',
|
192
|
+
:tickOptions => {:formatString => '%m/%d/%y'}}
|
193
|
+
}
|
194
|
+
|
195
|
+
s['data'] = data
|
196
|
+
options[:series] = series
|
197
|
+
options[:cursor] = {:zoom => true, :showTooltip => true}
|
198
|
+
s['options'] = options
|
199
|
+
|
200
|
+
@sources << s
|
140
201
|
end
|
202
|
+
|
203
|
+
@graph_t = 'http'
|
204
|
+
@data = [[[1,2],[3,4],[5,6]]].to_json
|
205
|
+
erb :jqplot, :layout => false
|
206
|
+
end
|
207
|
+
|
208
|
+
def get_http_routes()
|
209
|
+
keys = get_user_count("http:*:*")
|
210
|
+
method = key.gsub(/http:.*?:/,"")
|
211
|
+
#sources = get_sources('all')
|
212
|
+
|
213
|
+
#loop through arrays and remove any regex matches
|
214
|
+
# keysf = keys.inject([]) do |keys_final, element|
|
215
|
+
# found = true
|
216
|
+
# sources.each do |s|
|
217
|
+
# found = false if element.match(s)
|
218
|
+
# end
|
219
|
+
# keys_final << element.strip if found
|
220
|
+
# keys_final
|
221
|
+
# end
|
222
|
+
|
223
|
+
end
|
141
224
|
|
142
225
|
def count_graph(uri,title,name,metric)
|
143
226
|
start = 0
|
@@ -178,13 +261,13 @@ module GraphHelper
|
|
178
261
|
end
|
179
262
|
|
180
263
|
def get_user_count(name=nil,metric_p=nil,start=nil,finish=nil)
|
181
|
-
|
264
|
+
begin
|
182
265
|
if Rhoconnect.stats == true
|
183
266
|
names = name
|
184
267
|
if names
|
185
268
|
Rhoconnect::Stats::Record.keys(names)
|
186
269
|
else
|
187
|
-
metric = metric_p
|
270
|
+
metric = metric_p.strip
|
188
271
|
rtype = Rhoconnect::Stats::Record.rtype(metric)
|
189
272
|
if rtype == 'zset'
|
190
273
|
# returns [] if no results
|
@@ -198,10 +281,9 @@ module GraphHelper
|
|
198
281
|
else
|
199
282
|
raise ApiException.new(500, "Stats not enabled")
|
200
283
|
end
|
201
|
-
|
202
|
-
puts "error #{e.message} -- #{metric}"
|
284
|
+
rescue Exception => e
|
203
285
|
usercount = ["0:#{Time.now.to_i}"]
|
204
|
-
|
286
|
+
end
|
205
287
|
end
|
206
288
|
|
207
289
|
def get_sources(partition_type)
|