module Eco module API class Session class Config class TagTree < BaseConfig class MissingTagtree < StandardError end attr_key :file # @param include_archived [Boolean] whether or not it should include archived nodes. # @return [Eco::API::Organization::TagTree] def scope_tree(enviro: nil, include_archived: true, raise_on_missing: true) return @tagtree if instance_variable_defined?(:@tagtree) && @tagtree.enviro == enviro if tree_file = self.file if (tree = file_manager.load_json(tree_file)) && !tree.empty? @tagtree = Eco::API::Organization::TagTree.new(tree, enviro: enviro) end end kargs = { enviro: enviro, includeArchivedNodes: include_archived } @tagtree ||= live_tree(**kargs).tap do |tree| unless tree && !tree.empty? msg = "Could not find a local or live locations structure." raise MissingTagtree, msg end end end # Among all the locations structures it selects the one with more location nodes # If `id` is provided, it only retrieves this locations structure. def live_tree(id: nil, enviro: nil, include_archived: false, **kargs, &block) return @live_tree if instance_variable_defined?(:@live_tree) && @live_tree.enviro == enviro kargs = { enviro: enviro, includeArchivedNodes: include_archived }.merge(kargs) if id args = { id: id }.merge(kargs) @live_tree = live_tree_get(**args, &block) else kargs trees = live_trees(**kargs, &block) @live_tree = trees.reject do |tree| tree.empty? end.max do |a,b| a.count <=> b.count end end.tap do |tree| if tree msg = "Using LIVE LOCATIONS Structure: '#{tree.name}' (#{tree.count} nodes)" session_logger.info(msg) end end end # Gets a single locations structure # @note it does not memoize # @param include_archived [Boolean] whether or not to include archived **nodes** # @return [Eco::API::Organization::TagTree, NilClass] def live_tree_get(id: nil, enviro: nil, include_archived: false, **kargs, &block) return nil unless apis.active_api.version_available?(:graphql) return nil unless graphql = apis.api(version: :graphql) kargs = { id: id, includeArchivedNodes: include_archived }.merge(kargs) return nil unless tree = graphql.currentOrganization.locationStructure(**kargs, &block) args = { enviro: enviro, id: tree.id, name: tree.name } Eco::API::Organization::TagTree.new(tree.treeify, **args) end # Retrieves all the location structures of the organisation # @param include_archived [Boolean] whether or not to include archived **nodes** # @return [Array] def live_trees(enviro: nil, include_archived: false, **kargs, &block) [].tap do |eco_trees| next unless apis.active_api.version_available?(:graphql) next unless graphql = apis.api(version: :graphql) kargs = { includeArchivedNodes: include_archived }.merge(kargs) next unless trees = graphql.currentOrganization.locationStructures(**kargs, &block) trees.each do |tree| args = { enviro: enviro, id: tree.id, name: tree.name } eco_tree = Eco::API::Organization::TagTree.new(tree.treeify, **args) eco_trees.push(eco_tree) end end end private def session ASSETS.session end def session_logger session.logger end end end end end end