Description:
added codejom controller, show status in public
Commit status:
[Not Reviewed]
References:
Diff options:
Comments:
0 Commit comments
0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
r254:dff48a9ca2cd - - 8 files changed: 54 inserted, 3 deleted
@@ -0,0 +1,13 | |||
|
1 | + class CodejomController < ApplicationController | |
|
2 | + | |
|
3 | + before_filter :admin_authorization | |
|
4 | + before_filter :authenticate | |
|
5 | + | |
|
6 | + def index | |
|
7 | + @user = User.find(session[:user_id]) | |
|
8 | + @problems = Problem.find(:all) | |
|
9 | + @available_problems = @problems.find_all {|p| not p.available } | |
|
10 | + @activated_problems = @problems.find_all {|p| p.available } | |
|
11 | + end | |
|
12 | + | |
|
13 | + end |
@@ -0,0 +1,11 | |||
|
1 | + %h1 Code Jom Control Panel | |
|
2 | + | |
|
3 | + %h2= "Available problems (#{@available_problems.length})" | |
|
4 | + %ul | |
|
5 | + - @available_problems.each do |problem| | |
|
6 | + %li= problem.name | |
|
7 | + | |
|
8 | + %h2= "Activated problems (#{@activated_problems.length})" | |
|
9 | + - @activated_problems.each do |problem| | |
|
10 | + = problem.name | |
|
11 | + |
@@ -0,0 +1,8 | |||
|
1 | + require 'test_helper' | |
|
2 | + | |
|
3 | + class CodejomControllerTest < ActionController::TestCase | |
|
4 | + # Replace this with your real tests. | |
|
5 | + test "the truth" do | |
|
6 | + assert true | |
|
7 | + end | |
|
8 | + end |
@@ -0,0 +1,4 | |||
|
1 | + require 'test_helper' | |
|
2 | + | |
|
3 | + class CodejomHelperTest < ActionView::TestCase | |
|
4 | + end |
@@ -1,27 +1,38 | |||
|
1 | 1 | class StatusesController < ApplicationController |
|
2 | 2 | |
|
3 | - # protect the statuses, for now | |
|
4 | - before_filter :admin_authorization | |
|
3 | + def index | |
|
4 | + if not SHOW_CONTEST_STATUS | |
|
5 | + render :status => 403 and return | |
|
6 | + end | |
|
5 | 7 | |
|
6 | - def index | |
|
7 | 8 | problem_count = Problem.available_problem_count |
|
8 | 9 | |
|
9 | 10 | @dead_users = [] |
|
10 | 11 | @level_users = {} |
|
11 | 12 | @levels = (0..CODEJOM_MAX_ALIVE_LEVEL) |
|
12 | 13 | @levels.each { |l| @level_users[l] = [] } |
|
13 | 14 | User.find(:all).each do |user| |
|
14 | 15 | if user.codejom_status==nil |
|
15 | 16 | user.update_codejom_status |
|
16 | 17 | user.codejom_status(true) # reload |
|
17 | 18 | end |
|
18 | 19 | |
|
19 | 20 | if not user.codejom_status.alive |
|
20 | 21 | @dead_users << user |
|
21 | 22 | else |
|
22 | 23 | @level_users[user.codejom_level] << user |
|
23 | 24 | end |
|
24 | 25 | end |
|
26 | + | |
|
27 | + respond_to do |format| | |
|
28 | + format.html | |
|
29 | + format.xml do | |
|
30 | + render :xml => { | |
|
31 | + :levels => @level_users, | |
|
32 | + :dead_users => @dead_users | |
|
33 | + } | |
|
34 | + end | |
|
35 | + end | |
|
25 | 36 | end |
|
26 | 37 | |
|
27 | 38 | end |
@@ -15,96 +15,97 | |||
|
15 | 15 | |
|
16 | 16 | # Skip frameworks you're not going to use (only works if using vendor/rails) |
|
17 | 17 | # config.frameworks -= [ :action_web_service, :action_mailer ] |
|
18 | 18 | |
|
19 | 19 | # Only load the plugins named here, by default all plugins in vendor/plugins are loaded |
|
20 | 20 | # config.plugins = %W( exception_notification ssl_requirement ) |
|
21 | 21 | |
|
22 | 22 | # Add additional load paths for your own custom dirs |
|
23 | 23 | # config.load_paths += %W( #{RAILS_ROOT}/extras ) |
|
24 | 24 | |
|
25 | 25 | # Force all environments to use the same logger level |
|
26 | 26 | # (by default production uses :info, the others :debug) |
|
27 | 27 | # config.log_level = :debug |
|
28 | 28 | |
|
29 | 29 | # Use the database for sessions instead of the file system |
|
30 | 30 | # (create the session table with 'rake db:sessions:create') |
|
31 | 31 | config.action_controller.session_store = :active_record_store |
|
32 | 32 | |
|
33 | 33 | # Use SQL instead of Active Record's schema dumper when creating the test database. |
|
34 | 34 | # This is necessary if your schema can't be completely dumped by the schema dumper, |
|
35 | 35 | # like if you have constraints or database-specific column types |
|
36 | 36 | # config.active_record.schema_format = :sql |
|
37 | 37 | |
|
38 | 38 | # Activate observers that should always be running |
|
39 | 39 | # config.active_record.observers = :cacher, :garbage_collector |
|
40 | 40 | |
|
41 | 41 | # Make Active Record use UTC-base instead of local time |
|
42 | 42 | config.time_zone = 'UTC' |
|
43 | 43 | |
|
44 | 44 | # Setting locales |
|
45 | 45 | config.i18n.default_locale = 'en' |
|
46 | 46 | |
|
47 | 47 | # See Rails::Configuration for more options |
|
48 | 48 | |
|
49 | 49 | # ------------- |
|
50 | 50 | # Required gems |
|
51 | 51 | # ------------- |
|
52 | 52 | config.gem "haml" |
|
53 | 53 | config.gem "tmail" |
|
54 | 54 | config.gem "rdiscount", :lib => "rdiscount" |
|
55 | 55 | |
|
56 | 56 | # NOTES on rspec: if you wan to test with rspec, you have to install |
|
57 | 57 | # rspec yourself, just call: [sudo] gem install rspec-rails |
|
58 | 58 | |
|
59 | 59 | end |
|
60 | 60 | |
|
61 | 61 | # Add new inflection rules using the following format |
|
62 | 62 | # (all these examples are active by default): |
|
63 | 63 | # Inflector.inflections do |inflect| |
|
64 | 64 | # inflect.plural /^(ox)$/i, '\1en' |
|
65 | 65 | # inflect.singular /^(ox)en/i, '\1' |
|
66 | 66 | # inflect.irregular 'person', 'people' |
|
67 | 67 | # inflect.uncountable %w( fish sheep ) |
|
68 | 68 | # end |
|
69 | 69 | |
|
70 | 70 | # Add new mime types for use in respond_to blocks: |
|
71 | 71 | # Mime::Type.register "text/richtext", :rtf |
|
72 | 72 | # Mime::Type.register "application/x-mobile", :mobile |
|
73 | 73 | |
|
74 | 74 | # Include your application configuration below |
|
75 | 75 | |
|
76 | 76 | # If you want to manage graders through web interface, set the path to |
|
77 | 77 | # the grader directory below. This dir is where raw, ev, ev-exam, |
|
78 | 78 | # scripts reside. All grader scripts will be in |
|
79 | 79 | # #{GRADER_ROOT_DIR}/scripts. |
|
80 | 80 | GRADER_ROOT_DIR = '' |
|
81 | 81 | |
|
82 | 82 | # These are where inputs and outputs of test requests are stored |
|
83 | 83 | TEST_REQUEST_INPUT_FILE_DIR = RAILS_ROOT + '/data/test_request/input' |
|
84 | 84 | TEST_REQUEST_OUTPUT_FILE_DIR = RAILS_ROOT + '/data/test_request/output' |
|
85 | 85 | |
|
86 | 86 | # To use ANALYSIS MODE, provide the testcases/testruns breakdown, |
|
87 | 87 | # and the directory of the grading result (usually in judge's dir). |
|
88 | 88 | TASK_GRADING_INFO_FILENAME = RAILS_ROOT + '/config/tasks.yml' |
|
89 | 89 | |
|
90 | 90 | # TODO: change this to where results are kept. |
|
91 | 91 | GRADING_RESULT_DIR = 'RESULT-DIR' |
|
92 | 92 | |
|
93 | 93 | # Change this to allow importing testdata into database as test-pairs. |
|
94 | 94 | # This is mainly for Code Jom contest. |
|
95 | 95 | ALLOW_TEST_PAIR_IMPORT = false |
|
96 | 96 | |
|
97 | 97 | # Uncomment so that the system validates user e-mails |
|
98 | 98 | # VALIDATE_USER_EMAILS = true |
|
99 | 99 | |
|
100 | 100 | # Uncomment so that Apache X-Sendfile is used when delivering files |
|
101 | 101 | # (e.g., in /tasks/view). |
|
102 | 102 | # USE_APACHE_XSENDFILE = true |
|
103 | 103 | |
|
104 | 104 | # Uncomment so that configuration is read only once when the server is loaded |
|
105 | 105 | # Configuration.enable_caching |
|
106 | 106 | |
|
107 | 107 | # OPTIONS FOR CODE JOM |
|
108 | 108 | # -------------------- |
|
109 | 109 | CODEJOM_MAX_ALIVE_LEVEL = 10 |
|
110 | 110 | TEST_ASSIGNMENT_EXPIRATION_DURATION = 5.minute |
|
111 | + SHOW_CONTEST_STATUS = false |
@@ -1,28 +1,29 | |||
|
1 | 1 | ActionController::Routing::Routes.draw do |map| |
|
2 | 2 | map.resources :announcements |
|
3 | 3 | map.resources :sites |
|
4 | + map.resources :statuses | |
|
4 | 5 | |
|
5 | 6 | # The priority is based upon order of creation: first created -> highest priority. |
|
6 | 7 | |
|
7 | 8 | # Sample of regular route: |
|
8 | 9 | # map.connect 'products/:id', :controller => 'catalog', :action => 'view' |
|
9 | 10 | # Keep in mind you can assign values other than :controller and :action |
|
10 | 11 | |
|
11 | 12 | # Sample of named route: |
|
12 | 13 | # map.purchase 'products/:id/purchase', :controller => 'catalog', :action => 'purchase' |
|
13 | 14 | # This route can be invoked with purchase_url(:id => product.id) |
|
14 | 15 | |
|
15 | 16 | # You can have the root of your site routed by hooking up '' |
|
16 | 17 | # -- just remember to delete public/index.html. |
|
17 | 18 | map.connect '', :controller => 'main', :action => 'login' |
|
18 | 19 | |
|
19 | 20 | # Allow downloading Web Service WSDL as a file with an extension |
|
20 | 21 | # instead of a file named 'wsdl' |
|
21 | 22 | map.connect ':controller/service.wsdl', :action => 'wsdl' |
|
22 | 23 | |
|
23 | 24 | map.connect 'tasks/view/:file.:ext', :controller => 'tasks', :action => 'view' |
|
24 | 25 | |
|
25 | 26 | # Install the default route as the lowest priority. |
|
26 | 27 | map.connect ':controller/:action/:id.:format' |
|
27 | 28 | map.connect ':controller/:action/:id' |
|
28 | 29 | end |
You need to be logged in to leave comments.
Login now