X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/9d982cb5d7f9abe598c8df3eefabe10501056110..9cb7fa95bef77a6d1e0888f741c76adc865f1b17:/lib/nos_oignons/member.rb diff --git a/lib/nos_oignons/member.rb b/lib/nos_oignons/member.rb index 46fc41b..4bf23ca 100644 --- a/lib/nos_oignons/member.rb +++ b/lib/nos_oignons/member.rb @@ -21,7 +21,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 +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