Module: ActiveFedora::Datastreams::ClassMethods

Defined in:
lib/active_fedora/datastreams.rb

Instance Method Summary (collapse)

Instance Method Details

- (Object) build_datastream_accessor(dsid)



225
226
227
228
229
230
# File 'lib/active_fedora/datastreams.rb', line 225

def build_datastream_accessor(dsid)
name = name_for_dsid(dsid)
define_method name do
  datastreams[dsid]
end
end

- (Class) datastream_class_for_name(dsid)

Returns the class of the datastream

Parameters:

  • dsid (String)

    the datastream id

Returns:

  • (Class)

    the class of the datastream



162
163
164
# File 'lib/active_fedora/datastreams.rb', line 162

def datastream_class_for_name(dsid)
  ds_specs[dsid] ? ds_specs[dsid].fetch(:type, ActiveFedora::Datastream) : ActiveFedora::Datastream
end

- (Object) has_file_datastream(name, args) - (Object) has_file_datastream(args)

Overloads:

  • - (Object) has_file_datastream(name, args)

    Declares a file datastream exists for objects of this type

    Parameters:

    • name (String)
    • args (Hash)

      @option args :type (ActiveFedora::Datastream) The class the datastream should have @option args :label (“File Datastream”) The default value to put in the dsLabel field @option args :control_group (“M”) The type of controlGroup to store the datastream as. Defaults to M @option args [Boolean] :autocreate Always create this datastream on new objects @option args [Boolean] :versionable Should versioned datastreams be stored

  • - (Object) has_file_datastream(args)

    Declares a file datastream exists for objects of this type

    Parameters:

    • args (Hash)

      @option args :name (“content”) The dsid of the datastream @option args :type (ActiveFedora::Datastream) The class the datastream should have @option args :label (“File Datastream”) The default value to put in the dsLabel field @option args :control_group (“M”) The type of controlGroup to store the datastream as. Defaults to M @option args [Boolean] :autocreate Always create this datastream on new objects @option args [Boolean] :versionable Should versioned datastreams be stored



214
215
216
217
218
219
220
221
222
223
# File 'lib/active_fedora/datastreams.rb', line 214

def has_file_datastream(*args)
  @file_ds_defaults ||= {
    :autocreate => false,
    :type=>ActiveFedora::Datastream,
    :label=>"File Datastream",
    :control_group=>"M",
    :name=>"content"
  }
  spec_datastream(args, @file_ds_defaults)
end

- (Object) has_metadata(*args) { ... }

This method is used to specify the details of a datastream. You can pass the name as the first argument and a hash of options as the second argument or you can pass the :name as a value in the args hash. Either way, name is required. Note that this method doesn't actually execute the block, but stores it, to be executed by any the implementation of the datastream(specified as :type)

Parameters:

  • args (Hash)

Yields:

  • block executed by some kinds of datastreams



182
183
184
185
186
187
188
189
190
191
192
193
# File 'lib/active_fedora/datastreams.rb', line 182

def (*args, &block)
  @metadata_ds_defaults ||= {
    :autocreate => false,
    :type=>nil,
    :label=>"",
    :control_group=>nil,
    :disseminator=>"",
    :url=>"",
    :name=>nil
  }
  spec_datastream(args, @metadata_ds_defaults, &block)
end