This repository has been archived on 2024-11-28. You can view files and clone it, but cannot push or open issues or pull requests.
Incam_SGD/lib/api/ktcmis/ktNavigationService.inc.php

259 lines
8.7 KiB
PHP

<?php
/**
* Navigation Service CMIS wrapper API for KnowledgeTree.
*
* KnowledgeTree Community Edition
* Document Management Made Simple
* Copyright (C) 2008,2009 KnowledgeTree Inc.
*
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License version 3 as published by the
* Free Software Foundation.
*
* This program 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 General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* You can contact KnowledgeTree Inc., PO Box 7775 #87847, San Francisco,
* California 94120-7775, or email info@knowledgetree.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU General Public License version 3.
*
* In accordance with Section 7(b) of the GNU General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* KnowledgeTree" logo and retain the original copyright notice. If the display of the
* logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices
* must display the words "Powered by KnowledgeTree" and retain the original
* copyright notice.
*
* @copyright 2008-2009, KnowledgeTree Inc.
* @license GNU General Public License version 3
* @author KnowledgeTree Team
* @package KTCMIS
* @version Version 0.9
*/
require_once(realpath(dirname(__FILE__) . '/ktService.inc.php'));
require_once(CMIS_DIR . '/services/CMISNavigationService.inc.php');
/*
* Handles repository navigation
*/
class KTNavigationService extends KTCMISBase {
protected $NavigationService;
public function __construct(&$ktapi = null, $username = null, $password = null)
{
parent::__construct($ktapi, $username, $password);
// instantiate underlying CMIS service
$this->NavigationService = new CMISNavigationService();
$this->setInterface();
}
public function startSession($username, $password)
{
parent::startSession($username, $password);
$this->setInterface();
return self::$session;
}
public function setInterface(&$ktapi = null)
{
parent::setInterface($ktapi);
$this->NavigationService->setInterface(self::$ktapi);
}
/**
* Get descendents of the specified folder, up to the depth indicated
*
* @param string $repositoryId
* @param string $folderId
* @param boolean $includeAllowableActions
* @param boolean $includeRelationships
* @param string $typeID
* @param int $depth
* @param string $filter
* @return array $descendants
*/
public function getDescendants($repositoryId, $folderId, $includeAllowableActions, $includeRelationships,
$depth = 1, $typeID = 'Any', $filter = '')
{
// TODO optional parameters
$descendantsResult = $this->NavigationService->getDescendants($repositoryId, $folderId, $includeAllowableActions,
$includeRelationships, $depth);
if (PEAR::isError($descendantsResult))
{
return array(
"status_code" => 1,
"message" => "Failed getting descendants for folder"
);
}
// format for webservices consumption
// NOTE this will almost definitely be changing in the future, this is just to get something working
$descendants = CMISUtil::decodeObjectHierarchy($descendantsResult, 'child');
return array (
"status_code" => 0,
"results" => $descendants
);
}
/**
* Get direct children of the specified folder
*
* @param string $repositoryId
* @param string $folderId
* @param boolean $includeAllowableActions
* @param boolean $includeRelationships
* @param string $typeID
* @param string $filter
* @param int $maxItems
* @param int $skipCount
* @return array $descendants
*/
public function getChildren($repositoryId, $folderId, $includeAllowableActions, $includeRelationships,
$typeID = 'Any', $filter = '', $maxItems = 0, $skipCount = 0)
{
// TODO paging
// TODO optional parameters
$childrenResult = $this->NavigationService->getChildren($repositoryId, $folderId, $includeAllowableActions, $includeRelationships);
if (PEAR::isError($childrenResult))
{
return array(
"status_code" => 1,
"message" => "Failed getting descendants for folder"
);
}
$children = CMISUtil::decodeObjectHierarchy($childrenResult, 'child');
return array(
"status_code" => 0,
"results" => $children
);
}
/**
* Gets the parent of the selected folder
*
* @param string $repositoryId
* @param string $folderId
* @param boolean $includeAllowableActions
* @param boolean $includeRelationships
* @param boolean $returnToRoot
* @param string $filter
* @return ancestry[]
*/
public function getFolderParent($repositoryId, $folderId, $includeAllowableActions, $includeRelationships, $returnToRoot, $filter = '')
{
try {
$ancestryResult = $this->NavigationService->getFolderParent($repositoryId, $folderId, $includeAllowableActions,
$includeRelationships, $returnToRoot);
}
catch (Exception $e) {
return array(
"status_code" => 1,
"message" => "Failed getting ancestry for folder: " . $e->getMessage()
);
}
if (PEAR::isError($ancestryResult))
{
return array(
"status_code" => 1,
"message" => "Failed getting ancestry for folder"
);
}
$ancestry = CMISUtil::decodeObjectHierarchy($ancestryResult, 'child');
return array(
"status_code" => 0,
"results" => $ancestry
);
}
/**
* Gets the parents for the selected object
*
* @param string $repositoryId
* @param string $folderId
* @param boolean $includeAllowableActions
* @param boolean $includeRelationships
* @param string $filter
* @return ancestry[]
*/
function getObjectParents($repositoryId, $objectId, $includeAllowableActions, $includeRelationships, $filter = '')
{
$ancestryResult = $this->NavigationService->getObjectParents($repositoryId, $objectId, $includeAllowableActions,
$includeRelationships);
if (PEAR::isError($ancestryResult))
{
return array(
"status_code" => 1,
"message" => "Failed getting ancestry for object"
);
}
$ancestry = CMISUtil::decodeObjectHierarchy($ancestryResult, 'child');
return array(
"status_code" => 0,
"results" => $ancestry
);
}
/**
* Returns a list of checked out documents from the selected repository
*
* @param string $repositoryId
* @param string $folderId The folder for which checked out docs are requested
* @param string $filter
* @param boolean $includeAllowableActions
* @param boolean $includeRelationships
* @param int $maxItems
* @param int $skipCount
* @return array $checkedout The collection of checked out documents
*/
function getCheckedOutDocs($repositoryId, $includeAllowableActions, $includeRelationships, $folderId = null, $filter = '',
$maxItems = 0, $skipCount = 0)
{
$checkedout = $this->NavigationService->getCheckedOutDocs($repositoryId, $includeAllowableActions, $includeRelationships,
$folderId, $filter, $maxItems, $skipCount);
if (PEAR::isError($checkedout))
{
return array(
"status_code" => 1,
"message" => "Failed getting list of checked out documents"
);
}
// convert to array format for external code
$co = array();
foreach ($checkedout as $documentProperties)
{
$co[] = CMISUtil::createObjectPropertiesEntry($documentProperties);;
}
return array(
"status_code" => 0,
"results" => $co
);
}
}
?>