ktrss.inc.php
来自「PHP 知识管理系统(基于树结构的知识管理系统), 英文原版的PHP源码。」· PHP 代码 · 共 749 行 · 第 1/2 页
PHP
749 行
$xmlItemHead = "<item>\n
<title>".htmlspecialchars($aItem[0][0][name], ENT_QUOTES, 'UTF-8')."</title>\n
<link>".$hostPath."action.php?kt_path_info=ktcore.actions.".htmlspecialchars($sTypeSelect, ENT_QUOTES, 'UTF-8')."=".$aItem[0][0]['id']."</link>\n
<description>\n";
$htmlItem = "<table border='0' width='90%'>\n
<tr>\n
<td width='5%' height='16px'>
<a href='".$hostPath."action.php?kt_path_info=ktcore.actions.".$sTypeSelect."=".$aItem[0][0][id]."' >
<img src='".$aItem[0][mimeTypeIcon]."' align='left' height='16px' width='16px' alt='' border='0' /></a>
</td>\n
<td align='left'> ".$aItem[0][mimeTypeFName]."</td>\n
</tr>\n
<tr>\n
<td colspan='2'>\n
".ucfirst($aItem[0]['itemType'])." Information (ID: ".$aItem[0][0][id].")</>\n
<hr>\n
<table width='95%'>\n
<tr>\n
<td>"._kt('Filename').": ".htmlspecialchars($aItem[0][0][filename], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n
<td>"._kt('Author').": ".htmlspecialchars($aItem[0][0][author], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n
<td>"._kt('Owner').": ".htmlspecialchars($owner, ENT_QUOTES, 'UTF-8')."</td>\n
<td></td>\n
</tr>\n
".$type."\n
<tr>\n
<td>"._kt('Workflow status').": ".htmlspecialchars($workflow, ENT_QUOTES, 'UTF-8')."</td>\n
<td></td>\n
</tr>\n
</table><br>\n
"._kt('Transaction Summary (Last 4)')."\n
<hr>\n
<table width='100%'>\n";
foreach($aItem[1] as $item){
$htmlItem .= "<tr>\n
<td>".$item[type]." name:</td>\n
<td>".htmlspecialchars($item[name], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n
<td>Path:</td>\n
<td>".htmlspecialchars($item[fullpath], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n
<td>Transaction:</td>\n
<td>".htmlspecialchars($item[transaction_name], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n
<td>Comment:</td>\n
<td>".htmlspecialchars($item[comment], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n";
if($item[version]){
$htmlItem .= "<td>Version:</td>\n
<td>".$item[version]."</td>\n";
}
$htmlItem .= "</tr>\n
<tr>\n
<td>Date:</td>\n
<td>".$item[datetime]."</td>\n
</tr>\n
<tr>\n
<td>User:</td>\n
<td>".htmlspecialchars($item[user_name], ENT_QUOTES, 'UTF-8')."</td>\n
</tr>\n
<tr>\n
<td colspan='2'><hr width='100' align='left'></td>\n
</tr>\n";
}
$htmlItem .= "</table>\n
</td>\n
</tr>\n
</table>";
$xmlItemFooter = "</description>\n</item>\n";
// Use htmlspecialchars to allow html tags in the xml.
$htmlItem = htmlspecialchars($htmlItem, ENT_QUOTES, 'UTF-8');
$feed .= $xmlItemHead.$htmlItem.$xmlItemFooter;
}
$footer = "</channel>\n</rss>\n";
return $head.$feed.$footer;
}
// Takes in an array as a parameter and returns rss2.0 compatible xml
function errorToXML($sError){
// Build path to host
$aPath = explode('/', trim($_SERVER['PHP_SELF']));
global $default;
$hostPath = "http" . ($default->sslEnabled ? "s" : "") . "://".$_SERVER['HTTP_HOST']."/".$aPath[1]."/";
$feed = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n
<rss version=\"2.0\">\n
<channel>\n
<title>".APP_NAME." RSS</title>\n
<copyright>(c) 2008 KnowledgeTree Inc.</copyright>\n
<link>{$hostPath}</link>\n
<description>KT-RSS</description>\n
<image>\n
<title>".APP_NAME." RSS</title>\n
<width>140</width>\n
<height>28</height>
<link>{$hostPath}knowledgeTree/</link>\n
<url>{$hostPath}resources/graphics/ktlogo_rss.png</url>\n
</image>\n
<item>\n
<title>Feed load error</title>\n
<description>".$sError."</description>\n
</item>\n
</channel>\n
</rss>\n";
return $feed;
}
// Delete feed function
function deleteFeed($iFeedId){
$res = DBUtil::autoDelete('plugin_rss', $iFeedId);
}
// Get title for external feed
function getExternalFeedTitle($iFeedId){
$sQuery = "SELECT title FROM plugin_rss WHERE id = ?";
$aParams = array($iFeedId);
$sFeedTitle = DBUtil::getOneResultKey(array($sQuery, $aParams), 'title');
if (PEAR::isError($sFeedTitle)) {
// XXX: log error
return false;
}
if ($sFeedTitle) {
return $sFeedTitle;
}
}
// Get url for external feed
function getExternalFeedUrl($iFeedId){
$sQuery = "SELECT url FROM plugin_rss WHERE id = ?";
$aParams = array($iFeedId);
$sFeedUrl = DBUtil::getOneResultKey(array($sQuery, $aParams), 'url');
if (PEAR::isError($sFeedUrl)) {
// XXX: log error
return false;
}
if ($sFeedUrl) {
return $sFeedUrl;
}
}
// Update external feed data
function updateFeed($iFeedId, $sFeedTitle, $sFeedUrl){
$sQuery = "UPDATE plugin_rss SET title=?, url=? WHERE id=?";
$aParams = array($sFeedTitle, $sFeedUrl, $iFeedId);
$res = DBUtil::runQuery(array($sQuery, $aParams));
return $res;
}
// Create new external feed
function createFeed($sFeedTitle, $sFeedUrl, $iUserId){
$aParams = array(
'user_id' => $iUserId,
'url' => $sFeedUrl,
'title' => $sFeedTitle,
);
$res = DBUtil::autoInsert('plugin_rss', $aParams);
return $res;
}
// Function to validate that a user has permissions for a specific document
function validateDocumentPermissions($iUserId, $iDocumentId){
// check if user id is in session. If not, set it
if(!isset($_SESSION["userID"])){
$_SESSION['userID'] = $iUserId;
}
// get document object
$oDocument =& Document::get($iDocumentId);
if (PEAR::isError($oDocument)) {
return false;
}
// check permissions for document
if(Permission::userHasDocumentReadPermission($oDocument)){
return true;
}else{
return false;
}
}
// Function to validate that a user has permissions for a specific folder
function validateFolderPermissions($iUserId, $iFolderId){
// check if user id is in session. If not, set it
if(!isset($_SESSION["userID"])){
$_SESSION['userID'] = $iUserId;
}
// get folder object
$oFolder = Folder::get($iFolderId);
if (PEAR::isError($oFolder)) {
return false;
}
// check permissions for folder
if(Permission::userHasFolderReadPermission($oFolder)){
return true;
}else{
return false;
}
}
// get icon link for rss
function getRssLinkIcon(){
// built server path
global $default;
$sHostPath = "http" . ($default->sslEnabled ? "s" : "") . "://".$_SERVER['HTTP_HOST']."/".$GLOBALS['KTRootUrl']."/";
// create image
$icon = "<img src='".$sHostPath."resources/graphics/rss.gif' alt='RSS' border=0/>";
return $icon;
}
// get rss link for a document/folder
function getRssLink($iItemId, $sItemType){
$item = strToLower($sItemType);
if($item == 'folder'){
$sItemParameter = '?folderId';
}else if($item == 'document'){
$sItemParameter = '?docId';
}
// built server path
global $default;
$sHostPath = "http" . ($default->sslEnabled ? "s" : "") . "://" . $_SERVER['HTTP_HOST'];
// build link
$sLink = $sHostPath.KTBrowseUtil::buildBaseUrl('rss').$sItemParameter.'='.$iItemId;
return $sLink;
}
// get rss icon link
function getImageLink($iItemId, $sItemType){
return "<a href='".KTrss::getRssLink($iItemId, $sItemType)."' target='_blank'>".KTrss::getRssLinkIcon()."</a>";
}
// get the mime type id for a document
function getDocumentMimeTypeId($iUserId, $iDocumentId){
if(!isset($_SESSION["userID"])){
$_SESSION['userID'] = $iUserId;
}
// get document object
$oDocument =& Document::get($iDocumentId);
$docMime = $oDocument->getMimeTypeID();
return $docMime;
}
// get mime information for a document
function getMimeTypeInfo($iUserId, $iDocumentId){
global $default;
$mimeinfo['typeId'] = KTrss::getDocumentMimeTypeId($iUserId, $iDocumentId); // mime type id
$mimeinfo['typeName'] = KTMime::getMimeTypeName($mimeinfo['typeId']); // mime type name
$mimeinfo['typeFName'] = KTMime::getFriendlyNameForString($mimeinfo['typeName']); // mime type friendly name
$mimeinfo['typeIcon'] = "http" . ($default->sslEnabled ? "s" : "") . "://".$_SERVER['HTTP_HOST']."/".$GLOBALS['KTRootUrl']."/resources/mimetypes/".KTMime::getIconPath($mimeinfo['typeId']).".png"; //icon path
return $mimeinfo;
}
// get the default folder icon
function getFolderIcon(){
global $default;
return $mimeinfo['typeIcon'] = "http" . ($default->sslEnabled ? "s" : "") . "://".$_SERVER['HTTP_HOST']."/".$GLOBALS['KTRootUrl']."/thirdparty/icon-theme/16x16/mimetypes/x-directory-normal.png"; //icon path
}
// get a document information
function getDocumentData($iUserId, $iDocumentId){
if(!isset($_SESSION["userID"])){
$_SESSION['userID'] = $iUserId;
}
// get document object
$oDocument =& Document::get($iDocumentId);
$cv = $oDocument->getContentVersionId();
$mv = $oDocument->getMetadataVersionId();
$sQuery = "SELECT dcv.document_id AS id, dmver.name AS name, dcv.filename AS filename, c.name AS author, o.name AS owner, dtl.name AS type, dwfs.name AS workflow_status " .
"FROM documents AS d LEFT JOIN document_content_version AS dcv ON d.id = dcv.document_id " .
"LEFT JOIN users AS o ON d.owner_id = o.id " .
"LEFT JOIN users AS c ON d.creator_id = c.id " .
"LEFT JOIN document_metadata_version AS dmv ON d.id = dmv.document_id " .
"LEFT JOIN document_types_lookup AS dtl ON dmv.document_type_id = dtl.id " .
"LEFT JOIN document_metadata_version AS dmver ON d.id = dmver.document_id " .
"LEFT JOIN workflow_states AS dwfs ON dmver.workflow_state_id = dwfs.id " .
"WHERE d.id = ? " .
"AND dmver.id = ? " .
"AND dcv.id = ? " .
"LIMIT 1";
$aParams = array($iDocumentId, $mv, $cv);
$aDocumentData = DBUtil::getResultArray(array($sQuery, $aParams));
if($aDocumentData){
return $aDocumentData;
}
}
// get a folder information
function getFolderData($iFolderId){
$sQuery = "SELECT f.id AS id, f.name AS name, f.name AS filename, c.name AS author, o.name AS owner, f.description AS description " .
"FROM folders AS f " .
"LEFT JOIN users AS o ON f.owner_id = o.id " .
"LEFT JOIN users AS c ON f.creator_id = c.id " .
"WHERE f.id = ? " .
"LIMIT 1";
$aParams = array($iFolderId);
$aFolderData = DBUtil::getResultArray(array($sQuery, $aParams));
if($aFolderData){
return $aFolderData;
}
}
// get a listing of the latest 3 transactions for a document
function getDocumentTransactions($aDocumentIds){
$sDocumentIds = implode(', ', $aDocumentIds);
$sQuery = "SELECT DT.datetime AS datetime, 'Document' AS type, DMV.name, D.full_path AS fullpath,
DTT.name AS transaction_name, U.name AS user_name, DT.version AS version, DT.comment AS comment
FROM document_transactions AS DT
INNER JOIN users AS U ON DT.user_id = U.id
INNER JOIN document_transaction_types_lookup AS DTT ON DTT.namespace = DT.transaction_namespace
LEFT JOIN documents AS D ON DT.document_id = D.id
LEFT JOIN document_metadata_version AS DMV ON D.metadata_version_id = DMV.id
WHERE DT.document_id IN ($sDocumentIds)
ORDER BY DT.datetime DESC
LIMIT 4";
$aDocumentTransactions = DBUtil::getResultArray($sQuery);
if(!PEAR::isError($aDocumentTransactions)){
return $aDocumentTransactions;
}
}
// Get a listing of the latest transactions for a folder and its child folders
function getFolderTransactions($aFolderIds){
$sFolderIds = implode(', ', $aFolderIds);
$sQuery = "SELECT FT.datetime AS datetime, 'Folder' AS type, F.name, F.full_path AS fullpath,
DTT.name AS transaction_name, U.name AS user_name, FT.comment AS comment
FROM folder_transactions AS FT LEFT JOIN users AS U ON FT.user_id = U.id
LEFT JOIN document_transaction_types_lookup AS DTT ON DTT.namespace = FT.transaction_namespace
LEFT JOIN folders AS F ON FT.folder_id = F.id
WHERE FT.folder_id IN ($sFolderIds)
ORDER BY FT.datetime DESC
LIMIT 4";
$aFolderTransactions = DBUtil::getResultArray($sQuery);
return $aFolderTransactions;
}
}
?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?