Merge branch 'guange_dev' into szzh
This commit is contained in:
commit
04e1ebbc6d
5
Gemfile
5
Gemfile
|
@ -4,10 +4,11 @@ source 'http://ruby.taobao.org'
|
||||||
unless RUBY_PLATFORM =~ /w32/
|
unless RUBY_PLATFORM =~ /w32/
|
||||||
# unix-like only
|
# unix-like only
|
||||||
gem 'iconv'
|
gem 'iconv'
|
||||||
gem 'rubyzip'
|
|
||||||
gem 'zip-zip'
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
gem 'rubyzip'
|
||||||
|
gem 'delayed_job_active_record'#, :group => :production
|
||||||
|
gem 'daemons'
|
||||||
gem 'grape', '~> 0.9.0'
|
gem 'grape', '~> 0.9.0'
|
||||||
gem 'grape-entity'
|
gem 'grape-entity'
|
||||||
gem 'seems_rateable', '~> 1.0.13'
|
gem 'seems_rateable', '~> 1.0.13'
|
||||||
|
|
|
@ -88,9 +88,7 @@ class AccountController < ApplicationController
|
||||||
# create a new token for password recovery
|
# create a new token for password recovery
|
||||||
token = Token.new(:user => user, :action => "recovery")
|
token = Token.new(:user => user, :action => "recovery")
|
||||||
if token.save
|
if token.save
|
||||||
Thread.new do
|
Mailer.run.lost_password(token)
|
||||||
Mailer.lost_password(token).deliver
|
|
||||||
end
|
|
||||||
flash[:notice] = l(:notice_account_lost_email_sent)
|
flash[:notice] = l(:notice_account_lost_email_sent)
|
||||||
redirect_to signin_url
|
redirect_to signin_url
|
||||||
return
|
return
|
||||||
|
@ -228,7 +226,7 @@ class AccountController < ApplicationController
|
||||||
user = User.find(params[:user]) if params[:user]
|
user = User.find(params[:user]) if params[:user]
|
||||||
token = Token.new(:user => user, :action => "register")
|
token = Token.new(:user => user, :action => "register")
|
||||||
if token.save
|
if token.save
|
||||||
Mailer.register(token).deliver
|
Mailer.run.register(token)
|
||||||
|
|
||||||
else
|
else
|
||||||
yield if block_given?
|
yield if block_given?
|
||||||
|
@ -366,7 +364,7 @@ class AccountController < ApplicationController
|
||||||
token = Token.new(:user => user, :action => "register")
|
token = Token.new(:user => user, :action => "register")
|
||||||
if user.save and token.save
|
if user.save and token.save
|
||||||
UserStatus.create(:user_id => user.id, :changsets_count => 0, :watchers_count => 0)
|
UserStatus.create(:user_id => user.id, :changsets_count => 0, :watchers_count => 0)
|
||||||
Mailer.register(token).deliver
|
Mailer.run.register(token)
|
||||||
|
|
||||||
|
|
||||||
flash[:notice] = l(:notice_account_register_done)
|
flash[:notice] = l(:notice_account_register_done)
|
||||||
|
@ -401,7 +399,7 @@ class AccountController < ApplicationController
|
||||||
if user.save
|
if user.save
|
||||||
UserStatus.create(:user_id => user.id ,:changsets_count => 0, :watchers_count => 0)
|
UserStatus.create(:user_id => user.id ,:changsets_count => 0, :watchers_count => 0)
|
||||||
# Sends an email to the administrators
|
# Sends an email to the administrators
|
||||||
Mailer.account_activation_request(user).deliver
|
Mailer.run.account_activation_request(user)
|
||||||
account_pending
|
account_pending
|
||||||
else
|
else
|
||||||
yield if block_given?
|
yield if block_given?
|
||||||
|
|
|
@ -13,7 +13,7 @@ class AppliedProjectController < ApplicationController
|
||||||
@applieds = AppliedProject.where("user_id = ? and project_id = ?", params[:user_id],params[:project_id])
|
@applieds = AppliedProject.where("user_id = ? and project_id = ?", params[:user_id],params[:project_id])
|
||||||
if @applieds.count == 0
|
if @applieds.count == 0
|
||||||
appliedproject = AppliedProject.create(:user_id => params[:user_id], :project_id => params[:project_id])
|
appliedproject = AppliedProject.create(:user_id => params[:user_id], :project_id => params[:project_id])
|
||||||
Mailer.applied_project(appliedproject).deliver
|
Mailer.run.applied_project(appliedproject)
|
||||||
@status = 2
|
@status = 2
|
||||||
else
|
else
|
||||||
@status = 1
|
@status = 1
|
||||||
|
@ -31,7 +31,7 @@ class AppliedProjectController < ApplicationController
|
||||||
@applieds = AppliedProject.where("user_id = ? and project_id = ?", params[:user_id],params[:project_id])
|
@applieds = AppliedProject.where("user_id = ? and project_id = ?", params[:user_id],params[:project_id])
|
||||||
if @applieds.count == 0
|
if @applieds.count == 0
|
||||||
appliedproject = AppliedProject.create(:user_id => params[:user_id], :project_id => params[:project_id])
|
appliedproject = AppliedProject.create(:user_id => params[:user_id], :project_id => params[:project_id])
|
||||||
Mailer.applied_project(appliedproject).deliver
|
Mailer.run.applied_project(appliedproject)
|
||||||
end
|
end
|
||||||
|
|
||||||
#redirect_to project_path(params[:project_id])
|
#redirect_to project_path(params[:project_id])
|
||||||
|
|
|
@ -110,7 +110,7 @@ class DocumentsController < ApplicationController
|
||||||
render_attachment_warning_if_needed(@document)
|
render_attachment_warning_if_needed(@document)
|
||||||
|
|
||||||
if attachments.present? && attachments[:files].present? && Setting.notified_events.include?('document_added')
|
if attachments.present? && attachments[:files].present? && Setting.notified_events.include?('document_added')
|
||||||
Mailer.attachments_added(attachments[:files]).deliver
|
Mailer.run.attachments_added(attachments[:files])
|
||||||
end
|
end
|
||||||
redirect_to document_url(@document)
|
redirect_to document_url(@document)
|
||||||
end
|
end
|
||||||
|
|
|
@ -314,7 +314,7 @@ class FilesController < ApplicationController
|
||||||
render_attachment_warning_if_needed(container)
|
render_attachment_warning_if_needed(container)
|
||||||
|
|
||||||
if !attachments.empty? && !attachments[:files].blank? && Setting.notified_events.include?('file_added')
|
if !attachments.empty? && !attachments[:files].blank? && Setting.notified_events.include?('file_added')
|
||||||
Mailer.attachments_added(attachments[:files]).deliver
|
Mailer.run.attachments_added(attachments[:files])
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO: 临时用 nyan
|
# TODO: 临时用 nyan
|
||||||
|
@ -343,7 +343,7 @@ class FilesController < ApplicationController
|
||||||
attachments = Attachment.attach_filesex(@course, params[:attachments], params[:attachment_type])
|
attachments = Attachment.attach_filesex(@course, params[:attachments], params[:attachment_type])
|
||||||
|
|
||||||
if !attachments.empty? && !attachments[:files].blank? && Setting.notified_events.include?('file_added')
|
if !attachments.empty? && !attachments[:files].blank? && Setting.notified_events.include?('file_added')
|
||||||
Mailer.attachments_added(attachments[:files]).deliver
|
Mailer.run.attachments_added(attachments[:files])
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO: 临时用 nyan
|
# TODO: 临时用 nyan
|
||||||
|
|
|
@ -336,7 +336,7 @@ class ProjectsController < ApplicationController
|
||||||
def send_mail_to_member
|
def send_mail_to_member
|
||||||
if !params[:mail].blank? && User.find_by_mail(params[:mail].to_s).nil?
|
if !params[:mail].blank? && User.find_by_mail(params[:mail].to_s).nil?
|
||||||
email = params[:mail]
|
email = params[:mail]
|
||||||
Mailer.send_invite_in_project(email, @project, User.current).deliver
|
Mailer.run.send_invite_in_project(email, @project, User.current)
|
||||||
@is_zhuce =false
|
@is_zhuce =false
|
||||||
flash[:notice] = l(:notice_email_sent, :value => email)
|
flash[:notice] = l(:notice_email_sent, :value => email)
|
||||||
else
|
else
|
||||||
|
|
|
@ -131,7 +131,7 @@ update
|
||||||
@project_path=@root_path+"htdocs/"+@repository_name
|
@project_path=@root_path+"htdocs/"+@repository_name
|
||||||
@repository_tag=params[:repository][:upassword] || params[:repository][:password]
|
@repository_tag=params[:repository][:upassword] || params[:repository][:password]
|
||||||
@repo_name=User.current.login.to_s+"_"+params[:repository][:identifier]
|
@repo_name=User.current.login.to_s+"_"+params[:repository][:identifier]
|
||||||
logger.info "htpasswd -mb "+@root_path+"user.passwd "+@repo_name+": "+@repository_tag
|
logger.info "htpasswd -mb "+@root_path+"htdocs/user.passwd "+@repo_name+": "+@repository_tag
|
||||||
logger.info "the value of create repository"+@root_path+": "+@repository_name+": "+@project_path+": "+@repo_name
|
logger.info "the value of create repository"+@root_path+": "+@repository_name+": "+@project_path+": "+@repo_name
|
||||||
attrs = pickup_extra_info
|
attrs = pickup_extra_info
|
||||||
if((@repository_tag!="")&¶ms[:repository_scm]=="Git")
|
if((@repository_tag!="")&¶ms[:repository_scm]=="Git")
|
||||||
|
@ -147,9 +147,9 @@ update
|
||||||
@repository.project = @project
|
@repository.project = @project
|
||||||
if request.post? && @repository.save
|
if request.post? && @repository.save
|
||||||
if(params[:repository_scm]=="Git")
|
if(params[:repository_scm]=="Git")
|
||||||
system "htpasswd -mb "+@root_path+"user.passwd "+@repo_name+" "+@repository_tag
|
system "htpasswd -mb "+@root_path+"htdocs/user.passwd "+@repo_name+" "+@repository_tag
|
||||||
system "echo -e '"+@repo_name+"-write:"+
|
system "echo -e '"+@repo_name+"-write:"+
|
||||||
" "+@repo_name+"' >> "+@root_path+"group.passwd"
|
" "+@repo_name+"' >> "+@root_path+"htdocs/group.passwd"
|
||||||
system "mkdir "+@root_path+"htdocs/"+User.current.login.to_s
|
system "mkdir "+@root_path+"htdocs/"+User.current.login.to_s
|
||||||
system "git init --bare "+@project_path
|
system "git init --bare "+@project_path
|
||||||
system "mv "+@project_path+"/hooks/post-update{.sample,}"
|
system "mv "+@project_path+"/hooks/post-update{.sample,}"
|
||||||
|
@ -243,8 +243,8 @@ update
|
||||||
if(@repository.type=="Repository::Git")
|
if(@repository.type=="Repository::Git")
|
||||||
logger.info "destory the repository value"+"root path"+@root_path+"repo_name"+@repo_name+
|
logger.info "destory the repository value"+"root path"+@root_path+"repo_name"+@repo_name+
|
||||||
"repository_name"+@repository_name+"user group"+@middle
|
"repository_name"+@repository_name+"user group"+@middle
|
||||||
system "sed -i /"+@repo_name+"/{d} "+@root_path+"user.passwd"
|
system "sed -i /"+@repo_name+"/{d} "+@root_path+"htdocs/user.passwd"
|
||||||
system "sed -i /"+@middle+"/{d} "+@root_path+"group.passwd"
|
system "sed -i /"+@middle+"/{d} "+@root_path+"htdocs/group.passwd"
|
||||||
system "rm -r "+@root_path+"htdocs/"+@repository_name
|
system "rm -r "+@root_path+"htdocs/"+@repository_name
|
||||||
# if(@sed_user&&@sed_group&&@remove)
|
# if(@sed_user&&@sed_group&&@remove)
|
||||||
# else
|
# else
|
||||||
|
|
|
@ -553,7 +553,7 @@ class UsersController < ApplicationController
|
||||||
@user.pref.save
|
@user.pref.save
|
||||||
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
|
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
|
||||||
|
|
||||||
Mailer.account_information(@user, params[:user][:password]).deliver if params[:send_information]
|
Mailer.run.account_information(@user, params[:user][:password]) if params[:send_information]
|
||||||
|
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
format.html {
|
format.html {
|
||||||
|
@ -620,9 +620,9 @@ class UsersController < ApplicationController
|
||||||
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
|
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
|
||||||
|
|
||||||
if was_activated
|
if was_activated
|
||||||
Mailer.account_activated(@user).deliver
|
Mailer.run.account_activated(@user)
|
||||||
elsif @user.active? && params[:send_information] && !params[:user][:password].blank? && @user.auth_source_id.nil?
|
elsif @user.active? && params[:send_information] && !params[:user][:password].blank? && @user.auth_source_id.nil?
|
||||||
Mailer.account_information(@user, params[:user][:password]).deliver
|
Mailer.run.account_information(@user, params[:user][:password])
|
||||||
end
|
end
|
||||||
|
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
|
|
|
@ -5,7 +5,7 @@ class ZipdownController < ApplicationController
|
||||||
#检查权限
|
#检查权限
|
||||||
#勿删 before_filter :authorize, :only => [:assort,:download_user_homework]
|
#勿删 before_filter :authorize, :only => [:assort,:download_user_homework]
|
||||||
SAVE_FOLDER = "#{Rails.root}/files"
|
SAVE_FOLDER = "#{Rails.root}/files"
|
||||||
OUTPUT_FOLDER = "#{Rails.root}/tmp/archiveZip"
|
OUTPUT_FOLDER = "#{Rails.root}/files/archiveZip"
|
||||||
|
|
||||||
#统一下载功能
|
#统一下载功能
|
||||||
def download
|
def download
|
||||||
|
@ -56,9 +56,9 @@ class ZipdownController < ApplicationController
|
||||||
if homework != nil
|
if homework != nil
|
||||||
unless homework.attachments.empty?
|
unless homework.attachments.empty?
|
||||||
zipfile = zip_homework_by_user homework
|
zipfile = zip_homework_by_user homework
|
||||||
send_file zipfile, :filename => ((homework.user.user_extensions.nil? || homework.user.user_extensions.student_id.nil?) ? "" : homework.user.user_extensions.student_id) +
|
send_file zipfile.file_path, :filename => ((homework.user.user_extensions.nil? || homework.user.user_extensions.student_id.nil?) ? "" : homework.user.user_extensions.student_id) +
|
||||||
"_" + (homework.user.lastname.nil? ? "" : homework.user.lastname) + (homework.user.firstname.nil? ? "" : homework.user.firstname) +
|
"_" + (homework.user.lastname.nil? ? "" : homework.user.lastname) + (homework.user.firstname.nil? ? "" : homework.user.firstname) +
|
||||||
"_" + homework.name + ".zip", :type => detect_content_type(zipfile) if(zipfile)
|
"_" + homework.name + ".zip", :type => detect_content_type(zipfile.file_path) if(zipfile)
|
||||||
else
|
else
|
||||||
render file: 'public/no_file_found.html'
|
render file: 'public/no_file_found.html'
|
||||||
end
|
end
|
||||||
|
@ -88,85 +88,116 @@ class ZipdownController < ApplicationController
|
||||||
def zip_bid(bid)
|
def zip_bid(bid)
|
||||||
# Todo: User Access Controll
|
# Todo: User Access Controll
|
||||||
bid_homework_path = []
|
bid_homework_path = []
|
||||||
|
digests = []
|
||||||
bid.homeworks.each do |homeattach|
|
bid.homeworks.each do |homeattach|
|
||||||
unless homeattach.attachments.empty?
|
unless homeattach.attachments.empty?
|
||||||
bid_homework_path << zip_homework_by_user(homeattach)
|
out_file = zip_homework_by_user(homeattach)
|
||||||
|
bid_homework_path << out_file.file_path
|
||||||
|
digests << out_file.file_digest
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
zips = split_pack_files(bid_homework_path, Setting.pack_attachment_max_size.to_i*1024)
|
homework_id = bid.id
|
||||||
x = 0
|
user_id = bid.author_id
|
||||||
|
|
||||||
|
|
||||||
zips.each { |o|
|
out_file = find_or_pack(homework_id, user_id, digests.sort){
|
||||||
x += 1
|
zipping("#{Time.now.to_i}_#{bid.name}.zip",
|
||||||
file = zipping "#{Time.now.to_i}_#{bid.name}_#{x}.zip", o[:files], OUTPUT_FOLDER
|
bid_homework_path, OUTPUT_FOLDER)
|
||||||
o[:real_file] = file
|
}
|
||||||
o[:file] = File.basename(file)
|
|
||||||
o[:size] = (File.size(file) / 1024.0 / 1024.0).round(2)
|
|
||||||
|
# zips = split_pack_files(bid_homework_path, Setting.pack_attachment_max_size.to_i*1024)
|
||||||
|
# x = 0
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# zips.each { |o|
|
||||||
|
# x += 1
|
||||||
|
# file = zipping "#{Time.now.to_i}_#{bid.name}_#{x}.zip", o[:files], OUTPUT_FOLDER
|
||||||
|
# o[:real_file] = file
|
||||||
|
# o[:file] = File.basename(file)
|
||||||
|
# o[:size] = (File.size(file) / 1024.0 / 1024.0).round(2)
|
||||||
|
# }
|
||||||
|
|
||||||
|
[{files:[out_file.file_path], count: 1, index: 1,
|
||||||
|
real_file: out_file.file_path, file: File.basename(out_file.file_path),
|
||||||
|
size:(out_file.pack_size / 1024.0 / 1024.0).round(2)
|
||||||
|
}]
|
||||||
|
end
|
||||||
|
|
||||||
|
def zip_homework_by_user(homework_attach)
|
||||||
|
homeworks_attach_path = []
|
||||||
|
not_exist_file = []
|
||||||
|
# 需要将所有homework.attachments遍历加入zip
|
||||||
|
|
||||||
|
|
||||||
|
digests = []
|
||||||
|
homework_attach.attachments.each do |attach|
|
||||||
|
if File.exist?(attach.diskfile)
|
||||||
|
homeworks_attach_path << attach.diskfile
|
||||||
|
digests << attach.digest
|
||||||
|
else
|
||||||
|
not_exist_file << attach.filename
|
||||||
|
digests << 'not_exist_file'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
out_file = find_or_pack(homework_attach.bid_id, homework_attach.user_id, digests.sort){
|
||||||
|
zipping("#{homework_attach.user.lastname}#{homework_attach.user.firstname}_#{((homework_attach.user.user_extensions.nil? || homework_attach.user.user_extensions.student_id.nil?) ? "" : homework_attach.user.user_extensions.student_id)}_#{Time.now.to_i.to_s}.zip",
|
||||||
|
homeworks_attach_path, OUTPUT_FOLDER, true, not_exist_file)
|
||||||
}
|
}
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def zip_homework_by_user(homeattach)
|
|
||||||
homeworks_attach_path = []
|
def find_or_pack(homework_id, user_id, digests)
|
||||||
not_exist_file = []
|
raise "please given a pack block" unless block_given?
|
||||||
# 需要将所有homework.attachments遍历加入zip
|
|
||||||
# 并且返回zip路径
|
out_file = ZipPack.packed?(homework_id, user_id, digests.sort)
|
||||||
homeattach.attachments.each do |attach|
|
|
||||||
if File.exist?(attach.diskfile)
|
unless out_file && out_file.file_valid?
|
||||||
homeworks_attach_path << attach.diskfile
|
file = yield
|
||||||
else
|
|
||||||
not_exist_file << attach.filename
|
ZipPack.where(homework_id: homework_id,
|
||||||
end
|
user_id: user_id).delete_all
|
||||||
|
|
||||||
|
out_file = ZipPack.create(homework_id: homework_id,
|
||||||
|
user_id: user_id,
|
||||||
|
file_digest: Trustie::Utils.digest(file),
|
||||||
|
file_path: file,
|
||||||
|
pack_size: File.size(file),
|
||||||
|
file_digests: digests.join(',')
|
||||||
|
)
|
||||||
|
else
|
||||||
|
out_file.pack_times = out_file.pack_times + 1
|
||||||
|
out_file.save
|
||||||
end
|
end
|
||||||
zipping("#{homeattach.user.lastname}#{homeattach.user.firstname}_#{((homeattach.user.user_extensions.nil? || homeattach.user.user_extensions.student_id.nil?) ? "" : homeattach.user.user_extensions.student_id)}_#{Time.now.to_i.to_s}.zip", homeworks_attach_path, OUTPUT_FOLDER, true, not_exist_file)
|
|
||||||
|
out_file
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
def zipping(zip_name_refer, files_paths, output_path, is_attachment=false, not_exist_file=[])
|
def zipping(zip_name_refer, files_paths, output_path, is_attachment=false, not_exist_file=[])
|
||||||
# 输入待打包的文件列表,已经打包文件定位到ouput_path
|
|
||||||
ic = Iconv.new('GBK//IGNORE', 'UTF-8//IGNORE')
|
|
||||||
|
|
||||||
rename_zipfile = zip_name_refer ||= "#{Time.now.to_i.to_s}.zip"
|
rename_zipfile = zip_name_refer ||= "#{Time.now.to_i.to_s}.zip"
|
||||||
zipfile_name = "#{output_path}/#{rename_zipfile}"
|
zipfile_name = "#{output_path}/#{rename_zipfile}"
|
||||||
|
|
||||||
Dir.mkdir(File.dirname(zipfile_name)) unless File.exist?(File.dirname(zipfile_name))
|
Dir.mkdir(File.dirname(zipfile_name)) unless File.exist?(File.dirname(zipfile_name))
|
||||||
|
|
||||||
unless is_attachment
|
|
||||||
#都是zip合并,没必要再费力压缩了
|
|
||||||
Zip.default_compression = Zlib::NO_COMPRESSION
|
|
||||||
else
|
|
||||||
Zip.default_compression = Zlib::DEFAULT_COMPRESSION
|
|
||||||
end
|
|
||||||
|
|
||||||
Zip::File.open(zipfile_name, Zip::File::CREATE) do |zipfile|
|
Zip::File.open(zipfile_name, Zip::File::CREATE) do |zipfile|
|
||||||
files_paths.each do |filename|
|
files_paths.each do |filename|
|
||||||
flag = true
|
rename_file = File.basename(filename)
|
||||||
index = 1
|
rename_file = filename_to_real( File.basename(filename)) if is_attachment
|
||||||
rename_file = ic.iconv( (File.basename(filename)) ).to_s
|
|
||||||
rename_file = ic.iconv( filename_to_real( File.basename(filename))).to_s if is_attachment
|
|
||||||
|
|
||||||
begin
|
begin
|
||||||
zipfile.add(rename_file, filename)
|
zipfile.add(rename_file, filename)
|
||||||
flag = false
|
|
||||||
rescue Exception => e
|
rescue Exception => e
|
||||||
zipfile.get_output_stream('FILE_NOTICE.txt') do |os|
|
zipfile.get_output_stream('FILE_NOTICE.txt'){|os| os.write l(:label_file_exist)}
|
||||||
os.write l(:label_file_exist)
|
|
||||||
end
|
|
||||||
next
|
next
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
unless not_exist_file.empty?
|
unless not_exist_file.empty?
|
||||||
zipfile.get_output_stream('FILE_LOST.txt') do |os|
|
zipfile.get_output_stream('FILE_LOST.txt'){|os| os.write l(:label_file_lost) + not_exist_file.join(',').to_s}
|
||||||
os.write l(:label_file_lost) + not_exist_file.join(',').to_s
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
zipfile_name
|
zipfile_name
|
||||||
#rescue Errno => e
|
|
||||||
# logger.error "[zipdown#zipping] ===> #{e}"
|
|
||||||
# @error = e
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# 合理分配文件打包
|
# 合理分配文件打包
|
||||||
|
|
|
@ -23,7 +23,7 @@ module AccountHelper
|
||||||
token = Token.new(:user => user, :action => "register")
|
token = Token.new(:user => user, :action => "register")
|
||||||
if user.save and token.save
|
if user.save and token.save
|
||||||
UserStatus.create(:user_id => user.id, :changsets_count => 0, :watchers_count => 0)
|
UserStatus.create(:user_id => user.id, :changsets_count => 0, :watchers_count => 0)
|
||||||
Mailer.register(token).deliver
|
Mailer.run.register(token)
|
||||||
#flash[:notice] = l(:notice_account_register_done)
|
#flash[:notice] = l(:notice_account_register_done)
|
||||||
#render action: 'email_valid', locals: {:mail => user.mail}
|
#render action: 'email_valid', locals: {:mail => user.mail}
|
||||||
else
|
else
|
||||||
|
@ -51,7 +51,7 @@ module AccountHelper
|
||||||
if user.save
|
if user.save
|
||||||
UserStatus.create(:user_id => user.id ,:changsets_count => 0, :watchers_count => 0)
|
UserStatus.create(:user_id => user.id ,:changsets_count => 0, :watchers_count => 0)
|
||||||
# Sends an email to the administrators
|
# Sends an email to the administrators
|
||||||
Mailer.account_activation_request(user).deliver
|
Mailer.run.account_activation_request(user)
|
||||||
#account_pending
|
#account_pending
|
||||||
else
|
else
|
||||||
yield if block_given?
|
yield if block_given?
|
||||||
|
|
|
@ -23,6 +23,13 @@ class Comment < ActiveRecord::Base
|
||||||
belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
|
belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
|
||||||
validates_presence_of :commented, :author, :comments
|
validates_presence_of :commented, :author, :comments
|
||||||
safe_attributes 'comments'
|
safe_attributes 'comments'
|
||||||
|
after_create :send_mail
|
||||||
|
|
||||||
|
def send_mail
|
||||||
|
if self.commented.is_a?(News) && Setting.notified_events.include?('news_comment_added')
|
||||||
|
Mailer.run.news_comment_added(self)
|
||||||
|
end
|
||||||
|
end
|
||||||
after_destroy :delete_kindeditor_assets
|
after_destroy :delete_kindeditor_assets
|
||||||
|
|
||||||
# Time 2015-03-31 09:15:06
|
# Time 2015-03-31 09:15:06
|
||||||
|
|
|
@ -1,27 +0,0 @@
|
||||||
# Redmine - project management software
|
|
||||||
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
|
|
||||||
class CommentObserver < ActiveRecord::Observer
|
|
||||||
def after_create(comment)
|
|
||||||
if comment.commented.is_a?(News) && Setting.notified_events.include?('news_comment_added')
|
|
||||||
##by senluo
|
|
||||||
thread3=Thread.new do
|
|
||||||
Mailer.news_comment_added(comment).deliver
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -24,6 +24,7 @@ class Document < ActiveRecord::Base
|
||||||
after_save :be_user_score # user_score
|
after_save :be_user_score # user_score
|
||||||
after_destroy :down_user_score
|
after_destroy :down_user_score
|
||||||
acts_as_attachable :delete_permission => :delete_documents
|
acts_as_attachable :delete_permission => :delete_documents
|
||||||
|
after_create :send_mail
|
||||||
# 被ForgeActivity虚拟关联
|
# 被ForgeActivity虚拟关联
|
||||||
has_many :forge_acts, :class_name => 'ForgeActivity',:as =>:forge_act ,:dependent => :destroy
|
has_many :forge_acts, :class_name => 'ForgeActivity',:as =>:forge_act ,:dependent => :destroy
|
||||||
# end
|
# end
|
||||||
|
@ -87,4 +88,8 @@ class Document < ActiveRecord::Base
|
||||||
:project_id => self.project_id)
|
:project_id => self.project_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def send_mail
|
||||||
|
Mailer.run.document_added(self) if Setting.notified_events.include?('document_added')
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,25 +0,0 @@
|
||||||
# Redmine - project management software
|
|
||||||
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
|
|
||||||
class DocumentObserver < ActiveRecord::Observer
|
|
||||||
def after_create(document)
|
|
||||||
##by senluo
|
|
||||||
thread2=Thread.new do
|
|
||||||
Mailer.document_added(document).deliver if Setting.notified_events.include?('document_added')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -20,7 +20,7 @@ class Forum < ActiveRecord::Base
|
||||||
after_destroy :delete_kindeditor_assets
|
after_destroy :delete_kindeditor_assets
|
||||||
acts_as_taggable
|
acts_as_taggable
|
||||||
scope :by_join_date, order("created_at DESC")
|
scope :by_join_date, order("created_at DESC")
|
||||||
#after_create :send_email
|
after_create :send_mail
|
||||||
def reset_counters!
|
def reset_counters!
|
||||||
self.class.reset_counters!(id)
|
self.class.reset_counters!(id)
|
||||||
end
|
end
|
||||||
|
@ -35,10 +35,9 @@ class Forum < ActiveRecord::Base
|
||||||
self.creator == user || user.admin?
|
self.creator == user || user.admin?
|
||||||
end
|
end
|
||||||
|
|
||||||
def send_email
|
def send_mail
|
||||||
Thread.start do
|
logger.debug "send mail for forum add."
|
||||||
Mailer.forum_add(self).deliver if Setting.notified_events.include?('forum_add')
|
Mailer.run.forum_add(self) if Setting.notified_events.include?('forum_add')
|
||||||
end
|
|
||||||
end
|
end
|
||||||
# Updates topic_count, memo_count and last_memo_id attributes for +board_id+
|
# Updates topic_count, memo_count and last_memo_id attributes for +board_id+
|
||||||
def self.reset_counters!(forum_id)
|
def self.reset_counters!(forum_id)
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
class ForumObserver < ActiveRecord::Observer
|
|
||||||
# def after_create(forum)
|
|
||||||
# Thread.start do
|
|
||||||
# Mailer.forum_add(forum).deliver if Setting.notified_events.include?('forum_add')
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# end
|
|
||||||
end
|
|
|
@ -18,13 +18,11 @@
|
||||||
class IssueObserver < ActiveRecord::Observer
|
class IssueObserver < ActiveRecord::Observer
|
||||||
|
|
||||||
def after_create(issue)
|
def after_create(issue)
|
||||||
Thread.start do
|
|
||||||
# 将跟踪者与本项目的其他成员都设为收件方,并去重,不在进行抄送,
|
# 将跟踪者与本项目的其他成员都设为收件方,并去重,不在进行抄送,
|
||||||
recipients = issue.recipients - issue.watcher_recipients + issue.watcher_recipients
|
recipients = issue.recipients - issue.watcher_recipients + issue.watcher_recipients
|
||||||
recipients.each do |rec|
|
recipients.each do |rec|
|
||||||
Mailer.issue_add(issue,rec).deliver if Setting.notified_events.include?('issue_added')
|
Mailer.run.issue_add(issue,rec) if Setting.notified_events.include?('issue_added')
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -23,14 +23,12 @@ class JournalObserver < ActiveRecord::Observer
|
||||||
(Setting.notified_events.include?('issue_status_updated') && journal.new_status.present?) ||
|
(Setting.notified_events.include?('issue_status_updated') && journal.new_status.present?) ||
|
||||||
(Setting.notified_events.include?('issue_priority_updated') && journal.new_value_for('priority_id').present?)
|
(Setting.notified_events.include?('issue_priority_updated') && journal.new_value_for('priority_id').present?)
|
||||||
)
|
)
|
||||||
Thread.start do
|
|
||||||
# 将跟踪者与本项目的其他成员都设为收件方,并去重,不在进行抄送,
|
# 将跟踪者与本项目的其他成员都设为收件方,并去重,不在进行抄送,
|
||||||
recipients = journal.recipients - journal.watcher_recipients + journal.watcher_recipients
|
recipients = journal.recipients - journal.watcher_recipients + journal.watcher_recipients
|
||||||
recipients.each do |rec|
|
recipients.each do |rec|
|
||||||
|
|
||||||
Mailer.issue_edit(journal,rec).deliver
|
Mailer.run.issue_edit(journal,rec)
|
||||||
end
|
end
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
# Added by young
|
# Added by young
|
||||||
class JournalsForMessageObserver < ActiveRecord::Observer
|
class JournalsForMessageObserver < ActiveRecord::Observer
|
||||||
def after_create(journals_for_message)
|
def after_create(journals_for_message)
|
||||||
thread1 = Thread.start do
|
Mailer.run.journals_for_message_add(User.current, journals_for_message)
|
||||||
Mailer.journals_for_message_add(User.current, journals_for_message).deliver
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -101,7 +101,7 @@ class MailHandler < ActionMailer::Base
|
||||||
end
|
end
|
||||||
add_user_to_group(@@handler_options[:default_group])
|
add_user_to_group(@@handler_options[:default_group])
|
||||||
unless @@handler_options[:no_account_notice]
|
unless @@handler_options[:no_account_notice]
|
||||||
Mailer.account_information(@user, @user.password).deliver
|
Mailer.run.account_information(@user, @user.password)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if logger && logger.error
|
if logger && logger.error
|
||||||
|
|
|
@ -27,6 +27,24 @@ class Mailer < ActionMailer::Base
|
||||||
{ :host => Setting.host_name, :protocol => Setting.protocol }
|
{ :host => Setting.host_name, :protocol => Setting.protocol }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
class MailerProxy
|
||||||
|
def initialize(cls)
|
||||||
|
@target = cls
|
||||||
|
end
|
||||||
|
def method_missing(name, *args, &block)
|
||||||
|
if Setting.delayjob_enabled && Object.const_defined?('Delayed')
|
||||||
|
@target.delay.send(name, *args, &block)
|
||||||
|
else
|
||||||
|
@target.send(name, *args, &block).deliver
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.run
|
||||||
|
MailerProxy.new(self)
|
||||||
|
end
|
||||||
|
|
||||||
# author: alan
|
# author: alan
|
||||||
# 发送邀请未注册用户加入项目邮件
|
# 发送邀请未注册用户加入项目邮件
|
||||||
# 功能: 在加入项目的同时自动注册用户
|
# 功能: 在加入项目的同时自动注册用户
|
||||||
|
@ -45,6 +63,12 @@ class Mailer < ActionMailer::Base
|
||||||
def send_for_user_activities(user, date_to, days)
|
def send_for_user_activities(user, date_to, days)
|
||||||
date_from = date_to - days.days
|
date_from = date_to - days.days
|
||||||
|
|
||||||
|
subject = "[ #{user.show_name} : #{l(:label_day_mail)}]"
|
||||||
|
@subject = " #{user.show_name} : #{date_to} #{l(:label_day_mail)}"
|
||||||
|
|
||||||
|
date_from = "#{date_from} 23:59:59"
|
||||||
|
date_to = "#{date_to} 23:59:59"
|
||||||
|
|
||||||
# 生成token用于直接点击登录
|
# 生成token用于直接点击登录
|
||||||
@user = user
|
@user = user
|
||||||
token = Token.new(:user =>user , :action => 'autologin')
|
token = Token.new(:user =>user , :action => 'autologin')
|
||||||
|
@ -59,10 +83,11 @@ class Mailer < ActionMailer::Base
|
||||||
course_ids = courses.map {|course| course.id}.join(",")
|
course_ids = courses.map {|course| course.id}.join(",")
|
||||||
|
|
||||||
# 查询user的缺陷,包括发布的,跟踪的以及被指派的缺陷
|
# 查询user的缺陷,包括发布的,跟踪的以及被指派的缺陷
|
||||||
@issues = Issue.find_by_sql("select DISTINCT i.* from issues i, watchers w
|
sql = "select DISTINCT i.* from issues i, watchers w
|
||||||
where (i.assigned_to_id = #{user.id} or i.author_id = #{user.id}
|
where (i.assigned_to_id = #{user.id} or i.author_id = #{user.id}
|
||||||
or (w.watchable_type = 'Issue' and w.watchable_id = i.id and w.user_id = #{user.id}))
|
or (w.watchable_type = 'Issue' and w.watchable_id = i.id and w.user_id = #{user.id}))
|
||||||
and (i.created_on between '#{date_from}' and '#{date_to}') order by i.created_on desc")
|
and (i.created_on between '#{date_from}' and '#{date_to}') order by i.created_on desc"
|
||||||
|
@issues = Issue.find_by_sql(sql)
|
||||||
|
|
||||||
# @bids 查询课程作业,包括老师发布的作业,以及user提交作业
|
# @bids 查询课程作业,包括老师发布的作业,以及user提交作业
|
||||||
# @attachments查询课程课件更新
|
# @attachments查询课程课件更新
|
||||||
|
@ -114,15 +139,15 @@ class Mailer < ActionMailer::Base
|
||||||
@forums = Forum.find_by_sql("select DISTINCT * from forums where creator_id = #{user.id} and (created_at between '#{date_from}' and '#{date_to}') order by created_at desc")
|
@forums = Forum.find_by_sql("select DISTINCT * from forums where creator_id = #{user.id} and (created_at between '#{date_from}' and '#{date_to}') order by created_at desc")
|
||||||
@memos = Memo.find_by_sql("select DISTINCT m.* from memos m, forums f where (m.author_id = #{user.id} or (m.forum_id = f.id and f.creator_id = #{user.id}))
|
@memos = Memo.find_by_sql("select DISTINCT m.* from memos m, forums f where (m.author_id = #{user.id} or (m.forum_id = f.id and f.creator_id = #{user.id}))
|
||||||
and (m.created_at between '#{date_from}' and '#{date_to}') order by m.created_at desc")
|
and (m.created_at between '#{date_from}' and '#{date_to}') order by m.created_at desc")
|
||||||
if days == 1
|
|
||||||
subject = "[ #{user.show_name} : #{l(:label_day_mail)}]"
|
|
||||||
@subject = " #{user.show_name} : #{date_to - 1.days} #{l(:label_day_mail)}"
|
|
||||||
else
|
|
||||||
subject = "[ #{user.show_name} : #{l(:label_week_mail)}]"
|
|
||||||
@subject = "#{user.show_name} : #{l(:label_week_mail)}"
|
|
||||||
end
|
|
||||||
mail :to => user.mail,:subject => subject
|
|
||||||
|
|
||||||
|
|
||||||
|
has_content = [@issues,@homeworks,@course_messages,@project_messages,@course_news,@project_news,
|
||||||
|
@course_journal_messages,@user_journal_messages,@forums,@memos,@attachments,@bids].any? {|o|
|
||||||
|
!o.empty?
|
||||||
|
}
|
||||||
|
binding.pry if Rails.env.development?
|
||||||
|
#有内容才发,没有不发
|
||||||
|
mail :to => user.mail,:subject => subject if has_content
|
||||||
end
|
end
|
||||||
|
|
||||||
# 公共讨论区发帖、回帖添加邮件发送信息
|
# 公共讨论区发帖、回帖添加邮件发送信息
|
||||||
|
@ -135,17 +160,15 @@ class Mailer < ActionMailer::Base
|
||||||
@issue_author_url = url_for(user_activities_url(@author))
|
@issue_author_url = url_for(user_activities_url(@author))
|
||||||
recipients ||= []
|
recipients ||= []
|
||||||
#将帖子创建者邮箱地址加入数组
|
#将帖子创建者邮箱地址加入数组
|
||||||
if @forum.creator.mail_notification != 'day' && @forum.creator.mail_notification != 'week'
|
recipients << @forum.creator.mail
|
||||||
recipients << @forum.creator.mail
|
|
||||||
end
|
|
||||||
#回复人邮箱地址加入数组
|
#回复人邮箱地址加入数组
|
||||||
if @author.mail_notification != 'day' && @author.mail_notification != 'week'
|
recipients << @author.mail
|
||||||
recipients << @author.mail
|
|
||||||
end
|
|
||||||
# cc = wiki_content.page.wiki.watcher_recipients - recipients
|
# cc = wiki_content.page.wiki.watcher_recipients - recipients
|
||||||
|
|
||||||
@memo_url = url_for(forum_memo_url(@forum, (@memo.parent_id.nil? ? @memo : @memo.parent_id)))
|
@memo_url = url_for(forum_memo_url(@forum, (@memo.parent_id.nil? ? @memo : @memo.parent_id)))
|
||||||
mail :to => recipients,:subject => "[ #{l(:label_message_plural)} : #{memo.subject} #{l(:label_memo_create_succ)}]"
|
mail :to => recipients,
|
||||||
|
:subject => "[ #{l(:label_message_plural)} : #{memo.subject} #{l(:label_memo_create_succ)}]",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
# Builds a Mail::Message object used to email recipients of the added journals for message.
|
# Builds a Mail::Message object used to email recipients of the added journals for message.
|
||||||
|
|
||||||
|
@ -180,12 +203,8 @@ class Mailer < ActionMailer::Base
|
||||||
# 验证用户的收取邮件的方式
|
# 验证用户的收取邮件的方式
|
||||||
recipients ||= []
|
recipients ||= []
|
||||||
recipients1 ||= []
|
recipients1 ||= []
|
||||||
if @mail.mail_notification != 'week' && @mail.mail_notification != 'day'
|
recipients1 = @mail.mail
|
||||||
recipients1 = @mail.mail
|
recipients = journals_for_message.jour.author.mail
|
||||||
end
|
|
||||||
if journals_for_message.jour.author.mail_notification != 'week' && journals_for_message.jour.author.mail_notification != 'day'
|
|
||||||
recipients = journals_for_message.jour.author.mail
|
|
||||||
end
|
|
||||||
|
|
||||||
# modify by nwb
|
# modify by nwb
|
||||||
#如果是直接留言并且留言对象是课程
|
#如果是直接留言并且留言对象是课程
|
||||||
|
@ -197,25 +216,24 @@ class Mailer < ActionMailer::Base
|
||||||
#收件人邮箱
|
#收件人邮箱
|
||||||
@recipients ||= []
|
@recipients ||= []
|
||||||
@members.each do |teacher|
|
@members.each do |teacher|
|
||||||
if teacher.user.mail_notification != 'week' && teacher.user.mail_notification != 'day'
|
@recipients << teacher.user.mail
|
||||||
@recipients << teacher.user.mail
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
mail :to => @recipients,
|
mail :to => @recipients,
|
||||||
:subject => "#{l(:label_your_course)}#{journals_for_message.jour.name}#{l(:label_have_message)} "
|
:subject => "#{l(:label_your_course)}#{journals_for_message.jour.name}#{l(:label_have_message)} ",
|
||||||
|
:filter => true
|
||||||
elsif journals_for_message.jour.class.to_s.to_sym == :Bid
|
elsif journals_for_message.jour.class.to_s.to_sym == :Bid
|
||||||
if !journals_for_message.jour.author.notify_about? journals_for_message
|
if !journals_for_message.jour.author.notify_about? journals_for_message
|
||||||
return -1
|
return -1
|
||||||
end
|
end
|
||||||
|
|
||||||
mail :to => recipients, :subject => @title
|
mail :to => recipients, :subject => @title,:filter => true
|
||||||
elsif journals_for_message.jour.class.to_s.to_sym == :Contest
|
elsif journals_for_message.jour.class.to_s.to_sym == :Contest
|
||||||
if !journals_for_message.jour.author.notify_about? journals_for_message
|
if !journals_for_message.jour.author.notify_about? journals_for_message
|
||||||
return -1
|
return -1
|
||||||
end
|
end
|
||||||
mail :to => recipients, :subject => @title
|
mail :to => recipients, :subject => @title,:filter => true
|
||||||
else
|
else
|
||||||
mail :to => recipients1, :subject => @title
|
mail :to => recipients1, :subject => @title,:filter => true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -250,9 +268,9 @@ class Mailer < ActionMailer::Base
|
||||||
|
|
||||||
|
|
||||||
subject = "[#{issue.project.name} - #{issue.tracker.name} ##{issue_id}] (#{issue.status.name}) #{issue.subject}"
|
subject = "[#{issue.project.name} - #{issue.tracker.name} ##{issue_id}] (#{issue.status.name}) #{issue.subject}"
|
||||||
mail(:to => recipients,
|
mail :to => recipients,
|
||||||
|
:subject => subject,
|
||||||
:subject => subject)
|
:filter => true
|
||||||
end
|
end
|
||||||
# issue.attachments.each do |attach|
|
# issue.attachments.each do |attach|
|
||||||
# attachments["#{attach.filename}"] = File.read("#{attach.disk_filename}")
|
# attachments["#{attach.filename}"] = File.read("#{attach.disk_filename}")
|
||||||
|
@ -298,9 +316,9 @@ class Mailer < ActionMailer::Base
|
||||||
@issue = issue
|
@issue = issue
|
||||||
@journal = journal
|
@journal = journal
|
||||||
# @issue_url = url_for(:controller => 'issues', :action => 'show', :id => issue, :anchor => "change-#{journal.id}")
|
# @issue_url = url_for(:controller => 'issues', :action => 'show', :id => issue, :anchor => "change-#{journal.id}")
|
||||||
mail(:to => recipients,
|
mail :to => recipients,
|
||||||
|
:subject => s,
|
||||||
:subject => s)
|
:filter => true
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.deliver_mailer(to,cc, subject)
|
def self.deliver_mailer(to,cc, subject)
|
||||||
|
@ -386,7 +404,8 @@ class Mailer < ActionMailer::Base
|
||||||
@issue_author_url = url_for(user_activities_url(@author))
|
@issue_author_url = url_for(user_activities_url(@author))
|
||||||
@document_url = url_for(:controller => 'documents', :action => 'show', :id => document)
|
@document_url = url_for(:controller => 'documents', :action => 'show', :id => document)
|
||||||
mail :to => document.recipients,
|
mail :to => document.recipients,
|
||||||
:subject => "[#{document.project.name}] #{l(:label_document_new)}: #{document.title}"
|
:subject => "[#{document.project.name}] #{l(:label_document_new)}: #{document.title}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
|
|
||||||
# Builds a Mail::Message object used to email recipients of a project when an attachements are added.
|
# Builds a Mail::Message object used to email recipients of a project when an attachements are added.
|
||||||
|
@ -424,21 +443,24 @@ class Mailer < ActionMailer::Base
|
||||||
@added_to = added_to
|
@added_to = added_to
|
||||||
@added_to_url = added_to_url
|
@added_to_url = added_to_url
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:subject => "[#{container.name}] #{l(:label_attachment_new)}"
|
:subject => "[#{container.name}] #{l(:label_attachment_new)}",
|
||||||
|
:filter => true
|
||||||
elsif container.class.name == 'Project'
|
elsif container.class.name == 'Project'
|
||||||
redmine_headers 'Project' => container.id
|
redmine_headers 'Project' => container.id
|
||||||
@attachments = attachments
|
@attachments = attachments
|
||||||
@added_to = added_to
|
@added_to = added_to
|
||||||
@added_to_url = added_to_url
|
@added_to_url = added_to_url
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:subject => "[#{container.name}] #{l(:label_attachment_new)}"
|
:subject => "[#{container.name}] #{l(:label_attachment_new)}",
|
||||||
|
:filter => true
|
||||||
else
|
else
|
||||||
redmine_headers 'Project' => container.project.identifier
|
redmine_headers 'Project' => container.project.identifier
|
||||||
@attachments = attachments
|
@attachments = attachments
|
||||||
@added_to = added_to
|
@added_to = added_to
|
||||||
@added_to_url = added_to_url
|
@added_to_url = added_to_url
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:subject => "[#{container.project.name}] #{l(:label_attachment_new)}"
|
:subject => "[#{container.project.name}] #{l(:label_attachment_new)}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -457,7 +479,8 @@ class Mailer < ActionMailer::Base
|
||||||
@news = news
|
@news = news
|
||||||
@news_url = url_for(:controller => 'news', :action => 'show', :id => news)
|
@news_url = url_for(:controller => 'news', :action => 'show', :id => news)
|
||||||
mail :to => news.recipients,
|
mail :to => news.recipients,
|
||||||
:subject => "[#{news.project.name}] #{l(:label_news)}: #{news.title}"
|
:subject => "[#{news.project.name}] #{l(:label_news)}: #{news.title}",
|
||||||
|
:filter => true
|
||||||
elsif news.course
|
elsif news.course
|
||||||
redmine_headers 'Course' => news.course.id
|
redmine_headers 'Course' => news.course.id
|
||||||
@author = news.author
|
@author = news.author
|
||||||
|
@ -467,7 +490,8 @@ class Mailer < ActionMailer::Base
|
||||||
recipients = news.course.notified_users.select { |user| user.allowed_to?(:view_files, news.course) }.collect { |u| u.mail }
|
recipients = news.course.notified_users.select { |user| user.allowed_to?(:view_files, news.course) }.collect { |u| u.mail }
|
||||||
@news_url = url_for(:controller => 'news', :action => 'show', :id => news)
|
@news_url = url_for(:controller => 'news', :action => 'show', :id => news)
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:subject => "[#{news.course.name}] #{l(:label_news)}: #{news.title}"
|
:subject => "[#{news.course.name}] #{l(:label_news)}: #{news.title}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -488,7 +512,8 @@ class Mailer < ActionMailer::Base
|
||||||
@news_url = url_for(:controller => 'news', :action => 'show', :id => news)
|
@news_url = url_for(:controller => 'news', :action => 'show', :id => news)
|
||||||
mail :to => news.recipients,
|
mail :to => news.recipients,
|
||||||
:cc => news.watcher_recipients,
|
:cc => news.watcher_recipients,
|
||||||
:subject => "Re: [#{news.project.name}] #{l(:label_news)}: #{news.title}"
|
:subject => "Re: [#{news.project.name}] #{l(:label_news)}: #{news.title}",
|
||||||
|
:filter => true
|
||||||
elsif news.course
|
elsif news.course
|
||||||
redmine_headers 'Course' => news.course.id
|
redmine_headers 'Course' => news.course.id
|
||||||
@author = comment.author
|
@author = comment.author
|
||||||
|
@ -500,7 +525,8 @@ class Mailer < ActionMailer::Base
|
||||||
recipients = news.course.notified_users.select { |user| user.allowed_to?(:view_files, news.course) }.collect { |u| u.mail }
|
recipients = news.course.notified_users.select { |user| user.allowed_to?(:view_files, news.course) }.collect { |u| u.mail }
|
||||||
|
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:subject => "[#{news.course.name}] #{l(:label_news)}: #{news.title}"
|
:subject => "[#{news.course.name}] #{l(:label_news)}: #{news.title}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -523,7 +549,8 @@ class Mailer < ActionMailer::Base
|
||||||
@message_url = url_for(message.event_url)
|
@message_url = url_for(message.event_url)
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:cc => cc,
|
:cc => cc,
|
||||||
:subject => "[#{message.board.project.name} - #{message.board.name} - msg#{message.root.id}] #{message.subject}"
|
:subject => "[#{message.board.project.name} - #{message.board.name} - msg#{message.root.id}] #{message.subject}",
|
||||||
|
:filter => true
|
||||||
elsif message.course
|
elsif message.course
|
||||||
redmine_headers 'Course' => message.course.id,
|
redmine_headers 'Course' => message.course.id,
|
||||||
'Topic-Id' => (message.parent_id || message.id)
|
'Topic-Id' => (message.parent_id || message.id)
|
||||||
|
@ -537,7 +564,8 @@ class Mailer < ActionMailer::Base
|
||||||
@message_url = url_for(message.event_url)
|
@message_url = url_for(message.event_url)
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:cc => cc,
|
:cc => cc,
|
||||||
:subject => "[#{message.board.course.name} - #{message.board.name} - msg#{message.root.id}] #{message.subject}"
|
:subject => "[#{message.board.course.name} - #{message.board.name} - msg#{message.root.id}] #{message.subject}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -559,7 +587,8 @@ class Mailer < ActionMailer::Base
|
||||||
:id => wiki_content.page.title)
|
:id => wiki_content.page.title)
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:cc => cc,
|
:cc => cc,
|
||||||
:subject => "[#{wiki_content.project.name}] #{l(:mail_subject_wiki_content_added, :id => wiki_content.page.pretty_title)}"
|
:subject => "[#{wiki_content.project.name}] #{l(:mail_subject_wiki_content_added, :id => wiki_content.page.pretty_title)}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
|
|
||||||
# Builds a Mail::Message object used to email the recipients of a project of the specified wiki content was updated.
|
# Builds a Mail::Message object used to email the recipients of a project of the specified wiki content was updated.
|
||||||
|
@ -583,7 +612,8 @@ class Mailer < ActionMailer::Base
|
||||||
:version => wiki_content.version)
|
:version => wiki_content.version)
|
||||||
mail :to => recipients,
|
mail :to => recipients,
|
||||||
:cc => cc,
|
:cc => cc,
|
||||||
:subject => "[#{wiki_content.project.name}] #{l(:mail_subject_wiki_content_updated, :id => wiki_content.page.pretty_title)}"
|
:subject => "[#{wiki_content.project.name}] #{l(:mail_subject_wiki_content_updated, :id => wiki_content.page.pretty_title)}",
|
||||||
|
:filter => true
|
||||||
end
|
end
|
||||||
|
|
||||||
# Builds a Mail::Message object used to email the specified user their account information.
|
# Builds a Mail::Message object used to email the specified user their account information.
|
||||||
|
@ -734,6 +764,25 @@ class Mailer < ActionMailer::Base
|
||||||
ActionMailer::Base.delivery_method = saved_method
|
ActionMailer::Base.delivery_method = saved_method
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#过滤掉不是不合规则的收件人
|
||||||
|
def filter(reps)
|
||||||
|
r_reps = []
|
||||||
|
if reps.is_a? Array
|
||||||
|
reps.each do |r|
|
||||||
|
u = User.find_by_mail(r)
|
||||||
|
if u && u.mail_notification == 'all'
|
||||||
|
r_reps << r
|
||||||
|
end
|
||||||
|
end
|
||||||
|
elsif reps.is_a? String
|
||||||
|
u = User.find_by_mail(r)
|
||||||
|
if u && u.mail_notification == 'all'
|
||||||
|
r_reps << r
|
||||||
|
end
|
||||||
|
end
|
||||||
|
r_reps
|
||||||
|
end
|
||||||
|
|
||||||
def mail(headers={})
|
def mail(headers={})
|
||||||
headers.merge! 'X-Mailer' => 'Redmine',
|
headers.merge! 'X-Mailer' => 'Redmine',
|
||||||
'X-Redmine-Host' => Setting.host_name,
|
'X-Redmine-Host' => Setting.host_name,
|
||||||
|
@ -750,6 +799,11 @@ class Mailer < ActionMailer::Base
|
||||||
headers[:cc].delete(@author.mail) if headers[:cc].is_a?(Array)
|
headers[:cc].delete(@author.mail) if headers[:cc].is_a?(Array)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if headers[:filter]
|
||||||
|
headers[:to] = filter(headers[:to])
|
||||||
|
headers[:cc] = filter(headers[:cc])
|
||||||
|
end
|
||||||
|
|
||||||
if @author && @author.logged?
|
if @author && @author.logged?
|
||||||
redmine_headers 'Sender' => @author.login
|
redmine_headers 'Sender' => @author.login
|
||||||
end
|
end
|
||||||
|
|
|
@ -44,7 +44,7 @@ class Memo < ActiveRecord::Base
|
||||||
"parent_id",
|
"parent_id",
|
||||||
"replies_count"
|
"replies_count"
|
||||||
|
|
||||||
after_create :add_author_as_watcher, :reset_counters!, :sendmail
|
after_create :add_author_as_watcher, :reset_counters!, :send_mail
|
||||||
# after_update :update_memos_forum
|
# after_update :update_memos_forum
|
||||||
after_destroy :reset_counters!,:delete_kindeditor_assets#,:down_user_score -- 公共区发帖暂不计入得分
|
after_destroy :reset_counters!,:delete_kindeditor_assets#,:down_user_score -- 公共区发帖暂不计入得分
|
||||||
# after_create :send_notification
|
# after_create :send_notification
|
||||||
|
@ -55,10 +55,8 @@ class Memo < ActiveRecord::Base
|
||||||
# includes(:forum => ).where()
|
# includes(:forum => ).where()
|
||||||
# }
|
# }
|
||||||
|
|
||||||
def sendmail
|
def send_mail
|
||||||
thread1=Thread.new do
|
Mailer.run.forum_message_added(self) if Setting.notified_events.include?('forum_message_added')
|
||||||
Mailer.forum_message_added(self).deliver if Setting.notified_events.include?('forum_message_added')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def cannot_reply_to_locked_topic
|
def cannot_reply_to_locked_topic
|
||||||
|
@ -115,7 +113,7 @@ class Memo < ActiveRecord::Base
|
||||||
|
|
||||||
def send_notification
|
def send_notification
|
||||||
if Setting.notified_events.include?('message_posted')
|
if Setting.notified_events.include?('message_posted')
|
||||||
Mailer.message_posted(self).deliver
|
Mailer.run.message_posted(self)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
class MemoObserver < ActiveRecord::Observer
|
|
||||||
def after_create(memo)
|
|
||||||
|
|
||||||
thread1=Thread.new do
|
|
||||||
Mailer.forum_message_added(memo).deliver if Setting.notified_events.include?('forum_message_added')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -66,10 +66,8 @@ class Message < ActiveRecord::Base
|
||||||
after_update :update_messages_board
|
after_update :update_messages_board
|
||||||
after_destroy :reset_counters!,:down_user_score,:delete_kindeditor_assets
|
after_destroy :reset_counters!,:down_user_score,:delete_kindeditor_assets
|
||||||
|
|
||||||
# fq
|
after_create :act_as_activity,:be_user_score,:act_as_forge_activity, :send_mail
|
||||||
after_create :act_as_activity,:be_user_score,:act_as_forge_activity
|
|
||||||
#before_save :be_user_score
|
#before_save :be_user_score
|
||||||
# end
|
|
||||||
|
|
||||||
scope :visible, lambda {|*args|
|
scope :visible, lambda {|*args|
|
||||||
includes(:board => :project).where(Project.allowed_to_condition(args.shift || User.current, :view_messages, *args))
|
includes(:board => :project).where(Project.allowed_to_condition(args.shift || User.current, :view_messages, *args))
|
||||||
|
@ -210,6 +208,10 @@ class Message < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def send_mail
|
||||||
|
Mailer.run.message_posted(self) if Setting.notified_events.include?('message_posted')
|
||||||
|
end
|
||||||
|
|
||||||
# Time 2015-03-31 09:15:06
|
# Time 2015-03-31 09:15:06
|
||||||
# Author lizanle
|
# Author lizanle
|
||||||
# Description 删除对应消息的图片资源
|
# Description 删除对应消息的图片资源
|
||||||
|
|
|
@ -1,25 +0,0 @@
|
||||||
# Redmine - project management software
|
|
||||||
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
|
|
||||||
class MessageObserver < ActiveRecord::Observer
|
|
||||||
def after_create(message)
|
|
||||||
##by senluo
|
|
||||||
thread5=Thread.new do
|
|
||||||
Mailer.message_posted(message).deliver if Setting.notified_events.include?('message_posted')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -47,12 +47,10 @@ class News < ActiveRecord::Base
|
||||||
:author_key => :author_id
|
:author_key => :author_id
|
||||||
acts_as_watchable
|
acts_as_watchable
|
||||||
|
|
||||||
after_create :add_author_as_watcher
|
after_create :act_as_activity,:act_as_forge_activity,:add_author_as_watcher, :send_mail
|
||||||
# fq
|
|
||||||
after_create :act_as_activity,:act_as_forge_activity
|
|
||||||
# end
|
|
||||||
after_destroy :delete_kindeditor_assets
|
after_destroy :delete_kindeditor_assets
|
||||||
|
|
||||||
scope :visible, lambda {|*args|
|
scope :visible, lambda {|*args|
|
||||||
includes(:project).where(Project.allowed_to_condition(args.shift || User.current, :view_news, *args))
|
includes(:project).where(Project.allowed_to_condition(args.shift || User.current, :view_news, *args))
|
||||||
}
|
}
|
||||||
|
@ -115,4 +113,8 @@ class News < ActiveRecord::Base
|
||||||
delete_kindeditor_assets_from_disk self.id,OwnerTypeHelper::NEWS
|
delete_kindeditor_assets_from_disk self.id,OwnerTypeHelper::NEWS
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def send_mail
|
||||||
|
Mailer.run.news_added(self) if Setting.notified_events.include?('news_added')
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,25 +0,0 @@
|
||||||
# Redmine - project management software
|
|
||||||
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
||||||
#
|
|
||||||
# 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.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
|
|
||||||
class NewsObserver < ActiveRecord::Observer
|
|
||||||
def after_create(news)
|
|
||||||
##by senluo
|
|
||||||
thread6=Thread.new do
|
|
||||||
Mailer.news_added(news).deliver if Setting.notified_events.include?('news_added')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -159,7 +159,7 @@ class RelativeMemo < ActiveRecord::Base
|
||||||
|
|
||||||
def send_notification
|
def send_notification
|
||||||
if Setting.notified_events.include?('message_posted')
|
if Setting.notified_events.include?('message_posted')
|
||||||
Mailer.message_posted(self).deliver
|
Mailer.run.message_posted(self)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -64,9 +64,10 @@ class User < Principal
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#每日一报、一事一报、不报
|
||||||
MAIL_NOTIFICATION_OPTIONS = [
|
MAIL_NOTIFICATION_OPTIONS = [
|
||||||
['all', :label_user_mail_option_all],
|
['all', :label_user_mail_option_all],
|
||||||
['week', :label_user_mail_option_week],
|
#['week', :label_user_mail_option_week],
|
||||||
['day', :label_user_mail_option_day],
|
['day', :label_user_mail_option_day],
|
||||||
['none', :label_user_mail_option_none]
|
['none', :label_user_mail_option_none]
|
||||||
]
|
]
|
||||||
|
|
|
@ -17,18 +17,12 @@
|
||||||
|
|
||||||
class WikiContentObserver < ActiveRecord::Observer
|
class WikiContentObserver < ActiveRecord::Observer
|
||||||
def after_create(wiki_content)
|
def after_create(wiki_content)
|
||||||
##by senluo
|
Mailer.run.wiki_content_added(wiki_content) if Setting.notified_events.include?('wiki_content_added')
|
||||||
thread7=Thread.new do
|
|
||||||
Mailer.wiki_content_added(wiki_content).deliver if Setting.notified_events.include?('wiki_content_added')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def after_update(wiki_content)
|
def after_update(wiki_content)
|
||||||
if wiki_content.text_changed?
|
if wiki_content.text_changed?
|
||||||
##by senluo
|
Mailer.run.wiki_content_updated(wiki_content) if Setting.notified_events.include?('wiki_content_updated')
|
||||||
thread8=Thread.new do
|
|
||||||
Mailer.wiki_content_updated(wiki_content).deliver if Setting.notified_events.include?('wiki_content_updated')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
class ZipPack < ActiveRecord::Base
|
||||||
|
# attr_accessible :title, :body
|
||||||
|
|
||||||
|
def self.packed?(bid_id, user_id, digests)
|
||||||
|
zip_pack = ZipPack.where(homework_id: bid_id, user_id: user_id).first
|
||||||
|
return false unless zip_pack && zip_pack.digests == digests
|
||||||
|
zip_pack
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_valid?
|
||||||
|
return false unless File.exist?(self.file_path)
|
||||||
|
Trustie::Utils.digest(self.file_path) == self.file_digest
|
||||||
|
end
|
||||||
|
|
||||||
|
def digests
|
||||||
|
self.file_digests.split(',').sort
|
||||||
|
end
|
||||||
|
end
|
|
@ -95,9 +95,7 @@ class UsersService
|
||||||
# create a new token for password recovery
|
# create a new token for password recovery
|
||||||
token = Token.new(:user => user, :action => "recovery")
|
token = Token.new(:user => user, :action => "recovery")
|
||||||
if token.save
|
if token.save
|
||||||
Thread.new do
|
Mailer.run.lost_password(token)
|
||||||
Mailer.lost_password(token).deliver
|
|
||||||
end
|
|
||||||
return l(:notice_account_lost_email_sent,:locale => user.language)
|
return l(:notice_account_lost_email_sent,:locale => user.language)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -22,8 +22,8 @@
|
||||||
<%= link_to "留言", get_homework_jours_homework_attach_index_path(:bid_id => @bid.id), {:remote => true}%>
|
<%= link_to "留言", get_homework_jours_homework_attach_index_path(:bid_id => @bid.id), {:remote => true}%>
|
||||||
(<span id="jours_count" class="c_red f_12"><%= @jours_count %></span>)
|
(<span id="jours_count" class="c_red f_12"><%= @jours_count %></span>)
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li><%= link_to "作品打包下载", zipdown_assort_path(obj_class: @bid.class, obj_id: @bid, format: :json),
|
||||||
<%#= link_to "作品打包下载", zipdown_assort_path(obj_class: @bid.class, obj_id: @bid), class: "tb_all" unless @bid.homeworks.empty? %>
|
remote: true, class: "tb_all" unless @bid.homeworks.empty? %>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
<% else %>
|
<% else %>
|
||||||
|
|
|
@ -90,7 +90,7 @@
|
||||||
:class => 'wmail_info',
|
:class => 'wmail_info',
|
||||||
:style => "color:#5a5a5a; float:left; margin-right:5px; display:block;color:#1b55a7;overflow:hidden; white-space: nowrap; text-overflow:ellipsis;"
|
:style => "color:#5a5a5a; float:left; margin-right:5px; display:block;color:#1b55a7;overflow:hidden; white-space: nowrap; text-overflow:ellipsis;"
|
||||||
%>
|
%>
|
||||||
<span class="wmail_date" style="color:#6e6e6e; float:right;display:block; margin-left:10px;"><%= format_time(homework.created_on) %></span>
|
<span class="wmail_date" style="color:#6e6e6e; float:right;display:block; margin-left:10px;"><%= format_time(homework.created_at) %></span>
|
||||||
</li>
|
</li>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
|
@ -37,8 +37,7 @@ module RedmineApp
|
||||||
# config.plugins = [ :exception_notification, :ssl_requirement, :all ]
|
# config.plugins = [ :exception_notification, :ssl_requirement, :all ]
|
||||||
|
|
||||||
# Activate observers that should always be running.
|
# Activate observers that should always be running.
|
||||||
config.active_record.observers = :journals_for_message_observer, :message_observer, :issue_observer, :journal_observer, :news_observer,
|
config.active_record.observers = :journals_for_message_observer, :issue_observer, :journal_observer, :wiki_content_observer
|
||||||
:document_observer, :wiki_content_observer, :comment_observer, :forum_observer, :memo_observer
|
|
||||||
|
|
||||||
config.active_record.store_full_sti_class = true
|
config.active_record.store_full_sti_class = true
|
||||||
config.active_record.default_timezone = :local
|
config.active_record.default_timezone = :local
|
||||||
|
|
|
@ -84,9 +84,6 @@ default:
|
||||||
email_delivery:
|
email_delivery:
|
||||||
delivery_method: :smtp
|
delivery_method: :smtp
|
||||||
smtp_settings:
|
smtp_settings:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
address: smtp.126.com
|
address: smtp.126.com
|
||||||
port: 25
|
port: 25
|
||||||
domain: smtp.126.com
|
domain: smtp.126.com
|
||||||
|
|
|
@ -2,6 +2,7 @@ I18n.default_locale = 'en'
|
||||||
I18n.backend = Redmine::I18n::Backend.new
|
I18n.backend = Redmine::I18n::Backend.new
|
||||||
|
|
||||||
require 'redmine'
|
require 'redmine'
|
||||||
|
require 'trustie'
|
||||||
|
|
||||||
# Load the secret token from the Redmine configuration file
|
# Load the secret token from the Redmine configuration file
|
||||||
secret = Redmine::Configuration['secret_token']
|
secret = Redmine::Configuration['secret_token']
|
||||||
|
|
|
@ -1,27 +1,15 @@
|
||||||
#!/usr/bin/env ruby
|
#coding=utf-8
|
||||||
|
|
||||||
require 'rubygems'
|
|
||||||
require 'rufus-scheduler'
|
|
||||||
|
|
||||||
#users = User.where("mail_notification = 'week' or mail_notification = 'day'")
|
## 移入crontab
|
||||||
|
|
||||||
scheduler = Rufus::Scheduler.new
|
|
||||||
scheduler.cron('0 0 * * 1') do
|
|
||||||
users = User.where("mail_notification = 'week'")
|
|
||||||
users.each do |user|
|
|
||||||
#Rails.logger.info "send mail to #{user.show_name}(#{user.mail}) at #{Time.now}"
|
|
||||||
Thread.start do
|
|
||||||
Mailer.send_for_user_activities(user, Date.today, 7).deliver
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
scheduler.cron('0 0 * * *') do
|
|
||||||
users = User.where("mail_notification = 'day'")
|
|
||||||
users.each do |user|
|
|
||||||
#Rails.logger.info "send mail to #{user.show_name}(#{user.mail}) at #{Time.now}"
|
|
||||||
Thread.start do
|
|
||||||
Mailer.send_for_user_activities(user, Date.today, 1).deliver
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
# scheduler = Rufus::Scheduler.new
|
||||||
|
#
|
||||||
|
# #每天18:00发送当天的邮件汇总
|
||||||
|
# scheduler.cron('0 18 * * *') do
|
||||||
|
# users = User.where(mail_notification: 'day')
|
||||||
|
# users.each do |user|
|
||||||
|
# mailer = Mailer.send_for_user_activities(user, Date.today, 1)
|
||||||
|
# mailer.deliver if mailer
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
|
@ -80,7 +80,7 @@ zh:
|
||||||
field_enterprise_name: 组织
|
field_enterprise_name: 组织
|
||||||
|
|
||||||
label_week_mail: 一周动态
|
label_week_mail: 一周动态
|
||||||
label_day_mail: 一日动态
|
label_day_mail: 今日动态
|
||||||
#added by huang
|
#added by huang
|
||||||
field_tea_name: 教师
|
field_tea_name: 教师
|
||||||
field_couurse_time: 学时
|
field_couurse_time: 学时
|
||||||
|
@ -2030,5 +2030,5 @@ zh:
|
||||||
label_name_not_null: 名称不能为空
|
label_name_not_null: 名称不能为空
|
||||||
modal_valid_unpassing: 该分班已经存在
|
modal_valid_unpassing: 该分班已经存在
|
||||||
|
|
||||||
|
mail_footer: 点击修改邮件发送设置
|
||||||
|
|
||||||
|
|
|
@ -102,11 +102,11 @@ RedmineApp::Application.routes.draw do
|
||||||
|
|
||||||
mount SeemsRateable::Engine => '/rateable', :as => :rateable
|
mount SeemsRateable::Engine => '/rateable', :as => :rateable
|
||||||
|
|
||||||
# namespace :zipdown do
|
namespace :zipdown do
|
||||||
# match 'assort'
|
match 'assort'
|
||||||
# match 'download_user_homework', :as => :download_user_homework
|
match 'download_user_homework', :as => :download_user_homework
|
||||||
# match 'download'
|
match 'download'
|
||||||
# end
|
end
|
||||||
namespace :test do
|
namespace :test do
|
||||||
match 'courselist'
|
match 'courselist'
|
||||||
match 'zip'
|
match 'zip'
|
||||||
|
|
|
@ -60,6 +60,11 @@ per_page_options:
|
||||||
default: '25,50,100'
|
default: '25,50,100'
|
||||||
mail_from:
|
mail_from:
|
||||||
default: trustieforge@gmail.com
|
default: trustieforge@gmail.com
|
||||||
|
|
||||||
|
### delayjob for send email.
|
||||||
|
delayjob_enabled:
|
||||||
|
default: 1
|
||||||
|
|
||||||
bcc_recipients:
|
bcc_recipients:
|
||||||
default: 1
|
default: 1
|
||||||
plain_text_mail:
|
plain_text_mail:
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
class ChnageMailNotificationWeekToDay < ActiveRecord::Migration
|
||||||
|
def up
|
||||||
|
User.where(mail_notification: 'week').update_all(mail_notification: 'day')
|
||||||
|
end
|
||||||
|
|
||||||
|
def down
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,22 @@
|
||||||
|
class CreateDelayedJobs < ActiveRecord::Migration
|
||||||
|
def self.up
|
||||||
|
create_table :delayed_jobs, force: true do |table|
|
||||||
|
table.integer :priority, default: 0, null: false # Allows some jobs to jump to the front of the queue
|
||||||
|
table.integer :attempts, default: 0, null: false # Provides for retries, but still fail eventually.
|
||||||
|
table.text :handler, null: false # YAML-encoded string of the object that will do work
|
||||||
|
table.text :last_error # reason for last failure (See Note below)
|
||||||
|
table.datetime :run_at # When to run. Could be Time.zone.now for immediately, or sometime in the future.
|
||||||
|
table.datetime :locked_at # Set when a client is working on this object
|
||||||
|
table.datetime :failed_at # Set when all retries have failed (actually, by default, the record is deleted instead)
|
||||||
|
table.string :locked_by # Who is working on this object (if locked)
|
||||||
|
table.string :queue # The name of the queue this job is in
|
||||||
|
table.timestamps null: true
|
||||||
|
end
|
||||||
|
|
||||||
|
add_index :delayed_jobs, [:priority, :run_at], name: "delayed_jobs_priority"
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.down
|
||||||
|
drop_table :delayed_jobs
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,5 @@
|
||||||
|
class AddDelayjobEnabledToSettings < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
Setting.create(name: 'delayjob_enabled', value: 1 )
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,14 @@
|
||||||
|
class CreateZipPacks < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
create_table :zip_packs do |t|
|
||||||
|
t.integer :user_id
|
||||||
|
t.integer :homework_id
|
||||||
|
t.string :file_digest
|
||||||
|
t.string :file_path
|
||||||
|
t.integer :pack_times, default: 1
|
||||||
|
t.integer :pack_size, default: 0
|
||||||
|
t.string :file_digests
|
||||||
|
t.timestamps
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
2904
db/schema.rb
2904
db/schema.rb
File diff suppressed because it is too large
Load Diff
|
@ -194,5 +194,13 @@ END_DESC
|
||||||
abort l(:notice_email_error, e.message)
|
abort l(:notice_email_error, e.message)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
desc "send a email for day"
|
||||||
|
task :day => :environment do
|
||||||
|
users = User.where(mail_notification: 'day')
|
||||||
|
users.each do |user|
|
||||||
|
Mailer.run.send_for_user_activities(user, Date.today, 1)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
require 'trustie/utils'
|
|
@ -0,0 +1,20 @@
|
||||||
|
#coding=utf-8
|
||||||
|
|
||||||
|
module Trustie
|
||||||
|
module Utils
|
||||||
|
def self.digest(diskfile)
|
||||||
|
md5 = Digest::MD5.new
|
||||||
|
File.open(diskfile, "rb") do |f|
|
||||||
|
buffer = ""
|
||||||
|
while (buffer = f.read(8192))
|
||||||
|
md5.update(buffer)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
md5.hexdigest
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if __FILE__ == $0
|
||||||
|
puts Trustie::Utils.digest('/Users/guange/Downloads/QQ_V4.0.2.dmg')
|
||||||
|
end
|
|
@ -0,0 +1,5 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
|
||||||
|
require File.expand_path(File.join(File.dirname(__FILE__), '..', 'config', 'environment'))
|
||||||
|
require 'delayed/command'
|
||||||
|
Delayed::Command.new(ARGV).daemonize
|
Loading…
Reference in New Issue