X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/9abd734720ddad01338b0556ed6210bac5c5b145..167c022752e162910ffaddc29e449412c3f83717:/lib/nos_oignons.rb diff --git a/lib/nos_oignons.rb b/lib/nos_oignons.rb index 028cac9..4ecd3c4 100644 --- a/lib/nos_oignons.rb +++ b/lib/nos_oignons.rb @@ -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