|  |   | 
| Line 1: | Line 1: | 
| − | <!-- Pod2Wiki=_preamble_ 
 |  | 
| − | This page has been automatically generated from the EPrints 3.2 source. Any wiki changes made between the 'Pod2Wiki=*' and 'Edit below this comment' comments will be lost.
 |  | 
| − |  -->{{API}}{{Pod2Wiki}}{{API:Source|file=EPrints/Storage.pm|package_name=EPrints::Storage}}[[Category:API|Storage]]<div><!-- Edit below this comment -->
 |  | 
|  |  |  |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki=_private_ -->{{API:Unstable}}<!-- Pod2Wiki=head_name -->
 |  | 
| − | ==NAME==
 |  | 
| − | '''EPrints::Storage''' - store and retrieve objects in the storage engine
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=_private_ -->This should be inserted verbatum into the Wiki page.
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki=head_synopsis -->
 |  | 
| − | ==SYNOPSIS==
 |  | 
| − |   my $store = $repository->storage();
 |  | 
| − |   
 |  | 
| − |   $store->store(
 |  | 
| − |     $fileobj,    # file object
 |  | 
| − |     "diddle.pdf",  # filename
 |  | 
| − |     $fh        # file handle
 |  | 
| − |   );
 |  | 
| − |   
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=head_description -->
 |  | 
| − | ==DESCRIPTION==
 |  | 
| − | This module is the storage control layer which uses [[API:EPrints/Plugin/Storage|EPrints::Plugin::Storage]] plugins to support various storage back-ends. It enables the storage, retrieval and deletion of data streams. The maximum size of a stream is dependent on the back-end storage mechanism.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=head_methods -->
 |  | 
| − | ==METHODS==
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_new -->
 |  | 
| − | ===$store = EPrints::Storage->new( $repository )===
 |  | 
| − | 
 |  | 
| − | Create a new storage object for $repository. Should not be used directly, see [[API:EPrints/Session|EPrints::Session]].
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_store -->
 |  | 
| − | ===$len = $store->store( $fileobj, CODEREF )===
 |  | 
| − | 
 |  | 
| − | Read from and store all data from CODEREF for $fileobj. The '''filesize''' field in $fileobj must be set at the expected number of bytes to read from CODEREF.
 |  | 
| − | 
 |  | 
| − | Returns undef if the file couldn't be stored, otherwise the number of bytes read.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_retrieve -->
 |  | 
| − | ===$success = $store->retrieve( $fileobj, CALLBACK )===
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_delete -->
 |  | 
| − | ===$success = $store->delete( $fileobj )===
 |  | 
| − | 
 |  | 
| − | Delete all object copies stored for $fileobj.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_delete_copy -->
 |  | 
| − | ===$ok = $store->delete_copy( $plugin, $fileobj )===
 |  | 
| − | 
 |  | 
| − | Delete the copy of this file stored in $plugin.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_get_local_copy -->
 |  | 
| − | ===$filename = $store->get_local_copy( $fileobj )===
 |  | 
| − | 
 |  | 
| − | Return the name of a local copy of the file.
 |  | 
| − | 
 |  | 
| − | Will retrieve and cache the remote object using {{API:PodLink|file=File/Temp|package_name=File::Temp|section=|text=File::Temp}} if necessary.
 |  | 
| − | 
 |  | 
| − | Returns undef if retrieval failed.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_get_remote_copy -->
 |  | 
| − | ===$url = $store->get_remote_copy( $fileobj )===
 |  | 
| − | 
 |  | 
| − | Returns a URL from which this file can be accessed.
 |  | 
| − | 
 |  | 
| − | Returns undef if this file is not available via another service.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_get_plugins -->
 |  | 
| − | ===@plugins = $store->get_plugins( $fileobj )===
 |  | 
| − | 
 |  | 
| − | Returns the [[API:EPrints/Plugin/Storage|EPrints::Plugin::Storage]] plugin(s) to use for $fileobj. If more than one plugin is returned they should be used in turn until one succeeds.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_copy -->
 |  | 
| − | ===$ok = $store->copy( $plugin, $fileobj )===
 |  | 
| − | 
 |  | 
| − | Copy the contents of $fileobj into another storage $plugin.
 |  | 
| − | 
 |  | 
| − | Returns 1 on success, 0 on failure and -1 if a copy already exists in $plugin.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_open_write -->
 |  | 
| − | ===$ok = $storage->open_write( $fileobj )===
 |  | 
| − | 
 |  | 
| − | Start a write session for $fileobj. $fileobj must have at least the "filesize" property set (which is the number of bytes that will be written).
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_write -->
 |  | 
| − | ===$ok = $storage->write( $fileobj, $buffer )===
 |  | 
| − | 
 |  | 
| − | Write $buffer to the storage plugin(s).
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=item_close_write -->
 |  | 
| − | ===$ok = $storage->close_write( $fileobj );===
 |  | 
| − | 
 |  | 
| − | Finish writing to the storage plugin(s) for $fileobj.
 |  | 
| − | 
 |  | 
| − | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce;  padding: 0em 1em 0em 1em; font-size: 80%; '>
 |  | 
| − | <span style='display:none'>User Comments</span>
 |  | 
| − | <!-- Edit below this comment -->
 |  | 
| − | 
 |  | 
| − | 
 |  | 
| − | </div>
 |  | 
| − | 
 |  | 
| − | <!-- Pod2Wiki= -->
 |  | 
| − | </div>
 |  | 
| − | <!-- Pod2Wiki=_postamble_ --><!-- Edit below this comment -->
 |  |