Difference between revisions of "API:EPrints/DataObj/File"
(8 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
<!-- Pod2Wiki=_preamble_ | <!-- Pod2Wiki=_preamble_ | ||
− | This page has been automatically generated from the EPrints 3. | + | This page has been automatically generated from the EPrints 3.4 source. Any wiki changes made between the 'Pod2Wiki=*' and 'Edit below this comment' comments will be lost. |
− | -->{{API}}{{Pod2Wiki}}{{API:Source|file=EPrints/DataObj/File.pm|package_name=EPrints::DataObj::File}}[[Category:API|FILE]][[Category:API:EPrints/DataObj | + | -->{{API}}{{Pod2Wiki}}{{API:Source|file=EPrints/DataObj/File.pm|package_name=EPrints::DataObj::File}}[[Category:API|FILE]][[Category:API:EPrints/DataObj|FILE]]<div><!-- Edit below this comment --> |
Line 17: | Line 17: | ||
<!-- Pod2Wiki=head_description --> | <!-- Pod2Wiki=head_description --> | ||
==DESCRIPTION== | ==DESCRIPTION== | ||
− | This class contains the technical metadata associated with a file. A file is a sequence of bytes stored in the storage layer (a "stored object"). Utility methods for storing and retrieving the stored object from the storage layer are made available. | + | This class contains the technical metadata associated with a file. A file is a sequence of bytes stored in the storage layer (a "stored object"). Utility methods for storing and retrieving the stored object from the storage layer are made available. |
− | Revision numbers on File work slightly differently to other objects. A File is only revised when it's stored object is changed and not when changes to it's metadata are made. | + | Revision numbers on File work slightly differently to other objects. A File is only revised when it's stored object is changed and not when changes to it's metadata are made. |
This class is a subclass of [[API:EPrints/DataObj/SubObject|EPrints::DataObj::SubObject]]. | This class is a subclass of [[API:EPrints/DataObj/SubObject|EPrints::DataObj::SubObject]]. | ||
Line 30: | Line 30: | ||
<!-- Pod2Wiki= --> | <!-- Pod2Wiki= --> | ||
</div> | </div> | ||
− | <!-- Pod2Wiki= | + | <!-- Pod2Wiki=head_core_metadata_fields --> |
− | ==CORE FIELDS== | + | ==CORE METADATA FIELDS== |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <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> | <span style='display:none'>User Comments</span> | ||
Line 40: | Line 40: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_fileid --> | <!-- Pod2Wiki=item_fileid --> | ||
− | ===fileid=== | + | ===fileid (counter)=== |
Unique identifier for this file. | Unique identifier for this file. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 64: | Line 52: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_datasetid --> | <!-- Pod2Wiki=item_datasetid --> | ||
− | ===datasetid=== | + | ===datasetid (id)=== |
Id of the dataset of the parent object. | Id of the dataset of the parent object. | ||
Line 76: | Line 64: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_objectid --> | <!-- Pod2Wiki=item_objectid --> | ||
− | ===objectid=== | + | ===objectid (int)=== |
Id of the parent object. | Id of the parent object. | ||
Line 88: | Line 76: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_filename --> | <!-- Pod2Wiki=item_filename --> | ||
− | ===filename=== | + | ===filename (id)=== |
Name of the file (may contain directory separators). | Name of the file (may contain directory separators). | ||
Line 100: | Line 88: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_mime_type --> | <!-- Pod2Wiki=item_mime_type --> | ||
− | ===mime_type=== | + | ===mime_type (id)=== |
MIME type of the file (e.g. "image/png"). | MIME type of the file (e.g. "image/png"). | ||
Line 112: | Line 100: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_hash --> | <!-- Pod2Wiki=item_hash --> | ||
− | ===hash=== | + | ===hash (id)=== |
Check sum of the file. | Check sum of the file. | ||
Line 124: | Line 112: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_hash_type --> | <!-- Pod2Wiki=item_hash_type --> | ||
− | ===hash_type=== | + | ===hash_type (id)=== |
Name of check sum algorithm used (e.g. "MD5"). | Name of check sum algorithm used (e.g. "MD5"). | ||
Line 136: | Line 124: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_filesize --> | <!-- Pod2Wiki=item_filesize --> | ||
− | ===filesize=== | + | ===filesize (bigint)=== |
Size of the file in bytes. | Size of the file in bytes. | ||
Line 148: | Line 136: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_mtime --> | <!-- Pod2Wiki=item_mtime --> | ||
− | ===mtime=== | + | ===mtime (timestamp)=== |
Last modification time of the file. | Last modification time of the file. | ||
Line 160: | Line 148: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_url --> | <!-- Pod2Wiki=item_url --> | ||
− | ===url=== | + | ===url (url)=== |
Virtual field for storing the file's URL. | Virtual field for storing the file's URL. | ||
Line 172: | Line 160: | ||
</div> | </div> | ||
<!-- Pod2Wiki=item_data --> | <!-- Pod2Wiki=item_data --> | ||
− | ===data=== | + | ===data (base64)=== |
Virtual field for storing the file's content. | Virtual field for storing the file's content. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=head_references_and_related_objects --> | ||
+ | ==REFERENCES AND RELATED OBJECTS== | ||
+ | None. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=head_instances_variables --> | ||
+ | ==INSTANCES VARIABLES== | ||
+ | See [[API:EPrints/DataObj#INSTANCE_VARIABLES|EPrints::DataObj]]. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 205: | Line 215: | ||
$dataobj = EPrints::DataObj::File->new_from_filename( $session, $dataobj, $filename ) | $dataobj = EPrints::DataObj::File->new_from_filename( $session, $dataobj, $filename ) | ||
− | Convenience method to | + | Convenience method to return an existing file object for <tt>$filename</tt> stored in <tt>$dataobj</tt>. |
− | Returns undef if no such record exists. | + | Returns <tt>undef</tt> if no such record exists. |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 219: | Line 229: | ||
====create_from_data==== | ====create_from_data==== | ||
− | $dataobj = EPrints::DataObj::File->create_from_data( $session, $data | + | $dataobj = EPrints::DataObj::File->create_from_data( $session, $data, $dataset ) |
− | + | Returns a new file record using <tt>$data</tt> and the file <tt>$dataset</tt>. | |
+ | |||
+ | Private data elements: | ||
+ | _content - content to pass to [[API:EPrints/DataObj/File#set_file|set_file]]. | ||
+ | _filepath - path to source file used for improved mime-type detection | ||
+ | |||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <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> | <span style='display:none'>User Comments</span> | ||
Line 241: | Line 256: | ||
====get_system_field_info==== | ====get_system_field_info==== | ||
− | $ | + | $fields = EPrints::DataObj::File->get_system_field_info |
− | + | Returns an array describing the system metadata fields of the file dataset. | |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 255: | Line 270: | ||
$dataset = EPrints::DataObj::File->get_dataset_id | $dataset = EPrints::DataObj::File->get_dataset_id | ||
− | Returns the | + | Returns the ID of the [[API:EPrints/DataSet|EPrints::DataSet]] object to which this record belongs. |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 290: | Line 292: | ||
$new_file = $file->clone( $parent ) | $new_file = $file->clone( $parent ) | ||
− | Clone the | + | Clone the file object (including contained files) and return the new object. Uses <tt>$parent</tt> to set the <tt>objectid</tt> of the cloned file data object, in case this needs to be different to the original. |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 303: | Line 305: | ||
$success = $file->remove | $success = $file->remove | ||
− | Delete the | + | Delete the file data object and the file it stores. |
+ | |||
+ | Returns boolean depending on the success of removing this file. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_update --> | ||
+ | ====update==== | ||
+ | |||
+ | $file->update( $epdata ) | ||
+ | Updates the metadata for the file with <tt>$epdata</tt>. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 315: | Line 332: | ||
====get_local_copy==== | ====get_local_copy==== | ||
− | $filename = $file->get_local_copy() | + | $filename = $file->get_local_copy |
− | + | Returns the name of a local copy of the file (may be a {{API:PodLink|file=File/Temp|package_name=File::Temp|section=|text=File::Temp}} object). | |
+ | |||
+ | Uses [[API:EPrints/Storage#get_local_copy|EPrints::Storage#get_local_copy]] which in turn calls the configured local storage 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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_get_remote_copy --> | ||
+ | ====get_remote_copy==== | ||
+ | |||
+ | $filename = $file->get_remote_copy | ||
+ | Returns the name of a remote copy of the file (may be a {{API:PodLink|file=File/Temp|package_name=File::Temp|section=|text=File::Temp}} object). | ||
− | + | Uses [[API:EPrints/Storage#get_local_copy|EPrints::Storage#get_local_copy]] which in turn calls the configured remote storage plugin. | |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 331: | Line 363: | ||
$success = $file->add_file( $filepath, $filename [, $preserve_path ] ) | $success = $file->add_file( $filepath, $filename [, $preserve_path ] ) | ||
− | + | Reads and stores the contents of <tt>$filepath</tt> at <tt>$filename</tt>. | |
− | If $preserve_path is | + | If <tt>$preserve_path</tt> is not <tt>true</tt> will strip any leading path in <tt>$filename</tt>. |
+ | |||
+ | Returns a boolean depending on the success of adding the file. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 346: | Line 380: | ||
$bytes = $file->upload( $filehandle, $filename, $filesize [, $preserve_path ] ) | $bytes = $file->upload( $filehandle, $filename, $filesize [, $preserve_path ] ) | ||
− | + | Reads and stores the data from <tt>$filehandle</tt> at <tt>$filename</tt> at the next revision number. | |
− | If $preserve_path is | + | If <tt>$preserve_path</tt> is not <tt>true</tt> will strip any leading path in <tt>$filename</tt>. |
Returns the number of bytes read from $filehandle or undef on failure. | Returns the number of bytes read from $filehandle or undef on failure. | ||
Line 362: | Line 396: | ||
====write_copy==== | ====write_copy==== | ||
− | $success = $ | + | $success = $file->write_copy( $filename ) |
− | Write a copy of this file to $filename. | + | Write a copy of this file to <tt>$filename</tt>. |
− | Returns true if the written file contains the same number of bytes as the stored file. | + | Returns <tt>true</tt> if the written file contains the same number of bytes as the stored file. |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 377: | Line 411: | ||
====write_copy_fh==== | ====write_copy_fh==== | ||
− | $success = $ | + | $success = $file->write_copy_fh( $filehandle ) |
− | Write a copy of this file to $filehandle. | + | Write a copy of this file to <tt>$filehandle</tt>. |
+ | |||
+ | Returns boolean depending on success of writing copy of file to the 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%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 390: | Line 426: | ||
====generate_md5==== | ====generate_md5==== | ||
− | $md5 = $ | + | $md5 = $file->generate_md5 |
Calculates and returns the MD5 for this file. | Calculates and returns the MD5 for this file. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_update_md5 --> | ||
+ | ====update_md5==== | ||
+ | |||
+ | $md5 = $file->update_md5 | ||
+ | Generates MD5 and sets <tt>hash</tt> and <tt>has_type</tt> (as <tt>MD5</tt>) for this file data object. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 403: | Line 452: | ||
====generate_sha==== | ====generate_sha==== | ||
− | $digest = $file->generate_sha( [ | + | $digest = $file->generate_sha( [ $alg ] ) |
− | + | Generates a SHA for this file, see {{API:PodLink|file=Digest/SHA|package_name=Digest::SHA|section=|text=Digest::SHA}} for a list of supported algorithms. Defaults to <tt>256</tt> (SHA-256) if <tt>$alg</tt> is not set. | |
Returns the hex-encoded digest. | Returns the hex-encoded digest. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_update_sha --> | ||
+ | ====update_sha==== | ||
+ | |||
+ | $md5 = $file->update_sha | ||
+ | Generates a SHA for this file, see {{API:PodLink|file=Digest/SHA|package_name=Digest::SHA|section=|text=Digest::SHA}} for a list of supported algorithms. Defaults to <tt>256</tt> (SHA-256) if <tt>$alg</tt> is not set. Then sets the <tt>hash</tt> and c<has_type> for this file data object. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_to_sax --> | ||
+ | ====to_sax==== | ||
+ | |||
+ | $file->to_sax( %opts ) | ||
+ | Generate SAX output for file data object and assign to <tt>Output</tt> of <tt>Handler</tt> specified in <tt>%opts</tt>. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 418: | Line 493: | ||
====add_plugin_copy==== | ====add_plugin_copy==== | ||
− | $ | + | $file->add_plugin_copy( $plugin, $sourceid ) |
− | Add a copy of this file stored using $plugin identified by $sourceid. | + | Add a copy of this file stored using <tt>$plugin</tt> identified by <tt>$sourceid</tt>. |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 431: | Line 506: | ||
====remove_plugin_copy==== | ====remove_plugin_copy==== | ||
− | $ | + | $file->remove_plugin_copy( $plugin ) |
− | Remove the copy of this file stored using $plugin. | + | Remove the copy of this file stored using <tt>$plugin</tt>. |
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 444: | Line 519: | ||
====get_file==== | ====get_file==== | ||
− | $success = $ | + | $success = $file->get_file( $f, [ $offset, $n ] ) |
− | Get the contents of the stored file | + | Get the contents of the stored file. |
+ | |||
+ | <tt>$offset</tt> is the position in bytes to start reading from, defaults to 0. | ||
− | $ | + | <tt>$n</tt> is the number of bytes to read, defaults to <tt>filesize</tt>. |
− | + | <tt>$f</tt> is: | |
+ | |||
+ | sub { | ||
+ | my( $buffer ) = @_; | ||
+ | ... | ||
+ | return 1; | ||
+ | } | ||
+ | |||
+ | Returns boolean dependent on whether file was successfully retrieved. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 461: | Line 546: | ||
====set_file==== | ====set_file==== | ||
− | $content_length = $ | + | $content_length = $file->set_file( $content, $clen ) |
− | + | Write <tt>$clen</tt> bytes from <tt>$content</tt> to the file object. Updates <tt>filesize</tt> and <tt>hash</tt>. You must then call [[API:EPrints/DataObj/File#commit|commit]]) to save these changes. | |
− | + | Returns an integer for the content length or <tt>undef</tt> on failure. | |
− | + | <tt>$content</tt> may be one of: | |
− | + | CODEREF - Will be called until it returns empty string (""). | |
− | + | SCALARREF - A scalar reference to a string of octets that will be written as-is. | |
− | + | GLOB - Will be treated as a file handle and read with sysread(). | |
− | + | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_set_file_chunk --> | ||
+ | ====set_file_chunk==== | ||
+ | |||
+ | $content_length = $file->set_file_chunk( $content, $clen, $offset, $total ) | ||
+ | Write a chunk of data to the content, overwriting or appending to the existing content. See [[API:EPrints/DataObj/File#set_file|set_file]] for <tt>$content</tt> and <tt>$clen</tt>. <tt>filesize</tt> is updated if <tt>$offset + $content_length</tt> is greater than the current <tt>filesize</tt>. | ||
+ | |||
+ | <tt>$offset</tt> is the starting point (in bytes) to write. <tt>$total</tt> is the total size of the file, used to determine where to store the content. | ||
+ | |||
+ | Returns the number of bytes written or <tt>undef</tt> on failure. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_start_element --> | ||
+ | ====start_element==== | ||
+ | |||
+ | $file->start_element( $data, $epdata, $state ) | ||
+ | Consumes a SAX event. See <EPrints::DataObj#start_element> for more information. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_end_element --> | ||
+ | ====end_element==== | ||
+ | |||
+ | $file->end_element( $data, $epdata, $state ) | ||
+ | Ends element from [[API:EPrints/DataObj/File#start_element|start_element]]. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_characters --> | ||
+ | ====characters==== | ||
+ | |||
+ | $file->characters( $data, $epdata, $state ) | ||
+ | Consumes characters within [[API:EPrints/DataObj/File#start_element|start_element]]. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_render_filesize --> | ||
+ | ====render_filesize==== | ||
+ | |||
+ | EPrints::DataObj::File->render_filesize( $repo, $field, $value ) | ||
+ | Returns an XHTML DOM fragment, which is either empty if <tt>$value</tt> is not set or a human-readable rendering of this file size. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_get_url --> | ||
+ | ====get_url==== | ||
+ | |||
+ | $file->get_url | ||
+ | Returns the URL from which this file can be downloaded. | ||
+ | |||
+ | Calls [[API:EPrints/DataObj/Document#get_url|EPrints::DataObj::Document#get_url]] on the parent object for this file with the <tt>filename</tt> as a parameter. | ||
+ | |||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=item_path --> | ||
+ | ====path==== | ||
+ | |||
+ | $file->path | ||
+ | Returns the filesystem path for this file. | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | ||
Line 485: | Line 665: | ||
[[API:EPrints/DataObj|EPrints::DataObj]] and [[API:EPrints/DataSet|EPrints::DataSet]]. | [[API:EPrints/DataObj|EPrints::DataObj]] and [[API:EPrints/DataSet|EPrints::DataSet]]. | ||
+ | <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 --> | ||
+ | |||
+ | |||
+ | <!-- Pod2Wiki= --> | ||
+ | </div> | ||
+ | <!-- Pod2Wiki=head_copyright --> | ||
+ | ==COPYRIGHT== | ||
+ | {{API:Copyright}} | ||
<div style='background-color: #e8e8f; margin: 0.5em 0em 1em 0em; border: solid 1px #cce; padding: 0em 1em 0em 1em; font-size: 80%; '> | <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> | <span style='display:none'>User Comments</span> |
Latest revision as of 10:51, 10 January 2022
EPrints 3 Reference: Directory Structure - Metadata Fields - Repository Configuration - XML Config Files - XML Export Format - EPrints data structure - Core API - Data Objects
Latest Source Code (3.4, 3.3) | Revision Log | Before editing this page please read Pod2Wiki
Contents
- 1 NAME
- 2 DESCRIPTION
- 3 CORE METADATA FIELDS
- 4 REFERENCES AND RELATED OBJECTS
- 5 INSTANCES VARIABLES
- 6 METHODS
- 6.1 Constructor Methods
- 6.2 Class Methods
- 6.3 Object Methods
- 6.3.1 clone
- 6.3.2 remove
- 6.3.3 update
- 6.3.4 get_local_copy
- 6.3.5 get_remote_copy
- 6.3.6 add_file
- 6.3.7 upload
- 6.3.8 write_copy
- 6.3.9 write_copy_fh
- 6.3.10 generate_md5
- 6.3.11 update_md5
- 6.3.12 generate_sha
- 6.3.13 update_sha
- 6.3.14 to_sax
- 6.3.15 add_plugin_copy
- 6.3.16 remove_plugin_copy
- 6.3.17 get_file
- 6.3.18 set_file
- 6.3.19 set_file_chunk
- 6.3.20 start_element
- 6.3.21 end_element
- 6.3.22 characters
- 6.3.23 render_filesize
- 6.3.24 get_url
- 6.3.25 path
- 7 SEE ALSO
- 8 COPYRIGHT
NAME
EPrints::DataObj::File - a stored file
DESCRIPTION
This class contains the technical metadata associated with a file. A file is a sequence of bytes stored in the storage layer (a "stored object"). Utility methods for storing and retrieving the stored object from the storage layer are made available.
Revision numbers on File work slightly differently to other objects. A File is only revised when it's stored object is changed and not when changes to it's metadata are made.
This class is a subclass of EPrints::DataObj::SubObject.
CORE METADATA FIELDS
fileid (counter)
Unique identifier for this file.
datasetid (id)
Id of the dataset of the parent object.
objectid (int)
Id of the parent object.
filename (id)
Name of the file (may contain directory separators).
mime_type (id)
MIME type of the file (e.g. "image/png").
hash (id)
Check sum of the file.
hash_type (id)
Name of check sum algorithm used (e.g. "MD5").
filesize (bigint)
Size of the file in bytes.
mtime (timestamp)
Last modification time of the file.
url (url)
Virtual field for storing the file's URL.
data (base64)
Virtual field for storing the file's content.
REFERENCES AND RELATED OBJECTS
None.
INSTANCES VARIABLES
See EPrints::DataObj.
METHODS
Constructor Methods
new_from_filename
$dataobj = EPrints::DataObj::File->new_from_filename( $session, $dataobj, $filename )
Convenience method to return an existing file object for $filename stored in $dataobj.
Returns undef if no such record exists.
create_from_data
$dataobj = EPrints::DataObj::File->create_from_data( $session, $data, $dataset )
Returns a new file record using $data and the file $dataset.
Private data elements:
_content - content to pass to set_file. _filepath - path to source file used for improved mime-type detection
Class Methods
get_system_field_info
$fields = EPrints::DataObj::File->get_system_field_info
Returns an array describing the system metadata fields of the file dataset.
get_dataset_id
$dataset = EPrints::DataObj::File->get_dataset_id
Returns the ID of the EPrints::DataSet object to which this record belongs.
Object Methods
clone
$new_file = $file->clone( $parent )
Clone the file object (including contained files) and return the new object. Uses $parent to set the objectid of the cloned file data object, in case this needs to be different to the original.
remove
$success = $file->remove
Delete the file data object and the file it stores.
Returns boolean depending on the success of removing this file.
update
$file->update( $epdata )
Updates the metadata for the file with $epdata.
get_local_copy
$filename = $file->get_local_copy
Returns the name of a local copy of the file (may be a File::Temp object).
Uses EPrints::Storage#get_local_copy which in turn calls the configured local storage plugin.
get_remote_copy
$filename = $file->get_remote_copy
Returns the name of a remote copy of the file (may be a File::Temp object).
Uses EPrints::Storage#get_local_copy which in turn calls the configured remote storage plugin.
add_file
$success = $file->add_file( $filepath, $filename [, $preserve_path ] )
Reads and stores the contents of $filepath at $filename.
If $preserve_path is not true will strip any leading path in $filename.
Returns a boolean depending on the success of adding the file.
upload
$bytes = $file->upload( $filehandle, $filename, $filesize [, $preserve_path ] )
Reads and stores the data from $filehandle at $filename at the next revision number.
If $preserve_path is not true will strip any leading path in $filename.
Returns the number of bytes read from $filehandle or undef on failure.
write_copy
$success = $file->write_copy( $filename )
Write a copy of this file to $filename.
Returns true if the written file contains the same number of bytes as the stored file.
write_copy_fh
$success = $file->write_copy_fh( $filehandle )
Write a copy of this file to $filehandle.
Returns boolean depending on success of writing copy of file to the file handle.
generate_md5
$md5 = $file->generate_md5
Calculates and returns the MD5 for this file.
update_md5
$md5 = $file->update_md5
Generates MD5 and sets hash and has_type (as MD5) for this file data object.
generate_sha
$digest = $file->generate_sha( [ $alg ] )
Generates a SHA for this file, see Digest::SHA for a list of supported algorithms. Defaults to 256 (SHA-256) if $alg is not set.
Returns the hex-encoded digest.
update_sha
$md5 = $file->update_sha
Generates a SHA for this file, see Digest::SHA for a list of supported algorithms. Defaults to 256 (SHA-256) if $alg is not set. Then sets the hash and c<has_type> for this file data object.
to_sax
$file->to_sax( %opts )
Generate SAX output for file data object and assign to Output of Handler specified in %opts.
add_plugin_copy
$file->add_plugin_copy( $plugin, $sourceid )
Add a copy of this file stored using $plugin identified by $sourceid.
remove_plugin_copy
$file->remove_plugin_copy( $plugin )
Remove the copy of this file stored using $plugin.
get_file
$success = $file->get_file( $f, [ $offset, $n ] )
Get the contents of the stored file.
$offset is the position in bytes to start reading from, defaults to 0.
$n is the number of bytes to read, defaults to filesize.
$f is:
sub { my( $buffer ) = @_; ... return 1; }
Returns boolean dependent on whether file was successfully retrieved.
set_file
$content_length = $file->set_file( $content, $clen )
Write $clen bytes from $content to the file object. Updates filesize and hash. You must then call commit) to save these changes.
Returns an integer for the content length or undef on failure.
$content may be one of:
CODEREF - Will be called until it returns empty string (""). SCALARREF - A scalar reference to a string of octets that will be written as-is. GLOB - Will be treated as a file handle and read with sysread().
set_file_chunk
$content_length = $file->set_file_chunk( $content, $clen, $offset, $total )
Write a chunk of data to the content, overwriting or appending to the existing content. See set_file for $content and $clen. filesize is updated if $offset + $content_length is greater than the current filesize.
$offset is the starting point (in bytes) to write. $total is the total size of the file, used to determine where to store the content.
Returns the number of bytes written or undef on failure.
start_element
$file->start_element( $data, $epdata, $state )
Consumes a SAX event. See <EPrints::DataObj#start_element> for more information.
end_element
$file->end_element( $data, $epdata, $state )
Ends element from start_element.
characters
$file->characters( $data, $epdata, $state )
Consumes characters within start_element.
render_filesize
EPrints::DataObj::File->render_filesize( $repo, $field, $value )
Returns an XHTML DOM fragment, which is either empty if $value is not set or a human-readable rendering of this file size.
get_url
$file->get_url
Returns the URL from which this file can be downloaded.
Calls EPrints::DataObj::Document#get_url on the parent object for this file with the filename as a parameter.
path
$file->path
Returns the filesystem path for this file.
SEE ALSO
EPrints::DataObj and EPrints::DataSet.
COPYRIGHT
© Copyright 2000-2024 University of Southampton.
EPrints 3.4 is supplied by EPrints Services.
http://www.eprints.org/eprints-3.4/
LICENSE
This file is part of EPrints 3.4 http://www.eprints.org/.
EPrints 3.4 and this file are released under the terms of the GNU Lesser General Public License version 3 as published by the Free Software Foundation unless otherwise stated.
EPrints 3.4 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with EPrints 3.4. If not, see http://www.gnu.org/licenses/.