]> nos-oignons.net Git - gestion-adh.git/blobdiff - lib/nos_oignons.rb
?
[gestion-adh.git] / lib / nos_oignons.rb
index 26ffdc63e09b25e9eed5349246a6b4ef23c70c28..b85ebeaec4d255c2cc5ff3426726f2cca32d3bbe 100644 (file)
@@ -1,4 +1,20 @@
 #-*- coding: utf-8 -*-
+#
+# Système de gestion des adhésions de Nos oignons
+# Copyright © 2013-2014 Nos oignons <contact@nos-oignons.net>
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
 require 'nos_oignons/git'
 require 'nos_oignons/mailman'
@@ -8,10 +24,30 @@ 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(/^    /, '')
+    Identifiant SIREN 842 479 313
+    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?
@@ -26,21 +62,22 @@ module NosOignons
       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)
+      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|
-        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
@@ -48,6 +85,35 @@ 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
+
+                              GNU AGPLv3 © Nos oignons <contact@nos-oignons.net>
+                               git clone https://nos-oignons.net/gestion-adh.git
+      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'
@@ -62,7 +128,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
@@ -78,7 +144,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