Description:
start working on e-mail registration git-svn-id: http://theory.cpe.ku.ac.th/grader/web/trunk@294 6386c4cd-e34a-4fa8-8920-d93eb39b512e
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r155:f1e975d4e9fc - - 14 files changed: 144 inserted, 8 deleted

@@ -0,0 +1,23
1 + class AddMoreOptionsToConfigurations < ActiveRecord::Migration
2 + def self.up
3 + # If the server is in contest mode and
4 + # Configuration['contest.multisites'] is true
5 + # the menu for site administrator is shown.
6 +
7 + Configuration.create(:key => 'contest.multisites',
8 + :value_type => 'boolean',
9 + :value => 'false')
10 +
11 + # If Configuration['system.online_registration'] is true,
12 + # the registration menu would appear
13 +
14 + Configuration.create(:key => 'system.online_registration',
15 + :value_type => 'boolean',
16 + :value => 'false')
17 + end
18 +
19 + def self.down
20 + Configuration.find_by_key('contest.multisites').destroy
21 + Configuration.find_by_key('system.online_registration').destroy
22 + end
23 + end
@@ -0,0 +1,15
1 + class AddActivatedToUsers < ActiveRecord::Migration
2 + def self.up
3 + add_column :users, :activated, :boolean, :default => 0
4 +
5 + User.find(:all).each do |user|
6 + user.activated = true
7 + user.save
8 + end
9 + end
10 +
11 +
12 + def self.down
13 + remove_column :users, :activated
14 + end
15 + end
@@ -0,0 +1,3
1 + #!/usr/bin/env ruby
2 + require File.dirname(__FILE__) + '/../config/boot'
3 + require 'commands/dbconsole'
@@ -0,0 +1,3
1 + #!/usr/bin/env ruby
2 + require File.dirname(__FILE__) + '/../../config/boot'
3 + require 'commands/performance/request'
@@ -0,0 +1,53
1 +
2 + require File.dirname(__FILE__) + '/../spec_helper'
3 +
4 + describe User do
5 +
6 + before(:each) do
7 + @password = "hello"
8 + @salt = "123"
9 + @john = stub_model(User, :salt => @salt,
10 + :hashed_password => User.encrypt(@password,@salt))
11 + end
12 +
13 + it "should authenticate activated user" do
14 + @john.should_receive(:activated).and_return(true)
15 + @john.authenticated?(@password).should == true
16 + end
17 +
18 + it "should not authenticate inactivated user" do
19 + @john.should_receive(:activated).and_return(false)
20 + @john.authenticated?(@password).should == false
21 + end
22 +
23 + it "should not authenticate user with incorrect password" do
24 + @john.should_receive(:activated).and_return(true)
25 + @john.should_receive(:hashed_password).and_return("byebye")
26 + @john.authenticated?(@password).should == false
27 + end
28 +
29 + end
30 +
31 + describe User, "during registration" do
32 +
33 + class User
34 + public :encrypt_new_password
35 + end
36 +
37 + before(:each) do
38 + @john = User.new(:login => 'john', :password => 'hello')
39 + @john.encrypt_new_password
40 + end
41 +
42 + it "should produce and accept activation key" do
43 + activation_key = @john.activation_key
44 +
45 + @john.verify_activation_key(activation_key).should == true
46 + end
47 +
48 + it "should not accept invalid activation key" do
49 + @john.verify_activation_key("12345").should == false
50 + end
51 +
52 +
53 + end
@@ -22,12 +22,13
22 def new
22 def new
23 @user = User.new
23 @user = User.new
24 end
24 end
25
25
26 def create
26 def create
27 @user = User.new(params[:user])
27 @user = User.new(params[:user])
28 + @user.activated = true
28 if @user.save
29 if @user.save
29 flash[:notice] = 'User was successfully created.'
30 flash[:notice] = 'User was successfully created.'
30 redirect_to :action => 'list'
31 redirect_to :action => 'list'
31 else
32 else
32 render :action => 'new'
33 render :action => 'new'
33 end
34 end
@@ -41,12 +42,13
41 user = User.new
42 user = User.new
42 user.login = items[0]
43 user.login = items[0]
43 user.full_name = items[1]
44 user.full_name = items[1]
44 user.alias = items[2]
45 user.alias = items[2]
45 user.password = items[3]
46 user.password = items[3]
46 user.password_confirmation = items[3]
47 user.password_confirmation = items[3]
48 + user.activated = true
47 user.save
49 user.save
48 end
50 end
49 end
51 end
50 redirect_to :action => 'list'
52 redirect_to :action => 'list'
51 end
53 end
52
54
@@ -100,13 +100,17
100 @@configurations[key] = Configuration.convert_type(val,conf.value_type)
100 @@configurations[key] = Configuration.convert_type(val,conf.value_type)
101 end
101 end
102 end
102 end
103
103
104 def self.read_one_key(key)
104 def self.read_one_key(key)
105 conf = Configuration.find_by_key(key)
105 conf = Configuration.find_by_key(key)
106 - return Configuration.convert_type(conf.value,conf.value_type)
106 + if conf
107 + return Configuration.convert_type(conf.value,conf.value_type)
108 + else
109 + return nil
110 + end
107 end
111 end
108
112
109 def self.read_grading_info
113 def self.read_grading_info
110 f = File.open(TASK_GRADING_INFO_FILENAME)
114 f = File.open(TASK_GRADING_INFO_FILENAME)
111 @@task_grading_info = YAML.load(f)
115 @@task_grading_info = YAML.load(f)
112 f.close
116 f.close
@@ -34,13 +34,17
34 def self.authenticate(login, password)
34 def self.authenticate(login, password)
35 user = find_by_login(login)
35 user = find_by_login(login)
36 return user if user && user.authenticated?(password)
36 return user if user && user.authenticated?(password)
37 end
37 end
38
38
39 def authenticated?(password)
39 def authenticated?(password)
40 - hashed_password == User.encrypt(password,self.salt)
40 + if self.activated
41 + hashed_password == User.encrypt(password,self.salt)
42 + else
43 + false
44 + end
41 end
45 end
42
46
43 def admin?
47 def admin?
44 self.roles.detect {|r| r.name == 'admin' }
48 self.roles.detect {|r| r.name == 'admin' }
45 end
49 end
46
50
@@ -69,12 +73,20
69 end
73 end
70
74
71 def alias_for_editing=(e)
75 def alias_for_editing=(e)
72 self.alias=e
76 self.alias=e
73 end
77 end
74
78
79 + def activation_key
80 + Digest::SHA1.hexdigest(self.hashed_password)[0..7]
81 + end
82 +
83 + def verify_activation_key(key)
84 + key == activation_key
85 + end
86 +
75 protected
87 protected
76 def encrypt_new_password
88 def encrypt_new_password
77 return if password.blank?
89 return if password.blank?
78 self.salt = (10+rand(90)).to_s
90 self.salt = (10+rand(90)).to_s
79 self.hashed_password = User.encrypt(self.password,self.salt)
91 self.hashed_password = User.encrypt(self.password,self.salt)
80 end
92 end
@@ -27,13 +27,20
27 %td{:align => "right"} Password:
27 %td{:align => "right"} Password:
28 %td= password_field_tag
28 %td= password_field_tag
29 = submit_tag 'Login'
29 = submit_tag 'Login'
30
30
31 %br/
31 %br/
32
32
33 - - if Configuration['system.mode']=='contest'
33 + -# if Configuration['system.online_registration']
34 + Want to participate?
35 + %b
36 + Please
37 + = link_to 'register.', :controller => :users, :action => :new
38 + %br/
39 +
40 + - if (Configuration['system.mode']=='contest') and (Configuration['contest.multisites'])
34 %script{:type => 'text/javascript'}
41 %script{:type => 'text/javascript'}
35 var siteList = new Array();
42 var siteList = new Array();
36 - @countries.each do |country|
43 - @countries.each do |country|
37 = "siteList[#{country.id}] = new Array();"
44 = "siteList[#{country.id}] = new Array();"
38 - country.sites.each do |site|
45 - country.sites.each do |site|
39 = "siteList[#{country.id}][#{site.id}] = \"#{site.name}\";"
46 = "siteList[#{country.id}][#{site.id}] = \"#{site.name}\";"
@@ -79,20 +79,20
79 parse_gem_version(read_environment_rb)
79 parse_gem_version(read_environment_rb)
80 end
80 end
81 end
81 end
82
82
83 def load_rubygems
83 def load_rubygems
84 require 'rubygems'
84 require 'rubygems'
85 -
85 + min_version = '1.1.1'
86 - unless rubygems_version >= '0.9.4'
86 + unless rubygems_version >= min_version
87 - $stderr.puts %(Rails requires RubyGems >= 0.9.4 (you have #{rubygems_version}). Please `gem update --system` and try again.)
87 + $stderr.puts %Q(Rails requires RubyGems >= #{min_version} (you have #{rubygems_version}). Please `gem update --system` and try again.)
88 exit 1
88 exit 1
89 end
89 end
90
90
91 rescue LoadError
91 rescue LoadError
92 - $stderr.puts %(Rails requires RubyGems >= 0.9.4. Please install RubyGems and try again: http://rubygems.rubyforge.org)
92 + $stderr.puts %Q(Rails requires RubyGems >= #{min_version}. Please install RubyGems and try again: http://rubygems.rubyforge.org)
93 exit 1
93 exit 1
94 end
94 end
95
95
96 def parse_gem_version(text)
96 def parse_gem_version(text)
97 $1 if text =~ /^[^#]*RAILS_GEM_VERSION\s*=\s*["']([!~<>=]*\s*[\d.]+)["']/
97 $1 if text =~ /^[^#]*RAILS_GEM_VERSION\s*=\s*["']([!~<>=]*\s*[\d.]+)["']/
98 end
98 end
@@ -40,14 +40,21
40
40
41 # Make Active Record use UTC-base instead of local time
41 # Make Active Record use UTC-base instead of local time
42 config.active_record.default_timezone = :utc
42 config.active_record.default_timezone = :utc
43
43
44 # See Rails::Configuration for more options
44 # See Rails::Configuration for more options
45
45
46 + # -------------
47 + # Required gems
48 + # -------------
49 +
46 # This is for rspec
50 # This is for rspec
47 config.gem "rspec-rails", :lib => "spec"
51 config.gem "rspec-rails", :lib => "spec"
52 + config.gem "haml"
53 + config.gem "pony"
54 + #config.gem "BlueCloth", :lig => "bluecloth"
48 end
55 end
49
56
50 # Add new inflection rules using the following format
57 # Add new inflection rules using the following format
51 # (all these examples are active by default):
58 # (all these examples are active by default):
52 # Inflector.inflections do |inflect|
59 # Inflector.inflections do |inflect|
53 # inflect.plural /^(ox)$/i, '\1en'
60 # inflect.plural /^(ox)$/i, '\1en'
@@ -6,13 +6,13
6 # to create the application database on another system, you should be using db:schema:load, not running
6 # to create the application database on another system, you should be using db:schema:load, not running
7 # all the migrations from scratch. The latter is a flawed and unsustainable approach (the more migrations
7 # all the migrations from scratch. The latter is a flawed and unsustainable approach (the more migrations
8 # you'll amass, the slower it'll run and the greater likelihood for issues).
8 # you'll amass, the slower it'll run and the greater likelihood for issues).
9 #
9 #
10 # It's strongly recommended to check this file into your version control system.
10 # It's strongly recommended to check this file into your version control system.
11
11
12 - ActiveRecord::Schema.define(:version => 20081107145815) do
12 + ActiveRecord::Schema.define(:version => 20081204122651) do
13
13
14 create_table "announcements", :force => true do |t|
14 create_table "announcements", :force => true do |t|
15 t.string "author"
15 t.string "author"
16 t.text "body"
16 t.text "body"
17 t.boolean "published"
17 t.boolean "published"
18 t.datetime "created_at"
18 t.datetime "created_at"
@@ -179,11 +179,12
179 t.string "hashed_password"
179 t.string "hashed_password"
180 t.string "salt", :limit => 5
180 t.string "salt", :limit => 5
181 t.string "alias"
181 t.string "alias"
182 t.string "email"
182 t.string "email"
183 t.integer "site_id"
183 t.integer "site_id"
184 t.integer "country_id"
184 t.integer "country_id"
185 + t.boolean "activated", :default => false
185 end
186 end
186
187
187 add_index "users", ["login"], :name => "index_users_on_login", :unique => true
188 add_index "users", ["login"], :name => "index_users_on_login", :unique => true
188
189
189 end
190 end
@@ -1,11 +1,16
1
1
2 require File.dirname(__FILE__) + '/../spec_helper'
2 require File.dirname(__FILE__) + '/../spec_helper'
3
3
4 describe Configuration do
4 describe Configuration do
5
5
6 + # only work with cached configuration
7 + class Configuration
8 + @@cache = true
9 + end
10 +
6 before(:each) do
11 before(:each) do
7 @int_config = mock(Configuration,
12 @int_config = mock(Configuration,
8 :id => 1,
13 :id => 1,
9 :key => 'mode',
14 :key => 'mode',
10 :value_type => 'integer',
15 :value_type => 'integer',
11 :value => '30')
16 :value => '30')
@@ -1,7 +1,8
1 begin
1 begin
2 require File.join(File.dirname(__FILE__), 'lib', 'haml') # From here
2 require File.join(File.dirname(__FILE__), 'lib', 'haml') # From here
3 rescue LoadError
3 rescue LoadError
4 require 'haml' # From gem
4 require 'haml' # From gem
5 end
5 end
6
6
7 + # Load Haml and Sass
7 Haml.init_rails(binding)
8 Haml.init_rails(binding)
You need to be logged in to leave comments. Login now