X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/457001c90a8e16ee40b314e4281658238048648c..e3849b258d72a17748bd07c931980d382ac88082:/lib/nos_oignons.rb diff --git a/lib/nos_oignons.rb b/lib/nos_oignons.rb index 2a5d414..dec787e 100644 --- a/lib/nos_oignons.rb +++ b/lib/nos_oignons.rb @@ -8,10 +8,29 @@ require 'nos_oignons/reminder_db' module NosOignons BOARD_EMAIL = 'ca@nos-oignons.net' + ADVISORS_EMAIL = 'deontologie@nos-oignons.net' MEMBER_MAILING_LIST = 'ag' + CONTACT_INFO = <<-EOT.gsub(/^ /, '') + https://nos-oignons.net/ + contact@nos-oignons.net + Téléphone : +33 9 72 42 96 04 + Fax : +33 9 72 42 96 06 + EOT + POSTAL_ADDRESS = <<-EOT.gsub(/^ /, '') + Nos oignons + Centre UBIDOCA, 7585 + 105 route des Pommiers + 74370 Saint Martin Bellevue + France + EOT # The following class methods are all meant to be called as command-line scripts class << self + def create_membership_fee_receipt!(member_id, amount) + member = NosOignons::Member.new(member_id) + member.create_receipt!(amount) + end + def list_emails! NosOignons::Member.all.each do |member| if member.up_to_date? @@ -35,14 +54,13 @@ module NosOignons 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 + reminders = NosOignons::Reminder.all.sort_by(&:days) + anniversary = Time.new(today.year, member.joined_on.month, + member.joined_on.day).to_date + next if member.membership_fee_paid_on >= anniversary - reminders.last.days + reminders.each do |reminder| + next if (anniversary - today).to_i > reminder.days + next if member.reminded_on && (anniversary - member.reminded_on).to_i <= reminder.days member.remind(reminder) break @@ -50,6 +68,32 @@ module NosOignons end end + def send_member_emails_to_advisors! + uptodate_emails = NosOignons::Member.all.select(&:up_to_date?).collect(&:email) + subject = 'Adresses email des membres à jour de cotisation' + body = <<-END_OF_BODY.gsub(/^ /, '') + Cher comité de déontologie de Nos oignons, + + Comme le prévoient les statuts l'article 12 des statuts de + l'association, vous devez être en mesure de pouvoir convoquer une + assemblée générale extraordinaire. Pour ce faire, voici donc la liste + des emails à jour de cotisation à la date d'aujourd'hui : + + #{uptodate_emails.join("\n")} + + Et merci encore de votre engagement auprès de Nos oignons ! + + -- + Le robot du conseil d'administration + END_OF_BODY + mail = Mail.new :charset => 'utf-8', + :from => NosOignons::BOARD_EMAIL, + :to => NosOignons::ADVISORS_EMAIL, + :subject => subject, + :body => body + mail.deliver + end + def pre_commit_hook! if system('git rev-parse --quiet --verify HEAD >/dev/null') against = 'HEAD'