2007-12-12 17:29:16 +01:00
< ? php
/***************************************************************************
2008-11-25 16:57:29 +01:00
Copyright ( C ) 2004 - 2006 Scuttle project
http :// sourceforge . net / projects / scuttle /
http :// scuttle . org /
2007-12-12 17:29:16 +01:00
2008-11-25 16:57:29 +01:00
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
2007-12-12 17:29:16 +01:00
2008-11-25 16:57:29 +01:00
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 .
2007-12-12 17:29:16 +01:00
2008-11-25 16:57:29 +01:00
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
***************************************************************************/
2007-12-12 17:29:16 +01:00
2010-02-08 08:32:34 +01:00
require_once 'www-header.php' ;
2007-12-12 17:29:16 +01:00
2008-11-25 16:57:29 +01:00
/* Service creation: only useful services are created */
2009-10-23 19:13:16 +02:00
$bookmarkservice = SemanticScuttle_Service_Factory :: get ( 'Bookmark' );
$cacheservice = SemanticScuttle_Service_Factory :: get ( 'Cache' );
2007-12-12 17:29:16 +01:00
2008-11-25 16:57:29 +01:00
/* Managing all possible inputs */
isset ( $_GET [ 'action' ]) ? define ( 'GET_ACTION' , $_GET [ 'action' ]) : define ( 'GET_ACTION' , '' );
isset ( $_POST [ 'submitted' ]) ? define ( 'POST_SUBMITTED' , $_POST [ 'submitted' ]) : define ( 'POST_SUBMITTED' , '' );
isset ( $_GET [ 'title' ]) ? define ( 'GET_TITLE' , $_GET [ 'title' ]) : define ( 'GET_TITLE' , '' );
isset ( $_GET [ 'address' ]) ? define ( 'GET_ADDRESS' , $_GET [ 'address' ]) : define ( 'GET_ADDRESS' , '' );
isset ( $_GET [ 'description' ]) ? define ( 'GET_DESCRIPTION' , $_GET [ 'description' ]) : define ( 'GET_DESCRIPTION' , '' );
2009-01-12 17:40:39 +01:00
isset ( $_GET [ 'privateNote' ]) ? define ( 'GET_PRIVATENOTE' , $_GET [ 'privateNote' ]) : define ( 'GET_PRIVATENOTE' , '' );
2008-11-25 16:57:29 +01:00
isset ( $_GET [ 'tags' ]) ? define ( 'GET_TAGS' , $_GET [ 'tags' ]) : define ( 'GET_TAGS' , '' );
2009-02-16 10:49:51 +01:00
isset ( $_GET [ 'copyOf' ]) ? define ( 'GET_COPYOF' , $_GET [ 'copyOf' ]) : define ( 'GET_COPYOF' , '' );
2008-11-25 16:57:29 +01:00
isset ( $_POST [ 'title' ]) ? define ( 'POST_TITLE' , $_POST [ 'title' ]) : define ( 'POST_TITLE' , '' );
isset ( $_POST [ 'address' ]) ? define ( 'POST_ADDRESS' , $_POST [ 'address' ]) : define ( 'POST_ADDRESS' , '' );
isset ( $_POST [ 'description' ]) ? define ( 'POST_DESCRIPTION' , $_POST [ 'description' ]) : define ( 'POST_DESCRIPTION' , '' );
2009-01-12 17:40:39 +01:00
isset ( $_POST [ 'privateNote' ]) ? define ( 'POST_PRIVATENOTE' , $_POST [ 'privateNote' ]) : define ( 'POST_PRIVATENOTE' , '' );
2008-11-25 16:57:29 +01:00
isset ( $_POST [ 'status' ]) ? define ( 'POST_STATUS' , $_POST [ 'status' ]) : define ( 'POST_STATUS' , '' );
2009-02-04 15:00:16 +01:00
isset ( $_POST [ 'referrer' ]) ? define ( 'POST_REFERRER' , $_POST [ 'referrer' ]) : define ( 'POST_REFERRER' , '' );
2008-11-25 16:57:29 +01:00
isset ( $_GET [ 'popup' ]) ? define ( 'GET_POPUP' , $_GET [ 'popup' ]) : define ( 'GET_POPUP' , '' );
isset ( $_POST [ 'popup' ]) ? define ( 'POST_POPUP' , $_POST [ 'popup' ]) : define ( 'POST_POPUP' , '' );
isset ( $_GET [ 'page' ]) ? define ( 'GET_PAGE' , $_GET [ 'page' ]) : define ( 'GET_PAGE' , 0 );
isset ( $_GET [ 'sort' ]) ? define ( 'GET_SORT' , $_GET [ 'sort' ]) : define ( 'GET_SORT' , '' );
2007-12-12 17:29:16 +01:00
2011-03-17 08:46:15 +01:00
if ( ! isset ( $_POST [ 'tags' ])) {
$_POST [ 'tags' ] = array ();
}
//echo '<p>' . var_export($_POST, true) . '</p>';die();
2007-12-12 17:29:16 +01:00
2008-11-25 16:57:29 +01:00
if (( GET_ACTION == " add " ) && ! $userservice -> isLoggedOn ()) {
$loginqry = str_replace ( " ' " , '%27' , stripslashes ( $_SERVER [ 'QUERY_STRING' ]));
header ( 'Location: ' . createURL ( 'login' , '?' . $loginqry ));
exit ();
}
2007-12-12 17:29:16 +01:00
if ( $userservice -> isLoggedOn ()) {
2008-12-05 08:25:04 +01:00
$currentUser = $userservice -> getCurrentObjectUser ();
$currentUserID = $currentUser -> getId ();
$currentUsername = $currentUser -> getUsername ();
2007-12-12 17:29:16 +01:00
}
2008-11-25 16:57:29 +01:00
@ list ( $url , $user , $cat ) = isset ( $_SERVER [ 'PATH_INFO' ]) ? explode ( '/' , $_SERVER [ 'PATH_INFO' ]) : NULL ;
2007-12-12 17:29:16 +01:00
$endcache = false ;
if ( $usecache ) {
2008-11-25 16:57:29 +01:00
// Generate hash for caching on
$hash = md5 ( $_SERVER [ 'REQUEST_URI' ] . $user );
// Don't cache if its users' own bookmarks
if ( $userservice -> isLoggedOn ()) {
if ( $currentUsername != $user ) {
// Cache for 5 minutes
$cacheservice -> Start ( $hash );
$endcache = true ;
}
} else {
// Cache for 30 minutes
$cacheservice -> Start ( $hash , 1800 );
$endcache = true ;
}
2007-12-12 17:29:16 +01:00
}
$pagetitle = $rssCat = $catTitle = '' ;
if ( $user ) {
2008-11-25 16:57:29 +01:00
if ( is_int ( $user )) {
$userid = intval ( $user );
} else {
if ( ! ( $userinfo = $userservice -> getUserByUsername ( $user ))) {
$tplVars [ 'error' ] = sprintf ( T_ ( 'User with username %s was not found' ), $user );
$templateservice -> loadTemplate ( 'error.404.tpl' , $tplVars );
exit ();
} else {
$userid =& $userinfo [ 'uId' ];
}
}
$pagetitle .= ': ' . $user ;
2007-12-12 17:29:16 +01:00
}
if ( $cat ) {
2008-11-25 16:57:29 +01:00
$catTitle = ': ' . str_replace ( '+' , ' + ' , $cat );
2009-02-17 10:36:20 +01:00
$catTitleWithUrls = ': ' ;
$titleTags = explode ( '+' , filter ( $cat ));
2008-12-18 23:11:03 +01:00
for ( $i = 0 ; $i < count ( $titleTags ); $i ++ ) {
$catTitleWithUrls .= $titleTags [ $i ] . '<a href="' . createUrl ( 'bookmarks' , $user . '/' . aggregateTags ( $titleTags , '+' , $titleTags [ $i ])) . '" title="' . T_ ( 'Remove the tag from the selection' ) . '">*</a> + ' ;
}
$catTitleWithUrls = substr ( $catTitleWithUrls , 0 , strlen ( $catTitleWithUrls ) - strlen ( ' + ' ));
$pagetitle .= $catTitleWithUrls ;
2007-12-12 17:29:16 +01:00
}
2009-05-22 17:15:00 +02:00
else
{
$catTitleWithUrls = '' ;
}
2007-12-12 17:29:16 +01:00
$pagetitle = substr ( $pagetitle , 2 );
// Header variables
$tplVars [ 'loadjs' ] = true ;
// ADD A BOOKMARK
$saved = false ;
$templatename = 'bookmarks.tpl' ;
2008-11-25 16:57:29 +01:00
if ( $userservice -> isLoggedOn () && POST_SUBMITTED != '' ) {
if ( ! POST_TITLE || ! POST_ADDRESS ) {
$tplVars [ 'error' ] = T_ ( 'Your bookmark must have a title and an address' );
$templatename = 'editbookmark.tpl' ;
} else {
$address = trim ( POST_ADDRESS );
// If the bookmark exists already, edit the original
if ( $bookmarkservice -> bookmarkExists ( $address , $currentUserID )) {
2010-03-17 21:03:49 +01:00
$bookmark = $bookmarkservice -> getBookmarkByAddress ( $address );
2008-11-25 16:57:29 +01:00
header ( 'Location: ' . createURL ( 'edit' , $bookmark [ 'bId' ]));
exit ();
// If it's new, save it
} else {
$title = trim ( POST_TITLE );
$description = trim ( POST_DESCRIPTION );
2009-01-12 17:40:39 +01:00
$privateNote = trim ( POST_PRIVATENOTE );
2008-11-25 16:57:29 +01:00
$status = intval ( POST_STATUS );
2011-03-22 18:20:37 +01:00
$categories = explode ( ',' , $_POST [ 'tags' ]);
2008-11-25 16:57:29 +01:00
$saved = true ;
2009-01-12 17:40:39 +01:00
if ( $bookmarkservice -> addBookmark ( $address , $title , $description , $privateNote , $status , $categories )) {
2008-11-25 16:57:29 +01:00
if ( POST_POPUP != '' ) {
$tplVars [ 'msg' ] = '<script type="text/javascript">window.close();</script>' ;
} else {
2009-02-27 11:51:46 +01:00
$tplVars [ 'msg' ] = T_ ( 'Bookmark saved' ) . ' <a href="javascript:history.go(-2)">' . T_ ( '(Come back to previous page.)' ) . '</a>' ;
2008-11-25 16:57:29 +01:00
// Redirection option
if ( $GLOBALS [ 'useredir' ]) {
$address = $GLOBALS [ 'url_redir' ] . $address ;
}
}
} else {
$tplVars [ 'error' ] = T_ ( 'There was an error saving your bookmark. Please try again or contact the administrator.' );
$templatename = 'editbookmark.tpl' ;
$saved = false ;
}
}
}
2007-12-12 17:29:16 +01:00
}
2008-11-25 16:57:29 +01:00
if ( GET_ACTION == " add " ) {
// If the bookmark exists already, edit the original
2009-02-17 10:36:20 +01:00
if ( $bookmarkservice -> bookmarkExists ( stripslashes ( GET_ADDRESS ), $currentUserID )) {
2010-03-18 20:24:21 +01:00
$bookmark =& $bookmarkservice -> getBookmarks ( 0 , NULL , $currentUserID , NULL , NULL , NULL , NULL , NULL , NULL , $bookmarkservice -> getHash ( stripslashes ( GET_ADDRESS )));
2008-11-25 16:57:29 +01:00
$popup = ( GET_POPUP != '' ) ? '?popup=1' : '' ;
header ( 'Location: ' . createURL ( 'edit' , $bookmark [ 'bookmarks' ][ 0 ][ 'bId' ] . $popup ));
exit ();
}
$templatename = 'editbookmark.tpl' ;
2007-12-12 17:29:16 +01:00
}
2008-11-25 16:57:29 +01:00
2007-12-12 17:29:16 +01:00
if ( $templatename == 'editbookmark.tpl' ) {
2008-11-25 16:57:29 +01:00
if ( $userservice -> isLoggedOn ()) {
$tplVars [ 'formaction' ] = createURL ( 'bookmarks' , $currentUsername );
if ( POST_SUBMITTED != '' ) {
$tplVars [ 'row' ] = array (
'bTitle' => stripslashes ( POST_TITLE ),
'bAddress' => stripslashes ( POST_ADDRESS ),
'bDescription' => stripslashes ( POST_DESCRIPTION ),
2009-01-12 17:40:39 +01:00
'bPrivateNote' => stripslashes ( POST_PRIVATENOTE ),
2011-03-17 08:46:15 +01:00
'tags' => ( $_POST [ 'tags' ] ? $_POST [ 'tags' ] : array ()),
2011-03-15 07:53:39 +01:00
'bStatus' => $GLOBALS [ 'defaults' ][ 'privacy' ],
2008-11-25 16:57:29 +01:00
);
2011-03-17 08:46:15 +01:00
$tplVars [ 'tags' ] = $_POST [ 'tags' ];
2009-02-17 10:36:20 +01:00
} else {
if ( GET_COPYOF != '' ) { //copy from bookmarks page
2009-10-29 10:05:37 +01:00
$tplVars [ 'row' ] = $bookmarkservice -> getBookmark ( intval ( GET_COPYOF ), true );
2009-02-17 10:36:20 +01:00
if ( ! $currentUser -> isAdmin ()) {
$tplVars [ 'row' ][ 'bPrivateNote' ] = '' ; //only admin can copy private note
}
} else { //copy from pop-up bookmarklet
$tplVars [ 'row' ] = array (
'bTitle' => stripslashes ( GET_TITLE ),
'bAddress' => stripslashes ( GET_ADDRESS ),
'bDescription' => stripslashes ( GET_DESCRIPTION ),
'bPrivateNote' => stripslashes ( GET_PRIVATENOTE ),
'tags' => ( GET_TAGS ? explode ( ',' , stripslashes ( GET_TAGS )) : array ()),
2011-03-15 07:53:39 +01:00
'bStatus' => $GLOBALS [ 'defaults' ][ 'privacy' ]
2009-02-17 10:36:20 +01:00
);
}
2008-11-25 16:57:29 +01:00
}
$title = T_ ( 'Add a Bookmark' );
2009-09-17 14:31:53 +02:00
$tplVars [ 'referrer' ] = '' ;;
if ( isset ( $_SERVER [ 'HTTP_REFERER' ])) {
$tplVars [ 'referrer' ] = $_SERVER [ 'HTTP_REFERER' ];
}
2008-11-25 16:57:29 +01:00
$tplVars [ 'pagetitle' ] = $title ;
$tplVars [ 'subtitle' ] = $title ;
$tplVars [ 'btnsubmit' ] = T_ ( 'Add Bookmark' );
$tplVars [ 'popup' ] = ( GET_POPUP != '' ) ? GET_POPUP : null ;
} else {
$tplVars [ 'error' ] = T_ ( 'You must be logged in before you can add bookmarks.' );
}
} else if ( $user && GET_POPUP == '' ) {
2008-12-05 08:25:04 +01:00
$tplVars [ 'sidebar_blocks' ] = array ( 'watchstatus' );
2008-11-25 16:57:29 +01:00
2009-02-10 12:40:07 +01:00
if ( ! $cat ) { //user page without tags
2008-11-25 16:57:29 +01:00
$cat = NULL ;
$tplVars [ 'currenttag' ] = NULL ;
2009-02-10 12:40:07 +01:00
//$tplVars['sidebar_blocks'][] = 'menu2';
2009-06-18 17:02:52 +02:00
$tplVars [ 'sidebar_blocks' ][] = 'linked' ;
2009-02-10 12:40:07 +01:00
$tplVars [ 'sidebar_blocks' ][] = 'popular' ;
} else { //pages with tags
2008-11-25 16:57:29 +01:00
$rssCat = '/' . filter ( $cat , 'url' );
$tplVars [ 'currenttag' ] = $cat ;
$tplVars [ 'sidebar_blocks' ][] = 'tagactions' ;
2009-02-10 12:40:07 +01:00
//$tplVars['sidebar_blocks'][] = 'menu2';
2008-11-25 16:57:29 +01:00
$tplVars [ 'sidebar_blocks' ][] = 'linked' ;
$tplVars [ 'sidebar_blocks' ][] = 'related' ;
2009-02-10 12:40:07 +01:00
/*$tplVars['sidebar_blocks'][] = 'menu';*/
2008-11-25 16:57:29 +01:00
}
2009-05-05 11:58:44 +02:00
$tplVars [ 'sidebar_blocks' ][] = 'menu2' ;
2008-11-25 16:57:29 +01:00
$tplVars [ 'popCount' ] = 30 ;
2008-12-19 01:22:32 +01:00
//$tplVars['sidebar_blocks'][] = 'popular';
2008-11-25 16:57:29 +01:00
$tplVars [ 'userid' ] = $userid ;
$tplVars [ 'userinfo' ] =& $userinfo ;
$tplVars [ 'user' ] = $user ;
$tplVars [ 'range' ] = 'user' ;
// Pagination
2009-05-19 17:59:55 +02:00
$perpage = getPerPageCount ( $currentUser );
2008-11-25 16:57:29 +01:00
if ( intval ( GET_PAGE ) > 1 ) {
2009-10-29 10:05:37 +01:00
$page = intval ( GET_PAGE );
2008-11-25 16:57:29 +01:00
$start = ( $page - 1 ) * $perpage ;
} else {
$page = 0 ;
$start = 0 ;
}
// Set template vars
$tplVars [ 'rsschannels' ] = array (
array ( filter ( $sitename . ': ' . $pagetitle ), createURL ( 'rss' , filter ( $user , 'url' ) . $rssCat . '?sort=' . getSortOrder ()))
);
$tplVars [ 'page' ] = $page ;
$tplVars [ 'start' ] = $start ;
$tplVars [ 'bookmarkCount' ] = $start + 1 ;
$bookmarks =& $bookmarkservice -> getBookmarks ( $start , $perpage , $userid , $cat , null , getSortOrder ());
$tplVars [ 'total' ] = $bookmarks [ 'total' ];
$tplVars [ 'bookmarks' ] =& $bookmarks [ 'bookmarks' ];
$tplVars [ 'cat_url' ] = createURL ( 'bookmarks' , '%s/%s' );
$tplVars [ 'nav_url' ] = createURL ( 'bookmarks' , '%s/%s%s' );
if ( $userservice -> isLoggedOn () && $user == $currentUsername ) {
2008-12-18 23:11:03 +01:00
$tplVars [ 'pagetitle' ] = T_ ( 'My Bookmarks' ) . $catTitle ;
$tplVars [ 'subtitle' ] = T_ ( 'My Bookmarks' ) . $catTitleWithUrls ;
2008-11-25 16:57:29 +01:00
} else {
2009-02-03 10:46:40 +01:00
$tplVars [ 'pagetitle' ] = $user . ': ' . $cat ;
2008-12-18 23:11:03 +01:00
$tplVars [ 'subtitle' ] = $pagetitle ;
2008-11-25 16:57:29 +01:00
}
2007-12-12 17:29:16 +01:00
}
2008-01-23 15:47:35 +01:00
$tplVars [ 'summarizeLinkedTags' ] = true ;
2008-05-14 10:55:38 +02:00
$tplVars [ 'pageName' ] = PAGE_BOOKMARKS ;
2008-01-23 15:47:35 +01:00
2009-02-04 15:00:16 +01:00
2007-12-12 17:29:16 +01:00
$templateservice -> loadTemplate ( $templatename , $tplVars );
if ( $usecache && $endcache ) {
2008-11-25 16:57:29 +01:00
// Cache output if existing copy has expired
$cacheservice -> End ( $hash );
2007-12-12 17:29:16 +01:00
}
?>