. */ // Permissions define('FEDORA_VIEW', 'view fedora repository'); define('FEDORA_METADATA_EDIT', 'edit fedora metadata'); define('FEDORA_ADD_DS', 'add fedora datastreams'); define('FEDORA_INGEST', 'ingest fedora objects'); define('FEDORA_PURGE', 'delete fedora objects and datastreams'); define('FEDORA_MODIFY_STATE', 'modify fedora state'); define('FEDORA_MANAGE', 'manage fedora items'); // hooks define('ISLANDORA_VIEW_HOOK', 'islandora_view_object'); define('ISLANDORA_EDIT_HOOK', 'islandora_edit_object'); /** * Implements hook_menu(). * we need some standard entry points so we can have consistent urls for different Object actions */ function islandora_menu() { $items = array(); $items['admin/islandora'] = array( 'title' => 'Islandora', 'description' => "Configure settings associated with Islandora.", 'access arguments' => array('administer site configuration'), 'type' => MENU_NORMAL_ITEM, ); $items['admin/islandora/configure'] = array( 'title' => 'Configuration', 'description' => 'Configure settings for Islandora.', 'page callback' => 'drupal_get_form', 'page arguments' => array('islandora_repository_admin'), 'file' => 'admin/islandora.admin.inc', 'access arguments' => array('administer site configuration'), 'type' => MENU_NORMAL_ITEM, 'weight' => -1, ); $items['admin/islandora/solution_packs'] = array( 'title' => 'Solution packs', 'description' => 'Install content models and collections required by installed solution packs.', 'page callback' => 'islandora_solution_packs_admin', 'access arguments' => array(FEDORA_ADD_DS), 'file' => 'includes/solution_packs.inc', 'type' => MENU_NORMAL_ITEM, ); $items['islandora/object/%islandora_object/manage/ingest'] = array( 'title' => 'Add an object', 'page callback' => 'islandora_ingest_callback', 'page arguments' => array(2), 'file' => 'includes/ingest-menu.inc', 'type' => MENU_LOCAL_ACTION, 'access callback' => 'islandora_ingest_access_callback', 'access arguments' => array(2, FEDORA_INGEST), ); $items['islandora'] = array( 'title' => 'Islandora Repository', 'page callback' => 'islandora_view_default_object', 'type' => MENU_NORMAL_ITEM, 'access arguments' => array(FEDORA_VIEW), ); $items['islandora/object/%islandora_object'] = array( 'title' => 'Repository', 'page callback' => 'islandora_view_object', 'page arguments' => array(2), 'type' => MENU_NORMAL_ITEM, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_VIEW), ); $items['islandora/object/%islandora_object/view'] = array( 'title' => 'View', 'type' => MENU_DEFAULT_LOCAL_TASK, 'weight' => -1, ); $items['islandora/object/%islandora_object/view/default'] = array( 'title' => 'View', 'type' => MENU_DEFAULT_LOCAL_TASK, 'weight' => -1, ); $items['islandora/object/%islandora_object/manage'] = array( 'title' => 'Manage', 'page callback' => 'islandora_edit_object', 'page arguments' => array(2), 'type' => MENU_LOCAL_TASK, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_MODIFY_STATE), ); $items['islandora/object/%islandora_object/manage/datastreams'] = array( 'title' => 'Datastreams', 'type' => MENU_DEFAULT_LOCAL_TASK, 'weight' => -10, ); $items['islandora/object/%islandora_object/manage/properties'] = array( 'title' => 'Properties', 'page callback' => 'drupal_get_form', 'file' => 'includes/object_properties.inc', 'page arguments' => array('islandora_edit_properties_form', 2), 'type' => MENU_LOCAL_TASK, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_MODIFY_STATE), 'weight' => -5, ); $items['islandora/object/%islandora_object/delete'] = array( 'title' => 'Delete object', 'file' => 'includes/purge.form.inc', 'page callback' => 'drupal_get_form', 'page arguments' => array('islandora_purge_object', 2), 'type' => MENU_CALLBACK, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_PURGE), ); $items['islandora/object/%islandora_object/manage/datastreams/add'] = array( 'title' => 'Add a datastream', 'file' => 'includes/datastream.inc', 'page callback' => 'drupal_get_form', 'page arguments' => array('islandora_add_datastream_form', 2), 'type' => MENU_LOCAL_ACTION, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_ADD_DS) ); $items['islandora/object/%islandora_object/manage/datastreams/add/autocomplete'] = array( 'file' => 'includes/datastream.inc', 'page callback' => 'islandora_datastream_autocomplete_callback', 'page arguments' => array(2), 'type' => MENU_CALLBACK, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_ADD_DS) ); $items['islandora/object/%islandora_object/datastream/%'] = array( 'title' => 'View datastream', 'page callback' => 'islandora_view_datastream', 'page arguments' => array(2, 4), 'type' => MENU_CALLBACK, 'file' => 'includes/datastream.inc', 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_VIEW), ); $items['islandora/object/%islandora_object/datastream/%/view'] = array( 'title' => 'View datastream', 'type' => MENU_DEFAULT_LOCAL_TASK, ); $items['islandora/object/%islandora_object/datastream/%/download'] = array( 'title' => 'Download datastream', 'page callback' => 'islandora_view_datastream', 'page arguments' => array(2, 4, 5), 'type' => MENU_CALLBACK, 'file' => 'includes/datastream.inc', 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_VIEW), ); $items['islandora/object/%islandora_object/datastream/%/edit'] = array( 'title' => 'Edit datastream', 'page callback' => 'islandora_edit_datastream', 'page arguments' => array(2, 4), 'type' => MENU_CALLBACK, 'file' => 'includes/datastream.inc', 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_METADATA_EDIT), ); $items['islandora/object/%islandora_object/datastream/%/delete'] = array( 'title' => 'Purge data stream', 'page callback' => 'drupal_get_form', 'page arguments' => array('islandora_purge_datastream', 2, 4), 'file' => 'includes/purge.form.inc', 'type' => MENU_CALLBACK, 'access callback' => 'islandora_access_callback', 'access arguments' => array(2, FEDORA_PURGE), ); return $items; } /** * Implements hook_admin_paths(). */ function islandora_admin_paths() { $paths = array(); $paths['islandora/object/*/manage*'] = TRUE; $paths['islandora/object/*/delete'] = TRUE; $paths['islandora/object/*/datastream/*/edit'] = TRUE; return $paths; } /** * determines whether we can see the object or not * checks PID namespace permissions, and user permissions * @global object $user * @param string $op * @param string $pid * * @return boolean */ function islandora_access_callback($object = NULL, $perm = NULL) { if (!$object || !$perm) { return FALSE; } $isRestricted = variable_get('islandora_namespace_restriction_enforced', FALSE); if (!$isRestricted) { $namespace_access = TRUE; } else { $pid_namespace = substr($object->id, 0, strpos($object->id, ':') + 1); // Get the namespace (with colon) $allowed_namespaces = explode(" ", variable_get('islandora_pids_allowed', 'default: demo: changeme: islandora: ilives: islandora-book: books: newspapers: ')); $namespace_access = in_array($pid_namespace, $allowed_namespaces); } return ($namespace_access && user_access($perm)); } /** * returns an array listing object types provided by sub modules * @return array */ function islandora_get_types() { return module_invoke_all('islandora_get_types'); } function islandora_init() { if (path_is_admin(current_path())) { drupal_add_css(drupal_get_path('module', 'islandora') . '/css/islandora.admin.css'); } } /** * Implements hook_forms(). */ function islandora_forms($form_id) { $forms = array(); if (strpos($form_id, 'islandora_solution_pack_form_') !== FALSE) { $forms[$form_id] = array( 'callback' => 'islandora_solution_pack_form', ); } return $forms; } /** * a function to call other modules edit page. If there are not any modules * that handle this function this module will build a default page. * @global object $user * @param string $object_id * @return string */ function islandora_edit_object($object) { if (!$object) { return drupal_not_found(); } drupal_alter('islandora_edit_object', $object); $arr = module_invoke_all('islandora_edit_object', $object); $output = ""; foreach ($arr as $key => $value) { $output .= $value; //if we have multiple modules handle one cmodel we need to iterate over multiple } //we could do another module invoke all here to build the edit tab with a default implemented in this module? return $output; } /** * edit properties form * @param type $object_id * @return string */ function islandora_edit_properties($object_id) { $object = islandora_object_load($object_id); if (isset($object)) { module_load_include('inc', 'islandora', 'includes/object_properties'); $form = drupal_get_form('islandora_edit_properties_form', $object); drupal_set_title($object->label); return drupal_render($form); } return ""; } /** * builds a default page for the edit tab * * @param object $fedora_object * A tuque Fedora Object */ function islandora_islandora_edit_object($fedora_object) { $supported_models = islandora_get_types(); $output = ""; foreach ($fedora_object->models as $model) { if (isset($supported_models[$model][ISLANDORA_EDIT_HOOK]) && $supported_models[$model][ISLANDORA_EDIT_HOOK] == TRUE) {//another module is handling the view return; } } $output = theme('islandora_default_edit', array('islandora_object' => $fedora_object)); return array('Default Edit output' => $output); } function islandora_view_default_object() { $pid = variable_get('islandora_repository_pid', 'islandora:root'); drupal_goto("islandora/object/$pid"); } /** * The view entry point. modules should implement hook_islandora_view_object for the Fedora Content models that * their modules want to provide a view for. * @global object $user * @param string $object_id * * @return string */ function islandora_view_object($fedora_object = NULL) { module_load_include('inc', 'islandora', 'includes/breadcrumb'); global $user; if (!$fedora_object) { return drupal_not_found(); } drupal_set_breadcrumb(islandora_get_breadcrumbs($fedora_object)); $page_number = (empty($_GET['page'])) ? '1' : $_GET['page']; $page_size = (empty($_GET['pagesize'])) ? '10' : $_GET['pagesize']; drupal_alter('islandora_object', $fedora_object); //modify object if required before it is passed along $arr = module_invoke_all('islandora_view_object', $fedora_object, $user, $page_number, $page_size); //allow submodules to decide how to handle content base on object type if (empty($arr)) { //TODO: make sure we iterate over the array as they will be more then one cmodel per object drupal_set_message(t('there was an error loading the view for islandora object %s', array('%s' => $object_id)), 'error'); return ""; } arsort($arr); drupal_alter('islandora_display', $arr); $output = ""; foreach ($arr as $key => $value) { $output .= $value; //if we have multiple modules handle one cmodel we need to iterate over multiple } return $output; } /** * The default view hook. If there are no modules registered to handle this objects cmodels or there are * not any cmodels specified this will create a default display. * * @param string $object_id * @return string */ function islandora_islandora_view_object($object) { $supported_models = islandora_get_types(); $output = ""; foreach ($object->models as $model) { if (isset($supported_models[$model][ISLANDORA_VIEW_HOOK]) && (boolean) $supported_models[$model][ISLANDORA_VIEW_HOOK] === TRUE) {//another module is handling the view return; } } $output = theme('islandora_default', array('islandora_object' => $object)); return array('Default Output' => $output); } /** * Implements hook_theme(). * * @return array */ function islandora_theme() { return array( 'islandora_default' => array( 'file' => 'theme/islandora.theme.inc', 'template' => 'theme/islandora-object', 'variables' => array('islandora_object' => NULL), ), 'islandora_default_edit' => array( 'file' => 'theme/islandora.theme.inc', 'template' => 'theme/islandora-object-edit', 'variables' => array('islandora_object' => NULL), ), ); } /** * Implements hook_permission(). * * @return array */ function islandora_permission() { return array( FEDORA_VIEW => array( 'title' => t('View repository objects and datastreams'), 'description' => t('View objects in the repository and their associated datastreams. Note: Fedora XACML security policies may override this permission.') ), FEDORA_ADD_DS => array( 'title' => t('Add datastreams to repository objects'), 'description' => t('Add datastreams to objects in the repository. Note: Fedora XACML security policies may override this position.') ), FEDORA_METADATA_EDIT => array( 'title' => t('Edit metadata'), 'description' => t('Edit metadata for objects in the repository.') ), FEDORA_INGEST => array( 'title' => t('Create new repository objects'), 'description' => t('Create new objects in the repository.') ), FEDORA_PURGE => array( 'title' => t('Permanently remove objects from the repository'), 'description' => t('Permanently remove objects from the repository.') ), FEDORA_MODIFY_STATE => array( 'title' => t('Change repository object states'), 'description' => t('Change the state of objects in the repository (e.g. from Active to Inactive).') ), FEDORA_MANAGE => array( 'title' => t('View object management tabs'), 'description' => t('View tabs that provide object management functions.') ) ); } /** * A helper function to get a connection and return an object * * @global object $user * @param string $object_id * @return FedoraObject */ function islandora_object_load($object_id) { module_load_include('inc', 'islandora', 'includes/tuque'); static $islandora_tuque = NULL; if (!$islandora_tuque) { $islandora_tuque = new IslandoraTuque(); } if (IslandoraTuque::exists()) { try { $fedora_object = $islandora_tuque->repository->getObject($object_id); } catch (Exception $e) { return NULL; } return $fedora_object; } else { IslandoraTuque::getError(); return NULL; } } /** * A helper function to get a connection and purge an object * * @global object $user * @param string $object_id * @return FedoraObject */ function islandora_object_purge($object_id) { if (!$object_id) { drupal_set_message(t('Cannot remove object, object id not set')); return; } // load object $object = islandora_object_load($object_id); if (!$object) { drupal_set_message(t('Could not remove object, object not found')); return; } $content_models = $object->models; $arr = module_invoke_all('islandora_pre_purge_object', $object); // notify modules of pending deletion if (isset($arr['delete']) && $arr['delete']) { try { $object->delete(); } catch (Exception $e) { drupal_set_message(t('Error deleting Islandora object %s %e', array('%s' => $object_id, '%e' => $e)), 'error'); return ""; } } else { try { $object->repository->purgeObject($object_id); } catch (Exception $e) { drupal_set_message(t('Error purging Islandora object %s %e', array('%s' => $object_id, '%e' => $e)), 'error'); return ""; } } module_invoke_all('islandora_post_purge_object', $object_id, $content_models); // notify modules post deletion } /** * Ingest access callback */ function islandora_ingest_access_callback($object, $perm) { if (islandora_access_callback($object, $perm) === FALSE) { return FALSE; } $ingest_registry = module_invoke_all('islandora_ingest_registry', $object); if (count($ingest_registry) > 0) { return TRUE; } else { return FALSE; } } /** * Content model, collection view and collection policy datastreams may now optionally define a version * number in their top-level XML element as an attribute, as in: * content); } elseif (!empty($datastream_file)) { $doc = simplexml_load_file($datastream_file); } if (!empty($doc) && $version = (int)$doc->attributes()->version) { $return = $version; } return $return; } /** * Implements hook_islandora_required_objects(). */ function islandora_islandora_required_objects() { // module path $module_path = drupal_get_path('module', 'islandora'); return array( 'islandora' => array( 'title' => 'Islandora', 'objects' => array( array( 'pid' => 'islandora:root', 'label' => 'Top-level collection', 'cmodel' => 'islandora:collectionCModel', 'datastreams' => array( array( 'dsid' => 'COLLECTION_POLICY', 'label' => 'Collection policy', 'mimetype' => 'text/xml', 'control_group' => 'X', 'datastream_file' => "$module_path/xml/islandora_collection_policy.xml", ), array( 'dsid' => 'TN', 'label' => 'Thumbnail', 'mimetype' => 'image/png', 'control_group' => 'M', 'datastream_file' => "$module_path/images/folder.png", ), ), ), ), ), ); }