X-Git-Url: https://nos-oignons.net/gitweb/gestion-adh.git/blobdiff_plain/4c730203fde2eb1d6fdcbe11542c6730d11124ae..9cb7fa95bef77a6d1e0888f741c76adc865f1b17:/lib/nos_oignons/member.rb diff --git a/lib/nos_oignons/member.rb b/lib/nos_oignons/member.rb index 9787a63..4bf23ca 100644 --- a/lib/nos_oignons/member.rb +++ b/lib/nos_oignons/member.rb @@ -1,22 +1,46 @@ require 'safe_yaml' SafeYAML::OPTIONS[:default_mode] = :safe +require 'nos_oignons/reminder_db' + module NosOignons - MEMBERS_ROOT = 'Membres' - MEMBER_FIELDS = [:name, :address, :email, :membership_fee_paid_on] + MEMBER_FIELDS = [:name, :address, :email, :joined_on, :membership_fee_paid_on] MEMBER_MANDATORY_FIELDS = [:name, :email] + # Directory in the board wiki which holds the member pages + MEMBERS_DB_DIR = 'Membres' class Member < Struct.new(*MEMBER_FIELDS) class << self + def db_path + if ENV['NOS_OIGNONS_BOARD_WIKI_PATH'] + @db_path = File.join(ENV['NOS_OIGNONS_BOARD_WIKI_PATH'], MEMBERS_DB_DIR) + else + return @db_path if @db_path + + git_path = `git rev-parse --show-toplevel`.strip + 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', git_path), MEMBERS_DB_DIR) + end + end + @db_path + end + def all - Dir.glob("#{MEMBERS_ROOT}/*.mdwn").sort.collect do |file| + Dir.glob("#{db_path}/*.mdwn").sort.collect do |file| member_id = File.basename(file).gsub(/\.mdwn$/, '') Member.new(member_id) end end def filename_for_id(member_id) - "Membres/%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) @@ -35,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 @@ -51,15 +80,35 @@ module NosOignons MEMBER_MANDATORY_FIELDS.each do |sym| raise ArgumentError.new('missing mandatory fields') unless self[sym] end - if membership_fee_paid_on && !membership_fee_paid_on.is_a?(Date) - raise ArgumentError.new('membership_fee_paid_on is not a date') + [:joined_on, :membership_fee_paid_on].each do |sym| + if self[sym] && !self[sym].is_a?(Date) + raise ArgumentError.new("#{sym.to_s} is not a date") + end end end def up_to_date? - now = Time.now - last_year = Time.new(now.year - 1, now.month, now.day).to_date - membership_fee_paid_on && last_year < membership_fee_paid_on + return false if !joined_on || !membership_fee_paid_on + + today = Time.now.to_date + expire_on = Time.new(membership_fee_paid_on.year + 1, joined_on.month, joined_on.day).to_date + today <= expire_on + end + + def remind(reminder) + reminder.send(self) + ReminderDb.instance.record(self) + end + + 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