]> nos-oignons.net Git - gestion-adh.git/blobdiff - lib/nos_oignons.rb
Fix NosOigons::Member.db_path
[gestion-adh.git] / lib / nos_oignons.rb
index d3777758197eb9c250a86184267f4e5e16a31831..26ffdc63e09b25e9eed5349246a6b4ef23c70c28 100644 (file)
@@ -2,26 +2,50 @@
 
 require 'nos_oignons/git'
 require 'nos_oignons/mailman'
 
 require 'nos_oignons/git'
 require 'nos_oignons/mailman'
-require 'nos_oignons/subscriptions'
+require 'nos_oignons/member'
+require 'nos_oignons/reminder'
+require 'nos_oignons/reminder_db'
 
 module NosOignons
 
 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!
   # The following class methods are all meant to be called as command-line scripts
   class << self
     def list_emails!
-      NosOignons::Subscription.all.each do |subscription|
-        if subscription.up_to_date?
-          puts subscription.email
+      NosOignons::Member.all.each do |member|
+        if member.up_to_date?
+          puts member.email
         end
       end
     end
 
         end
       end
     end
 
-    MEMBER_MAILING_LIST = 'ag'
     def update_ag_subscribers!
     def update_ag_subscribers!
-      current_emails = NosOignons::Mailman.list_members(MEMBER_MAILING_LIST)
-      uptodate_emails = NosOignons::Subscription.all.select(&:up_to_date?).collect(&:email)
+      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(list, uptodate_emails - current_emails)
+      NosOignons::Mailman.remove_members(list, current_emails - uptodate_emails)
+    end
 
 
-      NosOignons::Mailman.add_members(MEMBER_MAILING_LIST, uptodate_emails - current_emails)
-      NosOignons::Mailman.remove_members(MEMBER_MAILING_LIST, current_emails - uptodate_emails)
+    def send_membership_reminders!
+      today = Time.now.to_date
+      NosOignons::Member.all.select(&:up_to_date?).each do |member|
+        NosOignons::Reminder.all.sort_by(&:days).reverse.each do |reminder|
+          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.membership_fee_paid_on > today - reminder.days
+          next if anniversary > today - reminder.days
+          next if member.reminded_on && member.reminded_on >= today
+
+          member.remind(reminder)
+          break
+        end
+      end
     end
 
     def pre_commit_hook!
     end
 
     def pre_commit_hook!
@@ -34,10 +58,10 @@ module NosOignons
 
       IO.popen(['git', 'diff-index', '--cached', '--name-status', against]) do |io|
         NosOignons::Git.handle_modified_files(io) do |file|
 
       IO.popen(['git', 'diff-index', '--cached', '--name-status', against]) do |io|
         NosOignons::Git.handle_modified_files(io) do |file|
-          next unless file.start_with?("#{NosOignons::SUBSCRIPTIONS_ROOT}/")
+          next unless file.start_with?("#{NosOignons::MEMBERS_DB_DIR}/")
           begin
             # Use empty ref to get the index
           begin
             # Use empty ref to get the index
-            NosOignons::Subscription.read_from_git('', file)
+            NosOignons::Member.read_from_git('', file)
           rescue ArgumentError
             $stderr.puts "Désolé : #{file} n'a pas le bon format !"
             exit 1
           rescue ArgumentError
             $stderr.puts "Désolé : #{file} n'a pas le bon format !"
             exit 1
@@ -51,9 +75,9 @@ module NosOignons
         old_value, new_value, ref_name = ref_line.rstrip.split(' ', 3)
         IO.popen(['git', 'diff', '--name-status', "#{old_value}..#{new_value}"]) do |io|
           NosOignons::Git.handle_modified_files(io) do |file|
         old_value, new_value, ref_name = ref_line.rstrip.split(' ', 3)
         IO.popen(['git', 'diff', '--name-status', "#{old_value}..#{new_value}"]) do |io|
           NosOignons::Git.handle_modified_files(io) do |file|
-            next unless file.start_with?("#{NosOignons::SUBSCRIPTIONS_ROOT}/")
+            next unless file.start_with?("#{NosOignons::MEMBERS_DB_DIR}/")
             begin
             begin
-              NosOignons::Subscription.read_from_git(new_value, file)
+              NosOignons::Member.read_from_git(new_value, file)
             rescue ArgumentError
               $stderr.puts "Désolé : #{file} n'a pas le bon format !"
               exit 1
             rescue ArgumentError
               $stderr.puts "Désolé : #{file} n'a pas le bon format !"
               exit 1