]> git.openstreetmap.org Git - rails.git/blobdiff - script/deliver-message
avatar inline attachment; text alignment
[rails.git] / script / deliver-message
index 28b32cda61dbb9c84873b58589df5a85482caf6b..c15d365962e45124e6a7148c51f89dc6a22c6e88 100755 (executable)
@@ -1,34 +1,35 @@
 #!/usr/bin/env ruby
 
 #!/usr/bin/env ruby
 
-require File.dirname(__FILE__) + '/../config/environment'
-require 'tmail'
+require File.dirname(__FILE__) + "/../config/environment"
 
 
-exit 0 unless recipient = ARGV[0].match(/^([cm])-(\d+)-(.*)$/)
-
-if recipient[1] == "c"
-  comment = DiaryComment.find(recipient[2])
+if recipient = ARGV[0].match(/^c-(\d+)-(\d+)-(.*)$/)
+  comment = DiaryComment.find(recipient[1])
   digest = comment.digest
   digest = comment.digest
-  from = comment.diary_entry.user
+  date = comment.created_at
+  from = User.find(recipient[2])
   to = comment.user
   to = comment.user
-  subject = mail.subject
-else
-  message = Message.find(recipient[2])
+  token = recipient[3]
+elsif recipient = ARGV[0].match(/^m-(\d+)-(.*)$/)
+  message = Message.find(recipient[1])
   digest = message.digest
   digest = message.digest
+  date = message.sent_on
   from = message.recipient
   to = message.sender
   from = message.recipient
   to = message.sender
-  subject = mail.subject.sub(/\[OpenStreetMap\] */, "")
+  token = recipient[2]
+else
+  exit 0
 end
 
 end
 
-exit 0 unless recipient[3] == digest[0,6]
+exit 0 unless token == digest[0, 6]
+exit 0 if date < 1.month.ago
+
+message.update_attribute(:message_read, true) if message
 
 
-mail = TMail::Mail.parse(STDIN.readlines.join)
+mail = Mail.new(STDIN.readlines.join)
 
 
-message = Message.new(:sender => from, :recipient => to,
-                      :sent_on => Time.now.getutc,
-                      :title => subject,
-                      :body => mail.body)
+message = Message.from_mail(mail, from, to)
 message.save!
 
 message.save!
 
-Notifier::deliver_message_notification(message)
+Notifier.message_notification(message).deliver
 
 exit 0
 
 exit 0