X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/6257d0524bfb1247f04538b9fde2a7ddb7b15d2a..c94be6fd9c3d76c88d0e64d26673d0904e49ca07:/lib/nos_oignons/member.rb?ds=sidebyside diff --git a/lib/nos_oignons/member.rb b/lib/nos_oignons/member.rb index 32d32f7..0feb825 100644 --- a/lib/nos_oignons/member.rb +++ b/lib/nos_oignons/member.rb @@ -1,3 +1,22 @@ +#-*- coding: utf-8 -*- +# +# Système de gestion des adhésions de Nos oignons +# Copyright © 2013-2014 Nos oignons +# +# 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 . + +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