]> nos-oignons.net Git - gestion-adh.git/blobdiff - lib/nos_oignons.rb
Fix send-membership-reminders broken logic
[gestion-adh.git] / lib / nos_oignons.rb
index 028cac97375f77f8d0227dcdef5ea8c3a5fbc941..4ecd3c4b7e23600c50d8b3c38c5adae4e48b5d56 100644 (file)
@@ -3,8 +3,13 @@
 require 'nos_oignons/git'
 require 'nos_oignons/mailman'
 require 'nos_oignons/member'
+require 'nos_oignons/reminder'
+require 'nos_oignons/reminder_db'
 
 module NosOignons
+  BOARD_EMAIL = 'ca@nos-oignons.net'
+  MEMBER_MAILING_LIST = 'ag'
+
   # The following class methods are all meant to be called as command-line scripts
   class << self
     def list_emails!
@@ -15,13 +20,32 @@ module NosOignons
       end
     end
 
-    MEMBER_MAILING_LIST = 'ag'
     def update_ag_subscribers!
-      current_emails = NosOignons::Mailman.list_members(MEMBER_MAILING_LIST)
+      list = NosOignons::MEMBER_MAILING_LIST
+
+      current_emails = NosOignons::Mailman.list_members(list)
       uptodate_emails = NosOignons::Member.all.select(&:up_to_date?).collect(&:email)
 
-      NosOignons::Mailman.add_members(MEMBER_MAILING_LIST, uptodate_emails - current_emails)
-      NosOignons::Mailman.remove_members(MEMBER_MAILING_LIST, current_emails - uptodate_emails)
+      emails_to_add = uptodate_emails - current_emails
+      NosOignons::Mailman.add_members(list, emails_to_add) unless emails_to_add.empty?
+      emails_to_remove = current_emails - uptodate_emails
+      NosOignons::Mailman.remove_members(list, emails_to_remove) unless emails_to_remove.empty?
+    end
+
+    def send_membership_reminders!
+      today = Time.now.to_date
+      NosOignons::Member.all.select(&:up_to_date?).each do |member|
+        anniversary = Time.new(today.year, member.joined_on.month,
+                               member.joined_on.day).to_date
+        next if member.membership_fee_paid_on >= anniversary
+        next if member.reminded_on && member.reminded_on >= today
+        NosOignons::Reminder.all.sort_by(&:days).reverse.each do |reminder|
+          next if anniversary < today + reminder.days
+
+          member.remind(reminder)
+          break
+        end
+      end
     end
 
     def pre_commit_hook!
@@ -38,7 +62,7 @@ module NosOignons
           begin
             # Use empty ref to get the index
             NosOignons::Member.read_from_git('', file)
-          rescue ArgumentError
+          rescue ArgumentError, Psych::SyntaxError
             $stderr.puts "Désolé : #{file} n'a pas le bon format !"
             exit 1
           end
@@ -54,7 +78,7 @@ module NosOignons
             next unless file.start_with?("#{NosOignons::MEMBERS_DB_DIR}/")
             begin
               NosOignons::Member.read_from_git(new_value, file)
-            rescue ArgumentError
+            rescue ArgumentError, Psych::SyntaxError
               $stderr.puts "Désolé : #{file} n'a pas le bon format !"
               exit 1
             end