]> nos-oignons.net Git - gestion-adh.git/blobdiff - lib/nos_oignons/member.rb
résolution conflit
[gestion-adh.git] / lib / nos_oignons / member.rb
index 32d32f70ed500009c9b67d04b4fb8e8537e40157..0feb8255759924d028cd7ee9cb4e7038bf00c623 100644 (file)
@@ -1,3 +1,22 @@
+#-*- 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 'date'
 require 'safe_yaml'
 SafeYAML::OPTIONS[:default_mode] = :safe
 
@@ -59,7 +78,11 @@ module NosOignons
       end
       @member_id = member_id
       unless page_content
-        page_content = File.open(Member.filename_for_id(member_id)).read
+        begin
+          page_content = File.open(Member.filename_for_id(member_id)).read
+        rescue Errno::ENOENT
+          raise ArgumentError.new('unknown member')
+        end
       end
       unless page_content.start_with?("---\n")
         raise ArgumentError.new('content is not a proper YAML document')
@@ -99,5 +122,12 @@ module NosOignons
     def reminded_on
       ReminderDb.instance.last_reminder(self)
     end
+
+    def create_receipt!(amount)
+      require 'nos_oignons/receipt'
+
+      receipt = Receipt.new(self, amount)
+      receipt.create!
+    end
   end
 end