mirror of
https://github.com/silverstripe/silverstripe-dms
synced 2024-10-22 12:05:56 +00:00
e4bc553521
* Add 2.0.0 changelog * Update DMSInterface and DMSDocumentInterface removing *page and adding getDocumentSetsByPage to DMSInterface * Update use documentation and update unit tests This commit changes the relationship from Pages has_many Documents to Pages has_many DocumentSets which are many_many to Documents. The upload field has been upated to attach documents to a set instead of a page, the tests updated and the DMSInterface and DMSDocumentInterface updated to be less relevant to pages and more relevant to document sets.
153 lines
5.5 KiB
PHP
153 lines
5.5 KiB
PHP
<?php
|
|
/**
|
|
* Interface for a DMSDocument used in the Document Management System. A DMSDocument is create by storing a File
|
|
* object in an instance of the DMSInterface. All write operations on the DMSDocument create a new relation, so we
|
|
* never need to explicitly call the write() method on the DMSDocument DataObject
|
|
*/
|
|
interface DMSDocumentInterface
|
|
{
|
|
/**
|
|
* Adds a metadata tag to the DMSDocument. The tag has a category and a value.
|
|
* Each category can have multiple values by default. So: addTag("fruit","banana") addTag("fruit", "apple") will
|
|
* add two items.
|
|
* However, if the third parameter $multiValue is set to 'false', then all updates to a category only ever update
|
|
* a single value. So:
|
|
* addTag("fruit","banana") addTag("fruit", "apple") would result in a single metadata tag: fruit->apple.
|
|
* Can could be implemented as a key/value store table (although it is more like category/value, because the
|
|
* same category can occur multiple times)
|
|
* @param $category String of a metadata category to add (required)
|
|
* @param $value String of a metadata value to add (required)
|
|
* @param bool $multiValue Boolean that determines if the category is multi-value or single-value (optional)
|
|
* @return null
|
|
*/
|
|
public function addTag($category, $value, $multiValue = true);
|
|
|
|
/**
|
|
* Fetches all tags associated with this DMSDocument within a given category. If a value is specified this method
|
|
* tries to fetch that specific tag.
|
|
* @param $category String of the metadata category to get
|
|
* @param null $value String of the value of the tag to get
|
|
* @return array of Strings of all the tags or null if there is no match found
|
|
*/
|
|
public function getTagsList($category, $value = null);
|
|
|
|
/**
|
|
* Removes a tag from the DMSDocument. If you only set a category, then all values in that category are deleted.
|
|
* If you specify both a category and a value, then only that single category/value pair is deleted.
|
|
* Nothing happens if the category or the value do not exist.
|
|
* @param $category Category to remove (required)
|
|
* @param null $value Value to remove (optional)
|
|
* @return null
|
|
*/
|
|
public function removeTag($category, $value = null);
|
|
|
|
/**
|
|
* Deletes all tags associated with this DMSDocument.
|
|
* @return null
|
|
*/
|
|
public function removeAllTags();
|
|
|
|
/**
|
|
* Returns a link to download this DMSDocument from the DMS store
|
|
* @return String
|
|
*/
|
|
public function getLink();
|
|
|
|
/**
|
|
* Return the extension of the file associated with the document
|
|
*/
|
|
public function getExtension();
|
|
|
|
/**
|
|
* Returns the size of the file type in an appropriate format.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getSize();
|
|
|
|
/**
|
|
* Return the size of the file associated with the document, in bytes.
|
|
*
|
|
* @return int
|
|
*/
|
|
public function getAbsoluteSize();
|
|
|
|
|
|
/**
|
|
* Takes a File object or a String (path to a file) and copies it into the DMS, replacing the original document file
|
|
* but keeping the rest of the document unchanged.
|
|
* @param $file File object, or String that is path to a file to store
|
|
* @return DMSDocumentInstance Document object that we replaced the file in
|
|
*/
|
|
public function replaceDocument($file);
|
|
|
|
/**
|
|
* Hides the DMSDocument, so it does not show up when getByPage($myPage) is called
|
|
* (without specifying the $showEmbargoed = true parameter). This is similar to expire, except that this method
|
|
* should be used to hide DMSDocuments that have not yet gone live.
|
|
* @return null
|
|
*/
|
|
public function embargoIndefinitely();
|
|
|
|
/**
|
|
* Returns if this is DMSDocument is embargoed or expired.
|
|
* @return bool True or False depending on whether this DMSDocument is embargoed or expired
|
|
*/
|
|
public function isHidden();
|
|
|
|
|
|
/**
|
|
* Returns if this is DMSDocument is embargoed.
|
|
* @return bool True or False depending on whether this DMSDocument is embargoed
|
|
*/
|
|
public function isEmbargoed();
|
|
|
|
/**
|
|
* Hides the DMSDocument, so it does not show up when getByPage($myPage) is called. Automatically un-hides the
|
|
* DMSDocument at a specific date.
|
|
* @param $datetime String date time value when this DMSDocument should expire
|
|
* @return null
|
|
*/
|
|
public function embargoUntilDate($datetime);
|
|
|
|
/**
|
|
* Hides the document until any page it is linked to is published
|
|
* @return null
|
|
*/
|
|
public function embargoUntilPublished();
|
|
|
|
/**
|
|
* Clears any previously set embargos, so the DMSDocument always shows up in all queries.
|
|
* @return null
|
|
*/
|
|
public function clearEmbargo();
|
|
|
|
/**
|
|
* Returns if this is DMSDocument is expired.
|
|
* @return bool True or False depending on whether this DMSDocument is expired
|
|
*/
|
|
public function isExpired();
|
|
|
|
/**
|
|
* Hides the DMSDocument at a specific date, so it does not show up when getByPage($myPage) is called.
|
|
* @param $datetime String date time value when this DMSDocument should expire
|
|
* @return null
|
|
*/
|
|
public function expireAtDate($datetime);
|
|
|
|
/**
|
|
* Clears any previously set expiry.
|
|
* @return null
|
|
*/
|
|
public function clearExpiry();
|
|
|
|
/*---- FROM HERE ON: optional API features ----*/
|
|
|
|
/**
|
|
* Returns a DataList of all previous Versions of this DMSDocument (check the LastEdited date of each
|
|
* object to find the correct one)
|
|
* @return DataList List of DMSDocument objects
|
|
*/
|
|
public function getVersions();
|
|
}
|