Description:
- change user_admin default action from list to index - remove duplicate button in grader control
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r588:8bdb0ec71018 - - 4 files changed: 21 inserted, 23 deleted

@@ -1,83 +1,84
1 class GradersController < ApplicationController
1 class GradersController < ApplicationController
2
2
3 before_filter :admin_authorization, except: [ :submission ]
3 before_filter :admin_authorization, except: [ :submission ]
4 before_filter(only: [:submission]) {
4 before_filter(only: [:submission]) {
5 return false unless authenticate
5 return false unless authenticate
6
6
7 if GraderConfiguration["right.user_view_submission"]
7 if GraderConfiguration["right.user_view_submission"]
8 return true;
8 return true;
9 end
9 end
10
10
11 admin_authorization
11 admin_authorization
12 }
12 }
13
13
14 verify :method => :post, :only => ['clear_all',
14 verify :method => :post, :only => ['clear_all',
15 'start_exam',
15 'start_exam',
16 'start_grading',
16 'start_grading',
17 'stop_all',
17 'stop_all',
18 'clear_terminated'],
18 'clear_terminated'],
19 :redirect_to => {:action => 'index'}
19 :redirect_to => {:action => 'index'}
20
20
21 def index
21 def index
22 redirect_to :action => 'list'
22 redirect_to :action => 'list'
23 end
23 end
24
24
25 def list
25 def list
26 @grader_processes = GraderProcess.find_running_graders
26 @grader_processes = GraderProcess.find_running_graders
27 @stalled_processes = GraderProcess.find_stalled_process
27 @stalled_processes = GraderProcess.find_stalled_process
28
28
29 @terminated_processes = GraderProcess.find_terminated_graders
29 @terminated_processes = GraderProcess.find_terminated_graders
30
30
31 @last_task = Task.find(:first,
31 @last_task = Task.find(:first,
32 :order => 'created_at DESC')
32 :order => 'created_at DESC')
33 @last_test_request = TestRequest.find(:first,
33 @last_test_request = TestRequest.find(:first,
34 :order => 'created_at DESC')
34 :order => 'created_at DESC')
35 @submission = Submission.order("id desc").limit(20)
35 @submission = Submission.order("id desc").limit(20)
36 + @backlog_submission = Submission.where('graded_at is null')
36 end
37 end
37
38
38 def clear
39 def clear
39 grader_proc = GraderProcess.find(params[:id])
40 grader_proc = GraderProcess.find(params[:id])
40 grader_proc.destroy if grader_proc!=nil
41 grader_proc.destroy if grader_proc!=nil
41 redirect_to :action => 'list'
42 redirect_to :action => 'list'
42 end
43 end
43
44
44 def clear_terminated
45 def clear_terminated
45 GraderProcess.find_terminated_graders.each do |p|
46 GraderProcess.find_terminated_graders.each do |p|
46 p.destroy
47 p.destroy
47 end
48 end
48 redirect_to :action => 'list'
49 redirect_to :action => 'list'
49 end
50 end
50
51
51 def clear_all
52 def clear_all
52 GraderProcess.find(:all).each do |p|
53 GraderProcess.find(:all).each do |p|
53 p.destroy
54 p.destroy
54 end
55 end
55 redirect_to :action => 'list'
56 redirect_to :action => 'list'
56 end
57 end
57
58
58 def view
59 def view
59 if params[:type]=='Task'
60 if params[:type]=='Task'
60 redirect_to :action => 'task', :id => params[:id]
61 redirect_to :action => 'task', :id => params[:id]
61 else
62 else
62 redirect_to :action => 'test_request', :id => params[:id]
63 redirect_to :action => 'test_request', :id => params[:id]
63 end
64 end
64 end
65 end
65
66
66 def test_request
67 def test_request
67 @test_request = TestRequest.find(params[:id])
68 @test_request = TestRequest.find(params[:id])
68 end
69 end
69
70
70 def task
71 def task
71 @task = Task.find(params[:id])
72 @task = Task.find(params[:id])
72 end
73 end
73
74
74 def submission
75 def submission
75 @submission = Submission.find(params[:id])
76 @submission = Submission.find(params[:id])
76 formatter = Rouge::Formatters::HTML.new(css_class: 'highlight', line_numbers: true )
77 formatter = Rouge::Formatters::HTML.new(css_class: 'highlight', line_numbers: true )
77 lexer = case @submission.language.name
78 lexer = case @submission.language.name
78 when "c" then Rouge::Lexers::C.new
79 when "c" then Rouge::Lexers::C.new
79 when "cpp" then Rouge::Lexers::Cpp.new
80 when "cpp" then Rouge::Lexers::Cpp.new
80 when "pas" then Rouge::Lexers::Pas.new
81 when "pas" then Rouge::Lexers::Pas.new
81 when "ruby" then Rouge::Lexers::Ruby.new
82 when "ruby" then Rouge::Lexers::Ruby.new
82 when "python" then Rouge::Lexers::Python.new
83 when "python" then Rouge::Lexers::Python.new
83 when "java" then Rouge::Lexers::Java.new
84 when "java" then Rouge::Lexers::Java.new
@@ -1,71 +1,66
1 require 'csv'
1 require 'csv'
2
2
3 class UserAdminController < ApplicationController
3 class UserAdminController < ApplicationController
4
4
5 include MailHelperMethods
5 include MailHelperMethods
6
6
7 before_filter :admin_authorization
7 before_filter :admin_authorization
8
8
9 # GETs should be safe (see http://www.w3.org/2001/tag/doc/whenToUseGet.html)
9 # GETs should be safe (see http://www.w3.org/2001/tag/doc/whenToUseGet.html)
10 verify :method => :post, :only => [ :destroy,
10 verify :method => :post, :only => [ :destroy,
11 :create, :create_from_list,
11 :create, :create_from_list,
12 :update,
12 :update,
13 :manage_contest,
13 :manage_contest,
14 :bulk_mail
14 :bulk_mail
15 ],
15 ],
16 :redirect_to => { :action => :list }
16 :redirect_to => { :action => :list }
17
17
18 def index
18 def index
19 - list
20 - render :action => 'list'
21 - end
22 -
23 - def list
24 @user_count = User.count
19 @user_count = User.count
25 if params[:page] == 'all'
20 if params[:page] == 'all'
26 @users = User.all
21 @users = User.all
27 @paginated = false
22 @paginated = false
28 else
23 else
29 @users = User.paginate :page => params[:page]
24 @users = User.paginate :page => params[:page]
30 @paginated = true
25 @paginated = true
31 end
26 end
32 @hidden_columns = ['hashed_password', 'salt', 'created_at', 'updated_at']
27 @hidden_columns = ['hashed_password', 'salt', 'created_at', 'updated_at']
33 @contests = Contest.enabled
28 @contests = Contest.enabled
34 end
29 end
35
30
36 def active
31 def active
37 sessions = ActiveRecord::SessionStore::Session.find(:all, :conditions => ["updated_at >= ?", 60.minutes.ago])
32 sessions = ActiveRecord::SessionStore::Session.find(:all, :conditions => ["updated_at >= ?", 60.minutes.ago])
38 @users = []
33 @users = []
39 sessions.each do |session|
34 sessions.each do |session|
40 if session.data[:user_id]
35 if session.data[:user_id]
41 @users << User.find(session.data[:user_id])
36 @users << User.find(session.data[:user_id])
42 end
37 end
43 end
38 end
44 end
39 end
45
40
46 def show
41 def show
47 @user = User.find(params[:id])
42 @user = User.find(params[:id])
48 end
43 end
49
44
50 def new
45 def new
51 @user = User.new
46 @user = User.new
52 end
47 end
53
48
54 def create
49 def create
55 @user = User.new(params[:user])
50 @user = User.new(params[:user])
56 @user.activated = true
51 @user.activated = true
57 if @user.save
52 if @user.save
58 flash[:notice] = 'User was successfully created.'
53 flash[:notice] = 'User was successfully created.'
59 redirect_to :action => 'index'
54 redirect_to :action => 'index'
60 else
55 else
61 render :action => 'new'
56 render :action => 'new'
62 end
57 end
63 end
58 end
64
59
65 def clear_last_ip
60 def clear_last_ip
66 @user = User.find(params[:id])
61 @user = User.find(params[:id])
67 @user.last_ip = nil
62 @user.last_ip = nil
68 @user.save
63 @user.save
69 redirect_to action: 'index', page: params[:page]
64 redirect_to action: 'index', page: params[:page]
70 end
65 end
71
66
@@ -1,51 +1,52
1 # Methods added to this helper will be available to all templates in the application.
1 # Methods added to this helper will be available to all templates in the application.
2 module ApplicationHelper
2 module ApplicationHelper
3
3
4 + #new bootstrap header
4 def navbar_user_header
5 def navbar_user_header
5 left_menu = ''
6 left_menu = ''
6 right_menu = ''
7 right_menu = ''
7 user = User.find(session[:user_id])
8 user = User.find(session[:user_id])
8
9
9 if (user!=nil) and (GraderConfiguration.show_tasks_to?(user))
10 if (user!=nil) and (GraderConfiguration.show_tasks_to?(user))
10 left_menu << add_menu("#{I18n.t 'menu.tasks'}", 'tasks', 'list')
11 left_menu << add_menu("#{I18n.t 'menu.tasks'}", 'tasks', 'list')
11 left_menu << add_menu("#{I18n.t 'menu.submissions'}", 'main', 'submission')
12 left_menu << add_menu("#{I18n.t 'menu.submissions'}", 'main', 'submission')
12 left_menu << add_menu("#{I18n.t 'menu.test'}", 'test', 'index')
13 left_menu << add_menu("#{I18n.t 'menu.test'}", 'test', 'index')
13 end
14 end
14
15
15 if GraderConfiguration['right.user_hall_of_fame']
16 if GraderConfiguration['right.user_hall_of_fame']
16 left_menu << add_menu("#{I18n.t 'menu.hall_of_fame'}", 'report', 'problem_hof')
17 left_menu << add_menu("#{I18n.t 'menu.hall_of_fame'}", 'report', 'problem_hof')
17 end
18 end
18
19
19 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-question-sign')}".html_safe, 'main', 'help')
20 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-question-sign')}".html_safe, 'main', 'help')
20 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-comment')}".html_safe, 'messages', 'list', {title: I18n.t('menu.messages'), data: {toggle: 'tooltip'}})
21 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-comment')}".html_safe, 'messages', 'list', {title: I18n.t('menu.messages'), data: {toggle: 'tooltip'}})
21 if GraderConfiguration['system.user_setting_enabled']
22 if GraderConfiguration['system.user_setting_enabled']
22 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-cog')}".html_safe, 'users', 'index', {title: I18n.t('menu.settings'), data: {toggle: 'tooltip'}})
23 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-cog')}".html_safe, 'users', 'index', {title: I18n.t('menu.settings'), data: {toggle: 'tooltip'}})
23 end
24 end
24 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-log-out')} #{user.full_name}".html_safe, 'main', 'login', {title: I18n.t('menu.log_out'), data: {toggle: 'tooltip'}})
25 right_menu << add_menu("#{content_tag(:span,'',class: 'glyphicon glyphicon-log-out')} #{user.full_name}".html_safe, 'main', 'login', {title: I18n.t('menu.log_out'), data: {toggle: 'tooltip'}})
25
26
26
27
27 result = content_tag(:ul,left_menu.html_safe,class: 'nav navbar-nav') + content_tag(:ul,right_menu.html_safe,class: 'nav navbar-nav navbar-right')
28 result = content_tag(:ul,left_menu.html_safe,class: 'nav navbar-nav') + content_tag(:ul,right_menu.html_safe,class: 'nav navbar-nav navbar-right')
28 end
29 end
29
30
30 def add_menu(title, controller, action,html_option = {})
31 def add_menu(title, controller, action,html_option = {})
31 link_option = {controller: controller, action: action}
32 link_option = {controller: controller, action: action}
32 html_option[:class] = (html_option[:class] || '') + " active" if current_page?(link_option)
33 html_option[:class] = (html_option[:class] || '') + " active" if current_page?(link_option)
33 content_tag(:li, link_to(title,link_option),html_option)
34 content_tag(:li, link_to(title,link_option),html_option)
34 end
35 end
35
36
36 def user_header
37 def user_header
37 menu_items = ''
38 menu_items = ''
38 user = User.find(session[:user_id])
39 user = User.find(session[:user_id])
39
40
40 if (user!=nil) and (session[:admin])
41 if (user!=nil) and (session[:admin])
41 # admin menu
42 # admin menu
42 menu_items << "<b>Administrative task:</b> "
43 menu_items << "<b>Administrative task:</b> "
43 append_to menu_items, '[Announcements]', 'announcements', 'index'
44 append_to menu_items, '[Announcements]', 'announcements', 'index'
44 append_to menu_items, '[Msg console]', 'messages', 'console'
45 append_to menu_items, '[Msg console]', 'messages', 'console'
45 append_to menu_items, '[Problems]', 'problems', 'index'
46 append_to menu_items, '[Problems]', 'problems', 'index'
46 append_to menu_items, '[Users]', 'user_admin', 'index'
47 append_to menu_items, '[Users]', 'user_admin', 'index'
47 append_to menu_items, '[Results]', 'user_admin', 'user_stat'
48 append_to menu_items, '[Results]', 'user_admin', 'user_stat'
48 append_to menu_items, '[Report]', 'report', 'multiple_login'
49 append_to menu_items, '[Report]', 'report', 'multiple_login'
49 append_to menu_items, '[Graders]', 'graders', 'list'
50 append_to menu_items, '[Graders]', 'graders', 'list'
50 append_to menu_items, '[Contests]', 'contest_management', 'index'
51 append_to menu_items, '[Contests]', 'contest_management', 'index'
51 append_to menu_items, '[Sites]', 'sites', 'index'
52 append_to menu_items, '[Sites]', 'sites', 'index'
@@ -1,81 +1,82
1 - content_for :head do
1 - content_for :head do
2 <meta http-equiv ="refresh" content="60"/>
2 <meta http-equiv ="refresh" content="60"/>
3
3
4 %h1 Grader information
4 %h1 Grader information
5
5
6 %p
6 %p
7 = link_to 'Refresh', { :action => 'list' }, class: 'btn btn-info'
7 = link_to 'Refresh', { :action => 'list' }, class: 'btn btn-info'
8
8
9 .panel.panel-primary
9 .panel.panel-primary
10 .panel-heading
10 .panel-heading
11 Grader control:
11 Grader control:
12 .panel-body
12 .panel-body
13 =link_to 'Start Graders in grading env', { action: 'start_grading'}, class: 'btn btn-default', method: 'post'
13 =link_to 'Start Graders in grading env', { action: 'start_grading'}, class: 'btn btn-default', method: 'post'
14 =link_to 'Start Graders in exam env', { action: 'start_exam'}, class: 'btn btn-default', method: 'post'
14 =link_to 'Start Graders in exam env', { action: 'start_exam'}, class: 'btn btn-default', method: 'post'
15 =link_to 'Stop all running Graders', { action: 'stop_all'}, class: 'btn btn-default', method: 'post'
15 =link_to 'Stop all running Graders', { action: 'stop_all'}, class: 'btn btn-default', method: 'post'
16 =link_to 'Clear all data', { action: 'clear_all'}, class: 'btn btn-default', method: 'post'
16 =link_to 'Clear all data', { action: 'clear_all'}, class: 'btn btn-default', method: 'post'
17
17
18 - .submitbox
19 - .item
20 - Grader control:
21 - .item
22 - = form_for :clear, :url => {:action => 'start_grading'} do |f|
23 - = submit_tag 'Start graders in grading env'
24 - .item
25 - = form_for :clear, :url => {:action => 'start_exam'} do |f|
26 - = submit_tag 'Start graders in exam env'
27 - .item
28 - = form_for :clear, :url => {:action => 'stop_all'} do |f|
29 - = submit_tag 'Stop all running graders'
30 - .item
31 - = form_for :clear, :url => {:action => 'clear_all'} do |f|
32 - = submit_tag 'Clear all data'
33 - %br{:style => 'clear:both'}/
34 -
35 .row
18 .row
36 .col-md-6
19 .col-md-6
37 - if @last_task
20 - if @last_task
38 Last task:
21 Last task:
39 = link_to "#{@last_task.id}", :action => 'view', :id => @last_task.id, :type => 'Task'
22 = link_to "#{@last_task.id}", :action => 'view', :id => @last_task.id, :type => 'Task'
40
23
41 %br/
24 %br/
42
25
43 - if @last_test_request
26 - if @last_test_request
44 Last test_request:
27 Last test_request:
45 = link_to "#{@last_test_request.id}", :action => 'view', :id => @last_test_request.id, :type => 'TestRequest'
28 = link_to "#{@last_test_request.id}", :action => 'view', :id => @last_test_request.id, :type => 'TestRequest'
46
29
47 %h2 Current graders
30 %h2 Current graders
48
31
49 = render :partial => 'grader_list', :locals => {:grader_list => @grader_processes}
32 = render :partial => 'grader_list', :locals => {:grader_list => @grader_processes}
50
33
51 %h2 Stalled graders
34 %h2 Stalled graders
52
35
53 = render :partial => 'grader_list', :locals => {:grader_list => @stalled_processes}
36 = render :partial => 'grader_list', :locals => {:grader_list => @stalled_processes}
54
37
55 %h2 Terminated graders
38 %h2 Terminated graders
56
39
57 %p= link_to 'Clear data for terminated graders', { action: 'clear_terminated'}, class: 'btn btn-default', method: 'post'
40 %p= link_to 'Clear data for terminated graders', { action: 'clear_terminated'}, class: 'btn btn-default', method: 'post'
58
41
59 = render :partial => 'grader_list', :locals => {:grader_list => @terminated_processes}
42 = render :partial => 'grader_list', :locals => {:grader_list => @terminated_processes}
60 .col-md-6
43 .col-md-6
61 %h2 Last 20 submissions
44 %h2 Last 20 submissions
62 %table.table.table-striped.table-condensed
45 %table.table.table-striped.table-condensed
63 %thead
46 %thead
64 %th ID
47 %th ID
65 %th User
48 %th User
66 %th Problem
49 %th Problem
67 %th Submitted
50 %th Submitted
68 %th Graded
51 %th Graded
69 %th Result
52 %th Result
70 - %th
71 %tbody
53 %tbody
72 - @submission.each do |sub|
54 - @submission.each do |sub|
73 %tr.inactive
55 %tr.inactive
74 %td= link_to sub.id, controller: 'graders' ,action: 'submission', id: sub.id
56 %td= link_to sub.id, controller: 'graders' ,action: 'submission', id: sub.id
75 %td= sub.try(:user).try(:full_name)
57 %td= sub.try(:user).try(:full_name)
76 %td= sub.try(:problem).try(:full_name)
58 %td= sub.try(:problem).try(:full_name)
77 %td= "#{time_ago_in_words(sub.submitted_at)} ago"
59 %td= "#{time_ago_in_words(sub.submitted_at)} ago"
78 %td= sub.graded_at ? "#{time_ago_in_words(sub.graded_at)} ago" : " "
60 %td= sub.graded_at ? "#{time_ago_in_words(sub.graded_at)} ago" : " "
79 %td= sub.grader_comment
61 %td= sub.grader_comment
62 + %h2 Ungraded submission
63 + %table.table.table-striped.table-condensed
64 + %thead
65 + %th ID
66 + %th User
67 + %th Problem
68 + %th Submitted
69 + %th Graded
70 + %th Result
71 + %tbody
72 + - @backlog_submission.each do |sub|
73 + %tr.inactive
74 + %td= link_to sub.id, controller: 'graders' ,action: 'submission', id: sub.id
75 + %td= sub.try(:user).try(:full_name)
76 + %td= sub.try(:problem).try(:full_name)
77 + %td= "#{time_ago_in_words(sub.submitted_at)} ago"
78 + %td= sub.graded_at ? "#{time_ago_in_words(sub.graded_at)} ago" : " "
79 + %td= sub.grader_comment
80
80
81
81
82 +
You need to be logged in to leave comments. Login now