Description:
more heart beat feature add reset last login ip
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r534:dc7ae6e7079b - - 7 files changed: 77 inserted, 18 deleted

@@ -0,0 +1,30
1 + - content_for :header do
2 + = javascript_include_tag 'local_jquery'
3 + = stylesheet_link_tag 'tablesorter-theme.cafe'
4 +
5 + %script{:type=>"text/javascript"}
6 + $(function () {
7 + $('#since_datetime').datetimepicker({ showButtonPanel: true, dateFormat: "yy-mm-dd", controlType: "slider"} );
8 + $('#until_datetime').datetimepicker({ showButtonPanel: true, dateFormat: "yy-mm-dd", controlType: "slider"} );
9 + $('#my_table').tablesorter({widgets: ['zebra']});
10 + });
11 +
12 + %h1 Heart Beat Count
13 + = "Last 5 minutes distinct user count = #{@num}"
14 +
15 + %h1 Heart Beat List
16 +
17 + %table.tablesorter-cafe#my_table
18 + %thead
19 + %tr
20 + %th Login
21 + %th Full name
22 + %th IP
23 + %th Last Update
24 + %tbody
25 + - @hb.each do |hb|
26 + %tr{class: cycle('info-even','info-odd')}
27 + %td= link_to hb.user.login, controller: :users, :action => 'profile', :id => hb.user.id
28 + %td= hb.user.full_name
29 + %td= hb.ip_address
30 + %td= "#{time_ago_in_words(hb.updated_at)} ago"
@@ -0,0 +1,5
1 + class AddStatusToHeartBeat < ActiveRecord::Migration
2 + def change
3 + add_column :heart_beats, :status, :string
4 + end
5 + end
@@ -1,14 +1,29
1 1 class HeartbeatController < ApplicationController
2 + before_filter :admin_authorization, :only => ['index']
3 +
2 4 def edit
3 - render layout: 'empty'
4 5 @user = User.find_by_login(params[:id])
5 - return unless @user
6 + unless @user
7 + render text: "LOGIN_NOT_FOUND"
8 + return
9 + end
6 10
7 11 hb = HeartBeat.where(user_id: @user.id, ip_address: request.remote_ip).first
12 + puts "status = #{params[:status]}"
8 13 if hb
14 + if params[:status]
15 + hb.status = params[:status]
16 + hb.save
17 + end
9 18 hb.touch
10 19 else
11 - HeartBeat.create(user_id: @user.id, ip_address: request.remote_ip)
20 + HeartBeat.creae(user_id: @user.id, ip_address: request.remote_ip)
21 + end
22 + render text: "OK"
23 + end
24 +
25 + def index
26 + @hb = HeartBeat.includes(:user).order(:user_id).all
27 + @num = HeartBeat.where("updated_at >= ?",Time.zone.now-5.minutes).count
12 28 end
13 29 end
14 - end
@@ -53,24 +53,31
53 53
54 54 def create
55 55 @user = User.new(params[:user])
56 56 @user.activated = true
57 57 if @user.save
58 58 flash[:notice] = 'User was successfully created.'
59 59 redirect_to :action => 'list'
60 60 else
61 61 render :action => 'new'
62 62 end
63 63 end
64 64
65 + def clear_last_ip
66 + @user = User.find(params[:id])
67 + @user.last_ip = nil
68 + @user.save
69 + redirect_to action: 'list', page: params[:page]
70 + end
71 +
65 72 def create_from_list
66 73 lines = params[:user_list]
67 74
68 75 note = []
69 76
70 77 lines.split("\n").each do |line|
71 78 items = line.chomp.split(',')
72 79 if items.length>=2
73 80 login = items[0]
74 81 full_name = items[1]
75 82
76 83 added_random_password = false
@@ -55,33 +55,35
55 55 <%= will_paginate @users, :container => false %>
56 56 <% end %>
57 57 <table class="info">
58 58 <tr class="info-head">
59 59 <% for column in User.content_columns %>
60 60 <% if !@hidden_columns.index(column.name) %>
61 61 <th><%= column.human_name %></th>
62 62 <% end %>
63 63 <% end %>
64 64 <th></th>
65 65 <th></th>
66 66 <th></th>
67 + <th></th>
67 68 </tr>
68 69
69 70 <% for user in @users %>
70 71 <tr class="info-<%= cycle("odd","even") %>">
71 72 <td><%= link_to user.login, controller: :users, :action => 'profile', :id => user %></td>
72 73 <% for column in User.content_columns %>
73 74 <% if !@hidden_columns.index(column.name) and column.name != 'login' %>
74 75 <td><%=h user.send(column.name) %></td>
75 76 <% end %>
76 77 <% end %>
78 + <td><%= link_to 'Clear IP', {:action => 'clear_last_ip', :id => user, :page=>params[:page]}, :confirm => 'This will reset last logging in ip of the user, are you sure?' %></td>
77 79 <td><%= link_to 'Show', :action => 'show', :id => user %></td>
78 80 <td><%= link_to 'Edit', :action => 'edit', :id => user %></td>
79 81 <td><%= link_to 'Destroy', { :action => 'destroy', :id => user }, :confirm => 'Are you sure?', :method => :post %></td>
80 82 </tr>
81 83 <% end %>
82 84 </table>
83 85
84 86 <br />
85 87
86 88 <%= link_to '[New user]', :action => 'new' %>
87 89 <%= link_to '[New list of users]', :action => 'new_list' %>
@@ -2,29 +2,29
2 2 # This file is auto-generated from the current state of the database. Instead
3 3 # of editing this file, please use the migrations feature of Active Record to
4 4 # incrementally modify your database, and then regenerate this schema definition.
5 5 #
6 6 # Note that this schema.rb definition is the authoritative source for your
7 7 # database schema. If you need to create the application database on another
8 8 # system, you should be using db:schema:load, not running all the migrations
9 9 # from scratch. The latter is a flawed and unsustainable approach (the more migrations
10 10 # you'll amass, the slower it'll run and the greater likelihood for issues).
11 11 #
12 12 # It's strongly recommended to check this file into your version control system.
13 13
14 - ActiveRecord::Schema.define(:version => 20150914090545) do
14 + ActiveRecord::Schema.define(:version => 20150914155101) do
15 15
16 16 create_table "announcements", :force => true do |t|
17 17 t.string "author"
18 - t.text "body"
18 + t.text "body", :limit => 16777215
19 19 t.boolean "published"
20 20 t.datetime "created_at", :null => false
21 21 t.datetime "updated_at", :null => false
22 22 t.boolean "frontpage", :default => false
23 23 t.boolean "contest_only", :default => false
24 24 t.string "title"
25 25 t.string "notes"
26 26 end
27 27
28 28 create_table "contests", :force => true do |t|
29 29 t.string "title"
30 30 t.boolean "enabled"
@@ -41,79 +41,80
41 41 create_table "contests_users", :id => false, :force => true do |t|
42 42 t.integer "contest_id"
43 43 t.integer "user_id"
44 44 end
45 45
46 46 create_table "countries", :force => true do |t|
47 47 t.string "name"
48 48 t.datetime "created_at", :null => false
49 49 t.datetime "updated_at", :null => false
50 50 end
51 51
52 52 create_table "descriptions", :force => true do |t|
53 - t.text "body"
53 + t.text "body", :limit => 16777215
54 54 t.boolean "markdowned"
55 55 t.datetime "created_at", :null => false
56 56 t.datetime "updated_at", :null => false
57 57 end
58 58
59 59 create_table "grader_configurations", :force => true do |t|
60 60 t.string "key"
61 61 t.string "value_type"
62 62 t.string "value"
63 63 t.datetime "created_at", :null => false
64 64 t.datetime "updated_at", :null => false
65 - t.text "description"
65 + t.text "description", :limit => 16777215
66 66 end
67 67
68 68 create_table "grader_processes", :force => true do |t|
69 69 t.string "host", :limit => 20
70 70 t.integer "pid"
71 71 t.string "mode"
72 72 t.boolean "active"
73 73 t.datetime "created_at", :null => false
74 74 t.datetime "updated_at", :null => false
75 75 t.integer "task_id"
76 76 t.string "task_type"
77 77 t.boolean "terminated"
78 78 end
79 79
80 80 add_index "grader_processes", ["host", "pid"], :name => "index_grader_processes_on_ip_and_pid"
81 81
82 82 create_table "heart_beats", :force => true do |t|
83 83 t.integer "user_id"
84 84 t.string "ip_address"
85 85 t.datetime "created_at", :null => false
86 86 t.datetime "updated_at", :null => false
87 + t.string "status"
87 88 end
88 89
89 90 create_table "languages", :force => true do |t|
90 91 t.string "name", :limit => 10
91 92 t.string "pretty_name"
92 93 t.string "ext", :limit => 10
93 94 t.string "common_ext"
94 95 end
95 96
96 97 create_table "logins", :force => true do |t|
97 98 t.integer "user_id"
98 99 t.string "ip_address"
99 100 t.datetime "created_at", :null => false
100 101 t.datetime "updated_at", :null => false
101 102 end
102 103
103 104 create_table "messages", :force => true do |t|
104 105 t.integer "sender_id"
105 106 t.integer "receiver_id"
106 107 t.integer "replying_message_id"
107 - t.text "body"
108 + t.text "body", :limit => 16777215
108 109 t.boolean "replied"
109 110 t.datetime "created_at", :null => false
110 111 t.datetime "updated_at", :null => false
111 112 end
112 113
113 114 create_table "problems", :force => true do |t|
114 115 t.string "name", :limit => 30
115 116 t.string "full_name"
116 117 t.integer "full_score"
117 118 t.date "date_added"
118 119 t.boolean "available"
119 120 t.string "url"
@@ -140,25 +141,25
140 141 t.string "name"
141 142 end
142 143
143 144 create_table "roles_users", :id => false, :force => true do |t|
144 145 t.integer "role_id"
145 146 t.integer "user_id"
146 147 end
147 148
148 149 add_index "roles_users", ["user_id"], :name => "index_roles_users_on_user_id"
149 150
150 151 create_table "sessions", :force => true do |t|
151 152 t.string "session_id"
152 - t.text "data"
153 + t.text "data", :limit => 16777215
153 154 t.datetime "updated_at"
154 155 end
155 156
156 157 add_index "sessions", ["session_id"], :name => "index_sessions_on_session_id"
157 158 add_index "sessions", ["updated_at"], :name => "index_sessions_on_updated_at"
158 159
159 160 create_table "sites", :force => true do |t|
160 161 t.string "name"
161 162 t.boolean "started"
162 163 t.datetime "start_time"
163 164 t.datetime "created_at", :null => false
164 165 t.datetime "updated_at", :null => false
@@ -168,70 +169,70
168 169
169 170 create_table "submission_view_logs", :force => true do |t|
170 171 t.integer "user_id"
171 172 t.integer "submission_id"
172 173 t.datetime "created_at", :null => false
173 174 t.datetime "updated_at", :null => false
174 175 end
175 176
176 177 create_table "submissions", :force => true do |t|
177 178 t.integer "user_id"
178 179 t.integer "problem_id"
179 180 t.integer "language_id"
180 - t.text "source"
181 + t.text "source", :limit => 16777215
181 182 t.binary "binary"
182 183 t.datetime "submitted_at"
183 184 t.datetime "compiled_at"
184 - t.text "compiler_message"
185 + t.text "compiler_message", :limit => 16777215
185 186 t.datetime "graded_at"
186 187 t.integer "points"
187 - t.text "grader_comment"
188 + t.text "grader_comment", :limit => 16777215
188 189 t.integer "number"
189 190 t.string "source_filename"
190 191 t.float "max_runtime"
191 192 t.integer "peak_memory"
192 193 t.integer "effective_code_length"
193 194 t.string "ip_address"
194 195 end
195 196
196 197 add_index "submissions", ["user_id", "problem_id", "number"], :name => "index_submissions_on_user_id_and_problem_id_and_number", :unique => true
197 198 add_index "submissions", ["user_id", "problem_id"], :name => "index_submissions_on_user_id_and_problem_id"
198 199
199 200 create_table "tasks", :force => true do |t|
200 201 t.integer "submission_id"
201 202 t.datetime "created_at"
202 203 t.integer "status"
203 204 t.datetime "updated_at"
204 205 end
205 206
206 207 create_table "test_pairs", :force => true do |t|
207 208 t.integer "problem_id"
208 - t.text "input", :limit => 16777215
209 - t.text "solution", :limit => 16777215
209 + t.text "input", :limit => 2147483647
210 + t.text "solution", :limit => 2147483647
210 211 t.datetime "created_at", :null => false
211 212 t.datetime "updated_at", :null => false
212 213 end
213 214
214 215 create_table "test_requests", :force => true do |t|
215 216 t.integer "user_id"
216 217 t.integer "problem_id"
217 218 t.integer "submission_id"
218 219 t.string "input_file_name"
219 220 t.string "output_file_name"
220 221 t.string "running_stat"
221 222 t.integer "status"
222 223 t.datetime "updated_at", :null => false
223 224 t.datetime "submitted_at"
224 225 t.datetime "compiled_at"
225 - t.text "compiler_message"
226 + t.text "compiler_message", :limit => 16777215
226 227 t.datetime "graded_at"
227 228 t.string "grader_comment"
228 229 t.datetime "created_at", :null => false
229 230 t.float "running_time"
230 231 t.string "exit_status"
231 232 t.integer "memory_usage"
232 233 end
233 234
234 235 add_index "test_requests", ["user_id", "problem_id"], :name => "index_test_requests_on_user_id_and_problem_id"
235 236
236 237 create_table "user_contest_stats", :force => true do |t|
237 238 t.integer "user_id"
@@ -244,21 +245,21
244 245 create_table "users", :force => true do |t|
245 246 t.string "login", :limit => 50
246 247 t.string "full_name"
247 248 t.string "hashed_password"
248 249 t.string "salt", :limit => 5
249 250 t.string "alias"
250 251 t.string "email"
251 252 t.integer "site_id"
252 253 t.integer "country_id"
253 254 t.boolean "activated", :default => false
254 255 t.datetime "created_at"
255 256 t.datetime "updated_at"
257 + t.string "section"
256 258 t.boolean "enabled", :default => true
257 259 t.string "remark"
258 260 t.string "last_ip"
259 - t.string "section"
260 261 end
261 262
262 263 add_index "users", ["login"], :name => "index_users_on_login", :unique => true
263 264
264 265 end
deleted file
You need to be logged in to leave comments. Login now