X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/6a086c6afe926f02597b81b21b58000166b2c885..9cb7fa95bef77a6d1e0888f741c76adc865f1b17:/lib/nos_oignons/member.rb diff --git a/lib/nos_oignons/member.rb b/lib/nos_oignons/member.rb index 8b0bd97..4bf23ca 100644 --- a/lib/nos_oignons/member.rb +++ b/lib/nos_oignons/member.rb @@ -35,7 +35,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 +59,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 +103,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