49 lines
1.7 KiB
Ruby
49 lines
1.7 KiB
Ruby
#-- encoding: UTF-8
|
|
#-- copyright
|
|
# ChiliProject is a project management system.
|
|
#
|
|
# Copyright (C) 2010-2013 the ChiliProject Team
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# See doc/COPYRIGHT.rdoc for more details.
|
|
#++
|
|
|
|
desc 'Generates a configuration file for cookie store sessions.'
|
|
|
|
file 'config/initializers/session_store.rb' do
|
|
path = File.join(RAILS_ROOT, 'config', 'initializers', 'session_store.rb')
|
|
secret = ActiveSupport::SecureRandom.hex(40)
|
|
File.open(path, 'w') do |f|
|
|
f.write <<"EOF"
|
|
# This file was generated by 'rake config/initializers/session_store.rb',
|
|
# and should not be made visible to public.
|
|
# If you have a load-balancing Redmine cluster, you will need to use the
|
|
# same version of this file on each machine. And be sure to restart your
|
|
# server when you modify this file.
|
|
|
|
# Your secret key for verifying cookie session data integrity. If you
|
|
# change this key, all old sessions will become invalid! Make sure the
|
|
# secret is at least 30 characters and all random, no regular words or
|
|
# you'll be exposed to dictionary attacks.
|
|
ActionController::Base.session = {
|
|
:key => '_chiliproject_session',
|
|
#
|
|
# Uncomment and edit the :session_path below if are hosting your Redmine
|
|
# at a suburi and don't want the top level path to access the cookies
|
|
#
|
|
# See: http://www.redmine.org/issues/3968
|
|
#
|
|
# :session_path => '/url_path_to/your/redmine/',
|
|
:secret => '#{secret}'
|
|
}
|
|
EOF
|
|
end
|
|
end
|
|
|
|
desc 'Generates a configuration file for cookie store sessions.'
|
|
task :generate_session_store => ['config/initializers/session_store.rb']
|