NAME

WebService::Cmis::Repository - Representation of a cmis repository

DESCRIPTION

After fetching a WebService::Cmis::Client object, fetching the repository is the next thing to do in most cases using "getRepository" in WebService::Cmis::Client.

my $repo = WebService::Cmis::getClient->getRepository('repositoryId');

METHODS

new($client, $xmlDoc)

Create a new repository object using the given $client and loading the information stored in the $xmlDoc.

getClient() -> WebService::Cmis::Client

returns the the client object used to communicate with the repository.

toString()

return a string representation of this repository

reload()

This method will re-fetch the repository's XML data from the CMIS repository.

getRepositoryId()

returns this repository's ID

getRepositoryName()

returns this repository's name

getRepositoryInfo() -> %info

returns this repository's info record

See CMIS specification document 2.2.2.2 getRepositoryInfo

getCapabilities() -> %caps

returns this repository's capabilities

getSupportedPermissions() -> $permissions

returns this repository's supported permissions. values are:

basic: indicates that the CMIS Basic permissions are supported
repository: indicates that repository specific permissions are supported
both: indicates that both CMIS basic permissions and repository specific permissions are supported
getPropagation() -> $string

returns the value of the cmis:propagation element. Valid values are:

objectonly: indicates that the repository is able to apply ACEs
  without changing the ACLs of other objects

propagate: indicates that the repository is able to apply ACEs to a
  given object and propagate this change to all inheriting objects
getPermissionDefinitions() -> %permDefs

Returns a hash of permission definitions for this repository. The key is the permission string or technical name of the permission and the value is the permission description.

getPermissionMap() -> %permMap

returns a hash representing the permission mapping table where each key is a permission key string and each value is a list of one or more permissions the principal must have to perform the operation.

getUriTemplates() -> %templates

returns a hash of URI templates the repository service knows about.

getUriTemplate($type) -> $template

returns an uri template for the given type

getRootFolder() -> $folder

returns the root folder of the repository

getFolder($id) -> $foldeer

returns the a folder object of the given id

getCollection($collectionType, %args) -> $atomFeed

returns a AtomFeed of objects returned for the specified collection.

If the query collection is requested, an exception will be throwd. That collection isn't meant to be retrieved.

getTypeDefinition($typeId) -> $objectType

returns an ObjectType object for the specified object type id.

See CMIS specification document 2.2.2.5 getTypeDefinition

folderType = repo.getTypeDefinition('cmis:folder')

getCollectionLink($collectionType) -> $href

returns the link HREF from the specified collectionType (CHECKED_OUT_COLL, for example).

getLink($relation) -> $href

returns the HREF attribute of an Atom link element for the specified rel.

getObjectByPath($path, %params) -> $cmisObj

returns an object given the path to the object.

my $doc = $repo->getObjectByPath("/User homes/jeff/sample.pdf");
my $title = $doc->getTitle();

These optional arguments are supported:

filter: See section 2.2.1.2.1 Properties.
includeAllowableActions: See section 2.2.1.2.6 Allowable Actions.
includeRelationships: See section 2.2.1.2.2 Relationships.
renditionFilter: See section 2.2.1.2.4 Renditions.
includePolicyIds: See section 2.2.1.2.2 Relationships.
includeACL: See section 2.2.1.2.5 ACLs.

See CMIS specification document 2.2.4.9 getObjectByPath

getObject($id, %params) -> $cmisObj

returns an object given the specified object ID.

See CMIS specification document 2.2.4.7 getObject

getCheckedOutDocs(%params) -> $atomFeed

returns a result set of cmis objects that are currently checked out.

See CMIS specification document 2.2.3.6 getCheckedOutDocs

These optional arguments are supported:

folderId
maxItems
skipCount
orderBy
filter
includeRelationships
renditionFilter
includeAllowableActions
getUnfiledDocs(%params):

returns a AtomFeed of cmis objects that are currently unfiled.

These optional arguments are supported:

folderId
maxItems
skipCount
orderBy
filter
includeRelationships
renditionFilter
includeAllowableActions
getTypeDefinitions(%params) -> $atomFeed

returns a AtomFeed of ObjectTypes holding the base types in the repository.

Use the normal paging options.

createEmptyXmlDoc

static helper method that knows how to build an empty Atom entry.

createEntryXmlDoc( summary=>$summary folder=>$parentFolder, properties=>$propsList, contentFile=>$filename, contentData=>$data, contentType=>$type ) -> $atomEntry

helper method that knows how to build an Atom entry based on the properties and, optionally, the contentFile provided.

createObject($parentFolder, properties => $propertyList, %params);

creates a new CMIS Objec in the given folder using the properties provided.

To specify a custom object type, pass in a Property for cmis:objectTypeId representing the type ID of the instance you want to create. If you do not pass in an object type ID, an instance of 'cmis:document' will be created.

getTypeChildren($typeId, %params) -> $atomFeed

returns a result set ObjectType objects corresponding to the child types of the type specified by the typeId.

If no typeId is provided, the result will be the same as calling getTypeDefinitions

See CMIS specification document 2.2.2.3 getTypeChildren

These optional arguments are current supported:

includePropertyDefinitions
maxItems
skipCount
getTypeDescendants($typeId, %params) -> $atomFeed

Returns a result set ObjectType objects corresponding to the descendant types of the type specified by the typeId.

If no typeId is provided, the repository's "typesdescendants" URL will be called to determine the list of descendant types.

See CMIS specification document 2.2.2.4 getTypeDescendants

These optional arguments are supported:

depth
includePropertyDefinitions
query(statement, %params):

Returns a result set of CMIS Objects based on the CMIS Query Language passed in as the statement. The actual objects returned will be instances of the appropriate child class based on the object's base type ID.

In order for the results to be properly instantiated as objects, make sure you include 'cmis:objectId' as one of the fields in your select statement, or just use "SELECT \*".

If you want the search results to automatically be instantiated with the appropriate sub-class of CMIS Object you must either include cmis:baseTypeId as one of the fields in your select statement or just use "SELECT \*".

See CMIS specification document 2.2.6.1 query

The following optional arguments are supported:

searchAllVersions
includeRelationships
renditionFilter
includeAllowableActions
maxItems
skipCount
getContentChanges(%params) -> $atomFeed

returns a AtomFeed containing ChangeEntry objects.

See CMIS specification document 2.2.6.2 getContentChanges

The following optional arguments are supported:

changeLogToken
includeProperties
includePolicyIDs
includeACL
maxItems

You can get the latest change log token by inspecting the repository info via Repository.getRepositoryInfo.

createDocument( $name, folder=>$parentFolder, properties=>$propsList, contentFile=>$filename, contentData=>$data, contentType=>$type, ) -> $cmisDocument

creates a new Document object in the parent folder provided or filed to the Unfiled collection of the repository.

The method will attempt to guess the appropriate content type and encoding based on the file. To specify it yourself, pass them in via the contentType and

To specify a custom object type, pass in a Property for cmis:objectTypeId representing the type ID of the instance you want to create. If you do not pass in an object type ID, an instance of 'cmis:document' will be created.

createFolder($name, folder=>$parentFolder, properties=>$propertyList, %params) -> $cmisFolder

creates a new CMIS Folder using the properties provided.

To specify a custom folder type, pass in a property called cmis:objectTypeId representing the type ID of the instance you want to create. If you do not pass in an object type ID, an instance of 'cmis:folder' will be created.

my $rootFolder = $repo->getRootFolder;

my $subFolder = $rootFolder->createFolder(
  'My new folder', 
  summary => "This is my new test folder."
);

my $repo = $repo->createFolder(
  'My other folder', 
  folder => $rootFolder,
  summary => "This is my other test folder."
);

See CMIS specification document 2.2.4.3 createFolder

createRelationship

TODO: This is not yet implemented.

createPolicy

TODO: This is not yet implemented.

AUTHOR

Michael Daum <daum@michaeldaumconsulting.com>

COPYRIGHT AND LICENSE

Copyright 2012 Michael Daum

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See http://dev.perl.org/licenses/artistic.html.