Class: DataShift::DataFlowSchema
- Inherits:
-
Object
- Object
- DataShift::DataFlowSchema
- Includes:
- Logging
- Defined in:
- lib/datashift/mapping/data_flow_schema.rb
Instance Attribute Summary collapse
-
#nodes ⇒ Object
readonly
Returns the value of attribute nodes.
-
#raw_data ⇒ Object
readonly
Returns the value of attribute raw_data.
-
#yaml_data ⇒ Object
readonly
Returns the value of attribute yaml_data.
Instance Method Summary collapse
- #create_node_collections(klass, doc_context: nil) ⇒ Object
-
#headers ⇒ Object
@headers= <DataShift::Header:0x00000004bc37f8 @presentation=“status_str”, @source=“status_str”>],.
-
#initialize ⇒ DataFlowSchema
constructor
A new instance of DataFlowSchema.
-
#klass_to_model_methods(klass) ⇒ Object
Helpers for dealing with Active Record models and collections Catalogs the supplied Klass and builds set of expected/valid Headers for Klass.
-
#prepare_from_file(file_name, locale_key = 'data_flow_schema') ⇒ Object
Supports YAML with optional ERB snippets.
-
#prepare_from_klass(klass, doc_context = nil) ⇒ Object
Build the node collection from a Class, that is for each operator in scope create a method binding and a node context, and add to collection.
- #prepare_from_string(text, locale_key = 'data_flow_schema') ⇒ Object
- #prepare_from_yaml(yaml, locale_key = 'data_flow_schema') ⇒ Object
- #sources ⇒ Object
Methods included from Logging
#logdir, #logdir=, #logger, #verbose
Constructor Details
#initialize ⇒ DataFlowSchema
Returns a new instance of DataFlowSchema.
54 55 56 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 54 def initialize @nodes = DataShift::NodeCollection.new end |
Instance Attribute Details
#nodes ⇒ Object (readonly)
Returns the value of attribute nodes.
52 53 54 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 52 def nodes @nodes end |
#raw_data ⇒ Object (readonly)
Returns the value of attribute raw_data.
52 53 54 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 52 def raw_data @raw_data end |
#yaml_data ⇒ Object (readonly)
Returns the value of attribute yaml_data.
52 53 54 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 52 def yaml_data @yaml_data end |
Instance Method Details
#create_node_collections(klass, doc_context: nil) ⇒ Object
72 73 74 75 76 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 72 def create_node_collections(klass, doc_context: nil) context = doc_context || DocContext.new(klass) @nodes = DataShift::NodeCollection.new(doc_context: context) @nodes end |
#headers ⇒ Object
@headers= <DataShift::Header:0x00000004bc37f8
@presentation="status_str",
@source="status_str">],
63 64 65 66 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 63 def headers # TODO fix doc context so it can be created 'empty' i.e without AR klass, and always has empty headers @nodes.doc_context.try(:headers) || [] end |
#klass_to_model_methods(klass) ⇒ Object
Helpers for dealing with Active Record models and collections Catalogs the supplied Klass and builds set of expected/valid Headers for Klass
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 100 def klass_to_model_methods(klass) op_types_in_scope = DataShift::Configuration.call.op_types_in_scope collection = ModelMethods::Manager.catalog_class(klass) model_methods = [] if collection collection.each { |mm| model_methods << mm if(op_types_in_scope.include? mm.operator_type) } remove = DataShift::Transformation::Remove.new remove.unwanted_model_methods model_methods end model_methods end |
#prepare_from_file(file_name, locale_key = 'data_flow_schema') ⇒ Object
Supports YAML with optional ERB snippets
See Config generation or lib/datashift/templates/import_export_config.erb for full syntax
124 125 126 127 128 129 130 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 124 def prepare_from_file(file_name, locale_key = 'data_flow_schema') @raw_data = ERB.new(File.read(file_name)).result yaml = YAML.load(raw_data) prepare_from_yaml(yaml, locale_key) end |
#prepare_from_klass(klass, doc_context = nil) ⇒ Object
Build the node collection from a Class, that is for each operator in scope create a method binding and a node context, and add to collection.
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 81 def prepare_from_klass( klass, doc_context = nil ) @nodes = create_node_collections(klass, doc_context: doc_context) klass_to_model_methods( klass ).each_with_index do |mm, i| @nodes.headers.add(mm.operator) # for a class, the header names, default to the operators (methods) binding = MethodBinding.new(mm.operator, i, mm) # TODO - do we really need to pass in the doc context when parent nodes already has it ? @nodes << DataShift::NodeContext.new(@nodes.doc_context, binding, i, nil) end @nodes end |
#prepare_from_string(text, locale_key = 'data_flow_schema') ⇒ Object
132 133 134 135 136 137 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 132 def prepare_from_string(text, locale_key = 'data_flow_schema') @raw_data = text yaml = YAML.load(raw_data) prepare_from_yaml(yaml, locale_key) end |
#prepare_from_yaml(yaml, locale_key = 'data_flow_schema') ⇒ Object
139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 139 def prepare_from_yaml(yaml, locale_key = 'data_flow_schema') @yaml_data = yaml raise "Bad YAML syntax - No key #{locale_key} found in #{yaml}" unless yaml[locale_key] locale_section = yaml[locale_key] class_name = locale_section.keys.first klass = MapperUtils.class_from_string_or_raise(class_name) klass_section = locale_section[class_name] DataShift::Transformation.factory { |f| f.configure_from_yaml(class_name, klass_section) } @nodes = create_node_collections(klass) if(klass_section && klass_section.key?('nodes')) yaml_nodes = klass_section['nodes'] logger.info("Read Data Schema Nodes: #{yaml_nodes.inspect}") unless(yaml_nodes.is_a?(Array)) Rails.logger.error('Bad syntax in flow schema YAML - Nodes should be a sequence') raise 'Bad syntax in flow schema YAML - Nodes should be a sequence' end # for operator and type model_method_mgr = ModelMethods::Manager.catalog_class(klass) yaml_nodes.each_with_index do |keyed_node, i| unless(keyed_node.keys.size == 1) raise ConfigFormatError, "Bad syntax in flow schema YAML - Section #{keyed_node} should be keyed hash" end # data_flow_schema: # Project: # nodes: # - project: # source: "title" # source of data, defaults to node name (project) if not specified # presentation: "Title" # e.g for export headers # operator: title # operator_type: has_many # logger.info("Node Data: #{keyed_node.inspect}") node = keyed_node.keys.first section = keyed_node.values.first || {} # TODO - layout with heading is verbose for no benefit - defunct, simply node.source, node.presentation source = section.fetch('heading', {}).fetch('source', nil) # Unless a specific source mentioned assume the node is the source source ||= section.fetch('source', node) presentation = section.fetch('presentation', nil) @nodes.headers.add(source, presentation: presentation) if(section['operator']) # Find the domain model method details model_method = model_method_mgr.search(section['operator']) unless model_method operator_type = section['operator_type'] || :method # expect one of ModelMethod.supported_types_enum model_method = model_method_mgr.insert(section['operator'], operator_type) end method_binding = InternalMethodBinding.new(model_method) end method_binding ||= MethodBinding.new(source, i, model_method) node_context = DataShift::NodeContext.new(@nodes.doc_context, method_binding, i, nil) @nodes << node_context end end @nodes end |
#sources ⇒ Object
68 69 70 |
# File 'lib/datashift/mapping/data_flow_schema.rb', line 68 def sources @nodes.collect(&:method_binding).collect(&:source) end |