2012-07-16 03:06:35 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* When storing a document, the DMS sucks up the file and stores it separately from the assets section.
|
|
|
|
* When initializing the DMS, it should create some kind of storage system. For file-based storage, that could be
|
|
|
|
* a series of folders. Within the folders there are a number of files, keeping the same filename, but prefixed with
|
|
|
|
* an ID number, which corresponds to the document's ID. So "my-important-document" becomes:
|
|
|
|
* "/4000/4332~my-important-document" (folder structure to avoid storing too many files within one folder. Perhaps
|
|
|
|
* 10000 files per folder is a good amount)
|
|
|
|
*
|
|
|
|
*/
|
2015-12-17 19:48:37 +01:00
|
|
|
interface DMSInterface
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Factory method that returns an instance of the DMS. This could be any class that implements the DMSInterface.
|
|
|
|
* @static
|
|
|
|
* @abstract
|
|
|
|
* @return DMSInterface An instance of the Document Management System
|
|
|
|
*/
|
|
|
|
public static function inst();
|
2012-07-16 03:06:35 +02:00
|
|
|
|
2015-12-17 19:48:37 +01:00
|
|
|
/**
|
|
|
|
* Takes a File object or a String (path to a file) and copies it into the DMS. The original file remains unchanged.
|
|
|
|
* When storing a document, sets the fields on the File has "tag" metadata.
|
|
|
|
* @abstract
|
|
|
|
* @param $file File object, or String that is path to a file to store
|
|
|
|
* @return DMSDocumentInstance Document object that we just created
|
|
|
|
*/
|
|
|
|
public function storeDocument($file);
|
2012-07-16 03:06:35 +02:00
|
|
|
|
2015-12-17 19:48:37 +01:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Returns a number of Document objects based on the a search by tags. You can search by category alone,
|
2017-05-01 05:54:48 +02:00
|
|
|
* by tag value alone, or by both. I.e:
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* getByTag("fruits", null);
|
|
|
|
* getByTag(null, "banana");
|
|
|
|
* getByTag("fruits", "banana");
|
|
|
|
* </code>
|
2015-12-17 19:48:37 +01:00
|
|
|
* @abstract
|
|
|
|
* @param null $category The metadata category to search for
|
|
|
|
* @param null $value The metadata value to search for
|
|
|
|
* @param bool $showEmbargoed Boolean that specifies if embargoed documents should be included in results
|
|
|
|
* @return DMSDocumentInterface
|
|
|
|
*/
|
|
|
|
public function getByTag($category = null, $value = null, $showEmbargoed = false);
|
2012-07-16 03:06:35 +02:00
|
|
|
|
2015-12-17 19:48:37 +01:00
|
|
|
/**
|
|
|
|
* Returns a number of Document objects that match a full-text search of the Documents and their contents
|
|
|
|
* (if contents is searchable and compatible search module is installed - e.g. FullTextSearch module)
|
|
|
|
* @abstract
|
|
|
|
* @param $searchText String to search for
|
|
|
|
* @param bool $showEmbargoed Boolean that specifies if embargoed documents should be included in results
|
|
|
|
* @return DMSDocumentInterface
|
|
|
|
*/
|
|
|
|
public function getByFullTextSearch($searchText, $showEmbargoed = false);
|
2012-07-16 05:32:28 +02:00
|
|
|
|
|
|
|
|
2015-12-17 19:48:37 +01:00
|
|
|
/**
|
2017-05-02 04:49:41 +02:00
|
|
|
* Returns a list of Document objects associated with a Page via intermediary document sets
|
|
|
|
*
|
|
|
|
* @param SiteTree $page SiteTree to fetch the associated Documents from
|
|
|
|
* @param bool $showEmbargoed Boolean that specifies if embargoed documents should be included in results
|
|
|
|
* @return ArrayList Document list associated with the Page
|
|
|
|
*/
|
|
|
|
public function getByPage(SiteTree $page, $showEmbargoed = false);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of Document Set objects associated with a Page
|
|
|
|
*
|
|
|
|
* @param SiteTree $page SiteTree to fetch the associated Document Sets from
|
|
|
|
* @return ArrayList Document list associated with the Page
|
2015-12-17 19:48:37 +01:00
|
|
|
*/
|
2017-05-02 04:49:41 +02:00
|
|
|
public function getDocumentSetsByPage(SiteTree $page);
|
2015-12-17 19:48:37 +01:00
|
|
|
}
|