X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/9d982cb5d7f9abe598c8df3eefabe10501056110..3559b3c8b4be7605ef50162207911ae3b5d9f36b:/lib/nos_oignons/member.rb?ds=sidebyside diff --git a/lib/nos_oignons/member.rb b/lib/nos_oignons/member.rb index 46fc41b..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 @@ -21,7 +40,7 @@ module NosOignons if File.exists?(File.join(git_path, MEMBERS_DB_DIR)) @db_path = File.join(git_path, MEMBERS_DB_DIR) else - @db_path = File.join(File.expand_path('../wiki-ca', path), MEMBERS_DB_DIR) + @db_path = File.join(File.expand_path('../wiki-ca', git_path), MEMBERS_DB_DIR) end end @db_path @@ -35,7 +54,12 @@ module NosOignons end def filename_for_id(member_id) - "#{NosOignons::Member.db_path}/%06d.mdwn" % member_id + case member_id + when String + "#{NosOignons::Member.db_path}/#{member_id}.mdwn" + when Integer + "#{NosOignons::Member.db_path}/%06d.mdwn" % member_id + end end def read_from_git(ref, file) @@ -54,12 +78,17 @@ 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') end - data = YAML.load(page_content) + yaml_content = /\A---\n(.*)\n---\n/m.match(page_content)[1] + data = YAML.load(yaml_content) MEMBER_FIELDS.each do |field| self[field] = data[field.to_s] end @@ -93,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