X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/3e57bb279787236b1349f6b1da2ecf61ed4211e0..6a086c6afe926f02597b81b21b58000166b2c885:/lib/nos_oignons.rb diff --git a/lib/nos_oignons.rb b/lib/nos_oignons.rb index d377775..26ffdc6 100644 --- a/lib/nos_oignons.rb +++ b/lib/nos_oignons.rb @@ -2,26 +2,50 @@ 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 + 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! - 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 - MEMBER_MAILING_LIST = 'ag' 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! @@ -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| - 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 - 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 @@ -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| - next unless file.start_with?("#{NosOignons::SUBSCRIPTIONS_ROOT}/") + next unless file.start_with?("#{NosOignons::MEMBERS_DB_DIR}/") 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