/islandora_feeds

Feeds module for importing Islandora objects

Primary LanguagePHP

Islandora Feeds Importer

Introduction

This module allows users to create Islandora objects using the Feeds contrib module. This is still a very early proof-of-concept module.

Requirements

Feeds

Installation

Install as usual, see this for further information.

Usage

This module provides a Feeds processor that creates Islandora objects. Currently, the only datastream that is created is a managed XML datastream that contains elements mirroring the column headings in CSV files (or equivalent in other input formats) you are loading using Feeds, with element values that correspond to the values in the columns. Also, this module only imports data, it doesn't provide any way to view the imported data (other than by using Islandora's links to the imported datastream in the object's "Datastreams" tab.

The Processor provided by this module is similar to other Feeds processors. It uses a version of Feeds' Node processor to create a node for each item you are importing. Each node then serves as the source of the Islandora object that is created. You have the option of saving these nodes (for quality assurance) or deleting them immediately after the Islandora object is created.

For each content model you are importing objects into, you need to create a Drupal content type that contains all the fields corresponding to the data in your incoming Feed source. The nodes created during the import are instances of this content type.

After you have created your content type, configure your Feed importer by going to Structure > Feeds importers > Add importer and create a new importer. Attach your content type to the importer. Then edit the importer. The only settings you need to configure are the Processor settings. Under the Processor settings, select the Islandora Feeds node processor, and save. Then in the Processor Mappings, map the fields in your CSV (or similar) source to fields in your target content type.

Be sure to select the correct Islandora content model, collection, and datastream label. The datastream ID will correspond to the machine name of the bundle you attach the feed to. Also, you have the option to keep the nodes created during the import or have them deleted automatically. Note that these nodes do not have any relationship to the objects ingested into Fedora after the import is complete - they are only used as the source of the ingest and are not synchronized with the objects after the import.

You should map one of the fields in your source to Title in your target. The only other columns in your source you need to map are the ones you have defined in your target content type - you do not need to map any of the node properties unless you want to.

Once you have configured the importer, you're ready to import your source conent.

Notes

  • Mapping a source field that is a number to the title won’t work. Islandora defaults to sequential numbering as a label when you attempt it.
  • When deleting nodes, the error message suggests you’ve deleted Islandora objects. This is not correct - only the Drupal content is deleted.

To do

  • Add the ability to inspect/edit/etc. nodes before ingesting the objects into Fedora
  • Filter out content models in the config settings form that don't make sense.
  • Figure out how to import handle thumbnails and additional datastreams.
  • Figure out how to support deleting content loaded via this module.

Troubleshooting/issues/feedback

Use cases are welcome. The goal of this module is to leverage as much of Feeds' built-in functionality as possible while providing the ability to load a wide range of Islandora content types as possible. If you have any questions or comments, please post them to: