PHP 7.3 compat, bug fixes
This commit is contained in:
parent
e636523aac
commit
ea04385bc1
16 changed files with 45 additions and 58 deletions
16
README.md
Normal file
16
README.md
Normal file
|
@ -0,0 +1,16 @@
|
|||
# SemanticScuttle
|
||||
|
||||
SemanticScuttle is a social bookmarking tool experimenting with new features like structured tags and collaborative descriptions of tags. Originally a fork of Scuttle, it has overtaken its ancestor in stability, features and usability.
|
||||
|
||||
## Features
|
||||
* LDAP/Active Directory authentication
|
||||
* RSS feed support: global feed, user feeds, per-tag feeds, private feeds
|
||||
* Public and private bookmarks
|
||||
* Delicious and Browser bookmark import
|
||||
* Theming support
|
||||
* Firefox plugin
|
||||
|
||||
## Origin
|
||||
|
||||
* https://sourceforge.net/projects/semanticscuttle/
|
||||
* https://github.com/cweiske/SemanticScuttle
|
1
cache/.gitignore
vendored
Normal file
1
cache/.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
*.cache
|
3
cache/.htaccess
vendored
3
cache/.htaccess
vendored
|
@ -1,2 +1 @@
|
|||
order allow,deny
|
||||
deny from all
|
||||
Require all denied
|
||||
|
|
|
@ -115,7 +115,7 @@ $usecache = false;
|
|||
*
|
||||
* @var string
|
||||
*/
|
||||
$dir_cache = dirname(__FILE__) . '/cache/';
|
||||
$dir_cache = dirname(__DIR__, 1) . '/cache';
|
||||
|
||||
/**
|
||||
* Use clean urls without .php filenames.
|
||||
|
@ -149,14 +149,14 @@ $debugMode = false;
|
|||
*
|
||||
* @var string
|
||||
*/
|
||||
$dbtype = 'mysql4';
|
||||
$dbtype = 'mysqli';
|
||||
|
||||
/**
|
||||
* Database hostname/IP
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
$dbhost = '127.0.0.1';
|
||||
$dbhost = 'localhost';
|
||||
|
||||
/**
|
||||
* Database port.
|
||||
|
|
|
@ -46,7 +46,7 @@ $cleanurls = false;
|
|||
*
|
||||
* @var boolean
|
||||
*/
|
||||
$debugMode = true;
|
||||
$debugMode = false;
|
||||
|
||||
|
||||
/***************************************************
|
||||
|
@ -62,7 +62,7 @@ $debugMode = true;
|
|||
*
|
||||
* @var string
|
||||
*/
|
||||
$dbtype = 'mysql4';
|
||||
$dbtype = 'mysqli';
|
||||
/**
|
||||
* Database username
|
||||
*
|
||||
|
@ -89,7 +89,7 @@ $dbname = 'scuttle';
|
|||
*
|
||||
* @var string
|
||||
*/
|
||||
$dbhost = '127.0.0.1';
|
||||
$dbhost = 'localhost';
|
||||
|
||||
|
||||
/***************************************************
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
ALTER TABLE `sc_bookmarks` CHANGE `bDescription` `bDescription` VARCHAR( 1500 )
|
||||
ALTER TABLE `sc_bookmarks` CHANGE `bDescription` `bDescription` VARCHAR( 1500 );
|
||||
CREATE TABLE `sc_tagscache` (
|
||||
`tcId` int(11) NOT NULL auto_increment,
|
||||
`tag1` varchar(100) NOT NULL default '',
|
||||
|
|
|
@ -5,6 +5,9 @@
|
|||
-- Table structure for table `sc_bookmarks`
|
||||
--
|
||||
|
||||
# to avoid STRICT_TRANS_TABLES mode
|
||||
SET sql_mode = '';
|
||||
|
||||
CREATE TABLE `sc_bookmarks` (
|
||||
`bId` int(11) NOT NULL auto_increment,
|
||||
`uId` int(11) NOT NULL default '0',
|
||||
|
@ -17,8 +20,8 @@ CREATE TABLE `sc_bookmarks` (
|
|||
`bDescription` text default NULL,
|
||||
`bPrivateNote` text default NULL,
|
||||
`bHash` varchar(32) NOT NULL default '',
|
||||
`bVotes` int(11) NOT NULL,
|
||||
`bVoting` int(11) NOT NULL,
|
||||
`bVotes` int(11) NOT NULL default '0',
|
||||
`bVoting` int(11) NOT NULL default '0',
|
||||
`bShort` varchar(16) default NULL,
|
||||
PRIMARY KEY (`bId`),
|
||||
KEY `sc_bookmarks_usd` (`uId`,`bStatus`,`bDatetime`),
|
||||
|
|
|
@ -53,7 +53,7 @@ JS;
|
|||
$taglist = '';
|
||||
foreach (array_keys($tagsCloud) as $key) {
|
||||
$row = $tagsCloud[$key];
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', $row['bCount']);
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', (int)$row['bCount']);
|
||||
$taglist .= '<span'
|
||||
. ' title="'. $row['bCount'] . ' ' . $entries . '"'
|
||||
. ' style="font-size:' . $row['size'] . '"'
|
||||
|
|
|
@ -31,7 +31,7 @@ if ($popularTags && count($popularTags) > 0) {
|
|||
}
|
||||
|
||||
foreach ($popularTags as $row) {
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', $row['bCount']);
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', (int)$row['bCount']);
|
||||
$contents .= '<a href="'. sprintf($cat_url, $user, filter($row['tag'], 'url')) .'" title="'. $row['bCount'] .' '. $entries .'" rel="tag" style="font-size:'. $row['size'] .'">'. filter($row['tag']) .'</a> ';
|
||||
}
|
||||
echo $contents ."\n";
|
||||
|
|
|
@ -26,7 +26,7 @@ if ($recentTags && count($recentTags) > 0) {
|
|||
}
|
||||
|
||||
foreach ($recentTags as $row) {
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', $row['bCount']);
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', (int)$row['bCount']);
|
||||
$contents .= '<a href="'. sprintf($cat_url, $user, filter($row['tag'], 'url')) .'" title="'. $row['bCount'] .' '. $entries .'" rel="tag" style="font-size:'. $row['size'] .'">'. filter($row['tag']) .'</a> ';
|
||||
}
|
||||
echo $contents ."</p>\n";
|
||||
|
|
|
@ -16,7 +16,7 @@ if ($tags && count($tags) > 0) {
|
|||
<?php
|
||||
$contents = '';
|
||||
foreach ($tags as $row) {
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', $row['bCount']);
|
||||
$entries = T_ngettext('bookmark', 'bookmarks', (int)$row['bCount']);
|
||||
$contents .= '<a href="'. sprintf($cat_url, $user, filter($row['tag'], 'url')) .'" title="'. $row['bCount'] .' '. $entries .'" rel="tag" style="font-size:'. $row['size'] .'">'. filter($row['tag']) .'</a> ';
|
||||
}
|
||||
echo $contents ."\n";
|
||||
|
|
|
@ -1,8 +0,0 @@
|
|||
<ul class="menu">
|
||||
<li><a href="index.html">Index</a></li>
|
||||
<li><a href="INSTALL.html">Installation</a></li>
|
||||
<li><a href="UPGRADE.html">Upgrade</a></li>
|
||||
<li><a href="ChangeLog.html">ChangeLog</a></li>
|
||||
<li><a href="http://semanticscuttle.sourceforget.net/">Homepage</a></li>
|
||||
<li><a href="https://sourceforget.net/projects/semanticscuttle">Project page</a></li>
|
||||
</ul>
|
|
@ -1,28 +0,0 @@
|
|||
/* SemanticScuttle improvements */
|
||||
.document {
|
||||
max-width: 100ex;
|
||||
}
|
||||
h1.title {
|
||||
background-image: url("");
|
||||
background-repeat: no-repeat;
|
||||
padding-left: 64px;
|
||||
padding-top: 0.2em;
|
||||
margin-bottom: 00px;
|
||||
height: 60px;
|
||||
border-bottom: 3px solid #666;
|
||||
}
|
||||
h2 {
|
||||
margin-top: 1.5em;
|
||||
|
||||
}
|
||||
pre {
|
||||
padding: 1em;
|
||||
background-color: #EEE;
|
||||
border: 1px solid #BBB;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
tt, code {
|
||||
background-color: #DDD;
|
||||
padding: 0.2ex;
|
||||
}
|
|
@ -734,7 +734,7 @@ class SemanticScuttle_Service_Bookmark extends SemanticScuttle_DbService
|
|||
$tags = explode('+', trim($tags));
|
||||
}
|
||||
|
||||
$tagcount = count($tags);
|
||||
$tagcount = empty($tags) ? 0 : count($tags);
|
||||
for ($i = 0; $i < $tagcount; $i ++) {
|
||||
$tags[$i] = trim($tags[$i]);
|
||||
}
|
||||
|
@ -853,7 +853,7 @@ class SemanticScuttle_Service_Bookmark extends SemanticScuttle_DbService
|
|||
$aTerms = array_map('trim', $aTerms);
|
||||
|
||||
// Search terms in tags as well when none given
|
||||
if (!count($tags)) {
|
||||
if (!empty($tags)) {
|
||||
$query_2 .= ' LEFT JOIN '. $b2tservice->getTableName() .' AS T'
|
||||
. ' ON B.bId = T.bId';
|
||||
$dotags = true;
|
||||
|
@ -1136,7 +1136,7 @@ class SemanticScuttle_Service_Bookmark extends SemanticScuttle_DbService
|
|||
|
||||
// Delete final /
|
||||
if (substr($address, -1) == '/') {
|
||||
$address = substr($address, 0, count($address)-2);
|
||||
$address = substr($address, 0, strlen($address)-2);
|
||||
}
|
||||
|
||||
return $address;
|
||||
|
|
|
@ -691,14 +691,12 @@ class SemanticScuttle_Service_Bookmark2Tag extends SemanticScuttle_DbService
|
|||
}
|
||||
|
||||
if ($sortOrder == 'alphabet_asc') {
|
||||
usort($output, create_function('$a,$b','return strcasecmp(utf8_deaccent($a["tag"]), utf8_deaccent($b["tag"]));'));
|
||||
usort($output, "cmp");
|
||||
}
|
||||
|
||||
return $output;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Deletes all tags in bookmarks2tags
|
||||
*
|
||||
|
@ -711,4 +709,10 @@ class SemanticScuttle_Service_Bookmark2Tag extends SemanticScuttle_DbService
|
|||
}
|
||||
|
||||
}
|
||||
|
||||
function cmp($a,$b)
|
||||
{
|
||||
return strcasecmp(utf8_deaccent($a["tag"]), utf8_deaccent($b["tag"]));
|
||||
}
|
||||
|
||||
?>
|
||||
|
|
|
@ -6,7 +6,7 @@
|
|||
|
||||
# Rewrite clean URLs onto real files
|
||||
<IfModule mod_rewrite.c>
|
||||
Options +FollowSymlinks
|
||||
Options -MultiViews +FollowSymlinks
|
||||
RewriteEngine On
|
||||
RewriteCond %{REQUEST_FILENAME}.php -f
|
||||
RewriteRule ^([^/.]+)/?(.*)$ /$1.php/$2 [QSA,L]
|
||||
|
|
Loading…
Reference in a new issue