module Eco module API class Session class Config < Hash attr_reader :name def initialize(name = :default) super(nil) @name = name self["org"] = {} end def clone(name) keys.each_with_object(self.class.new(name)) do |key, cnf| begin cnf[key] = self[key].clone(config: cnf) rescue ArgumentError cnf[key] = self[key].clone end end end def reopen yield(self) end def apis self["apis"] ||= Session::Config::Apis.new(config: self) end def logger self["logger"] ||= Session::Config::Logger.new(config: self) end def s3storage self["s3_storage"] ||= Session::Config::S3Storage.new(config: self) end def files self["files"] ||= Session::Config::Files.new(config: self) end def mailer self["mailer"] ||= Session::Config::Mailer.new(config: self) end def org self["org"] end def people self["people"] ||= Session::Config::People.new(config: self) end # LOGGER def log_console_level=(value) logger.console_level= value end def log_file_level=(value) logger.file_level = value end def log_file=(file) logger.file = file end def timestamp_console=(value) logger.timestamp_console = value end def log_connection=(value) logger.log_connection = value end # API def dry_run! self["dry-run"] = true end def dry_run? self["dry-run"] end def run_mode=(mode) apis.active_api.mode = mode end def run_mode_local? apis.active_api.local? end def run_mode_remote? apis.active_api.remote? end def apis? apis.apis? end def add_api(name, **kargs) apis.add(name, **kargs) self end def active_api(name) apis.active_name = name self end def api(logger = ::Logger.new(IO::NULL)) apis.api(logger) end # FILES def working_directory=(path) files.working_directory = path end def working_directory(mode: :active_api) if mode == :active_api apis.active_root_name else files.working_directory end end def file_timestamp_pattern=(pattern) files.timestamp_pattern = pattern end def file_manager Eco::API::Common::Session::FileManager.new(self) end def require(file = nil, match: nil) if match file_manager.dir.dir_files(pattern: match).each do |file| #pp "#{File.expand_path(file)}" require_relative File.expand_path(file) end else require_relative "#{File.expand_path(file_manager.dir.file(file))}" end end # ORG def location_codes=(file) org["location_codes"] = file end def location_codes org["location_codes"] end def locations_mapper file = file_manager.newest(location_codes) @locations_mapper ||= Eco::Data::Mapper.new(file_manager.load_json(file), internal: :first) end def tagtree=(file) org["tagtree"] = file end def policy_groups return @policy_groups if instance_variable_defined?(:@policy_groups) pgs = api&.policy_groups.to_a @policy_groups = Eco::API::Organization::PolicyGroups.new(pgs) end def schemas return @schemas if instance_variable_defined?(:@schemas) schs = api&.person_schemas.to_a @schemas = Eco::API::Organization::PersonSchemas.new(schs) end # PEOPLE def discarded_people_file=(value) people.discarded_file = value end def people_cache=(file) people.cache = file end def requests_backup_folder=(folder) people.requests_folder = folder end # PERSON FIELDS MAPPER def person_fields_mapper=(file) people.fields_mapper = file end def default_schema=(name) people.default_schema = name end # ACCOUNT PRESETS def presets_custom=(file) people.presets_custom = file end def presets_map=(file) people.presets_map = file end # CUSTOM PERSON PARSERS def person_parser(format: :csv, &block) people.parser(format: format, &block) end # CUSTOM USE CASES def usecases cases = self["usecases"] ||= Eco::API::UseCases::UseGroup.new if block_given? yield(cases) self else cases end end # API POLICIES def policies api_policies = self["policies"] ||= Eco::API::Policies::UsedPolicies.new if block_given? yield(api_policies) self else api_policies end end end end end end require_relative 'config/base_config' require_relative 'config/api' require_relative 'config/apis' require_relative 'config/logger' require_relative 'config/mailer' require_relative 'config/s3_storage' require_relative 'config/files' require_relative 'config/people'