Merge branch 'master' of git@github.com:yacy/yacy_search_server.git

pull/8/head
Michael Peter Christen 10 years ago
commit d524a9d77c

@ -16,7 +16,7 @@
<classpathentry kind="lib" path="lib/J7Zip-modified.jar"/> <classpathentry kind="lib" path="lib/J7Zip-modified.jar"/>
<classpathentry kind="lib" path="lib/webcat-0.1-swf.jar"/> <classpathentry kind="lib" path="lib/webcat-0.1-swf.jar"/>
<classpathentry kind="lib" path="lib/commons-jxpath-1.3.jar"/> <classpathentry kind="lib" path="lib/commons-jxpath-1.3.jar"/>
<classpathentry kind="lib" path="lib/jsch-0.1.51.jar"/> <classpathentry kind="lib" path="lib/jsch-0.1.52.jar"/>
<classpathentry kind="lib" path="lib/jakarta-oro-2.0.8.jar"/> <classpathentry kind="lib" path="lib/jakarta-oro-2.0.8.jar"/>
<classpathentry kind="lib" path="lib/apache-mime4j-0.6.jar"/> <classpathentry kind="lib" path="lib/apache-mime4j-0.6.jar"/>
<classpathentry kind="lib" path="lib/commons-fileupload-1.3.1.jar"/> <classpathentry kind="lib" path="lib/commons-fileupload-1.3.1.jar"/>

@ -201,7 +201,7 @@
<pathelement location="${lib}/jetty-util-9.2.10.v20150310.jar" /> <pathelement location="${lib}/jetty-util-9.2.10.v20150310.jar" />
<pathelement location="${lib}/jetty-webapp-9.2.10.v20150310.jar" /> <pathelement location="${lib}/jetty-webapp-9.2.10.v20150310.jar" />
<pathelement location="${lib}/jetty-xml-9.2.10.v20150310.jar" /> <pathelement location="${lib}/jetty-xml-9.2.10.v20150310.jar" />
<pathelement location="${lib}/jsch-0.1.51.jar" /> <pathelement location="${lib}/jsch-0.1.52.jar" />
<pathelement location="${lib}/json-simple-1.1.1.jar" /> <pathelement location="${lib}/json-simple-1.1.1.jar" />
<pathelement location="${lib}/jsoup-1.8.2.jar" /> <pathelement location="${lib}/jsoup-1.8.2.jar" />
<pathelement location="${lib}/log4j-over-slf4j-1.7.9.jar" /> <pathelement location="${lib}/log4j-over-slf4j-1.7.9.jar" />

@ -200,11 +200,8 @@ public class Bookmarks {
prop.put("mode_public", "0"); prop.put("mode_public", "0");
prop.put("mode_feed", "0"); prop.put("mode_feed", "0");
} else { } else {
BookmarksDB.Bookmark bookmark = null; BookmarksDB.Bookmark bookmark = sb.bookmarksDB.getBookmark(urlHash);
try {
bookmark = sb.bookmarksDB.getBookmark(urlHash);
} catch (final IOException e1) {
}
if (bookmark == null) { if (bookmark == null) {
// try to get the bookmark from the LURL database // try to get the bookmark from the LURL database
final URIMetadataNode urlentry = sb.index.fulltext().getMetadata(ASCII.getBytes(urlHash)); final URIMetadataNode urlentry = sb.index.fulltext().getMetadata(ASCII.getBytes(urlHash));
@ -324,11 +321,7 @@ public class Bookmarks {
count = 0; count = 0;
while(count < max_count && it.hasNext()) { while(count < max_count && it.hasNext()) {
Bookmark bookmark = null; Bookmark bookmark = bookmark = sb.bookmarksDB.getBookmark(it.next());
try {
bookmark = sb.bookmarksDB.getBookmark(it.next());
} catch (final IOException e) {
}
if (bookmark != null){ if (bookmark != null){
if (bookmark.getFeed() && isAdmin) { if (bookmark.getFeed() && isAdmin) {
@ -490,11 +483,7 @@ public class Bookmarks {
final Iterator<String> bit = sb.bookmarksDB.getBookmarksIterator(fn, isAdmin); final Iterator<String> bit = sb.bookmarksDB.getBookmarksIterator(fn, isAdmin);
while (bit.hasNext()) { while (bit.hasNext()) {
Bookmark bookmark = null; Bookmark bookmark = sb.bookmarksDB.getBookmark(bit.next());
try {
bookmark = sb.bookmarksDB.getBookmark(bit.next());
} catch (final IOException e) {
}
if (bookmark == null) break; if (bookmark == null) break;
prop.put("display_folderlist_" + count + "_folder", "<li><a href=\"" + bookmark.getUrl() + "\" title=\"" + bookmark.getDescription() + "\">" + bookmark.getTitle() + "</a></li>"); prop.put("display_folderlist_" + count + "_folder", "<li><a href=\"" + bookmark.getUrl() + "\" title=\"" + bookmark.getDescription() + "\">" + bookmark.getTitle() + "</a></li>");
count++; count++;

@ -1,6 +1,5 @@
import java.io.IOException;
import java.util.Date; import java.util.Date;
import java.util.Iterator; import java.util.Iterator;
@ -154,10 +153,9 @@ public class get_bookmarks {
total += count; total += count;
} }
count = 0; count = 0;
BookmarksDB.Bookmark bookmark = null;
while (count < itemsPerPage && it.hasNext()) { while (count < itemsPerPage && it.hasNext()) {
try {
bookmark = sb.bookmarksDB.getBookmark(it.next()); BookmarksDB.Bookmark bookmark = sb.bookmarksDB.getBookmark(it.next());
if (bookmark != null) { if (bookmark != null) {
prop.put("display_bookmarks_"+count+"_id",count); prop.put("display_bookmarks_"+count+"_id",count);
prop.put("display_bookmarks_"+count+"_link",bookmark.getUrl()); prop.put("display_bookmarks_"+count+"_link",bookmark.getUrl());
@ -187,8 +185,6 @@ public class get_bookmarks {
count++; count++;
} }
} catch (final IOException e) {
}
} }
// eliminate the trailing comma for Json output // eliminate the trailing comma for Json output
@ -251,11 +247,10 @@ public class get_bookmarks {
} }
private static int print_XBEL(final Iterator<String> bit, int count) { private static int print_XBEL(final Iterator<String> bit, int count) {
BookmarksDB.Bookmark bookmark = null;
Date date; Date date;
while(bit.hasNext()){ while(bit.hasNext()){
try { BookmarksDB.Bookmark bookmark = sb.bookmarksDB.getBookmark(bit.next());
bookmark = sb.bookmarksDB.getBookmark(bit.next()); if (bookmark != null) {
date = new Date(bookmark.getTimeStamp()); date = new Date(bookmark.getTimeStamp());
prop.put("display_xbel_"+count+"_elements", "<bookmark id=\"" + bookmark.getUrlHash() prop.put("display_xbel_"+count+"_elements", "<bookmark id=\"" + bookmark.getUrlHash()
+ "\" href=\"" + CharacterCoding.unicode2xml(bookmark.getUrl(), true) + "\" href=\"" + CharacterCoding.unicode2xml(bookmark.getUrl(), true)
@ -285,7 +280,6 @@ public class get_bookmarks {
count++; count++;
prop.put("display_xbel_"+count+"_elements", "</bookmark>"); prop.put("display_xbel_"+count+"_elements", "</bookmark>");
count++; count++;
} catch (final IOException e) {
} }
} }
return count; return count;

@ -1,6 +1,5 @@
import java.io.IOException;
import java.util.Iterator; import java.util.Iterator;
import net.yacy.cora.protocol.RequestHeader; import net.yacy.cora.protocol.RequestHeader;
import net.yacy.cora.util.CommonPattern; import net.yacy.cora.util.CommonPattern;
@ -72,10 +71,9 @@ public class get_folders {
// loop through bookmarkList // loop through bookmarkList
it = sb.bookmarksDB.getBookmarksIterator(root, isAdmin); it = sb.bookmarksDB.getBookmarksIterator(root, isAdmin);
BookmarksDB.Bookmark bm;
while (it.hasNext()) { while (it.hasNext()) {
try { BookmarksDB.Bookmark bm = sb.bookmarksDB.getBookmark(it.next());
bm = sb.bookmarksDB.getBookmark(it.next()); if (bm != null) {
// TODO: get rid of bmtype // TODO: get rid of bmtype
if (post.containsKey("bmtype")) { if (post.containsKey("bmtype")) {
if (post.get("bmtype").equals("title")) { if (post.get("bmtype").equals("title")) {
@ -93,7 +91,6 @@ public class get_folders {
prop.put("folders_"+count+"_hasChildren", "false"); prop.put("folders_"+count+"_hasChildren", "false");
prop.put("folders_"+count+"_comma", ","); prop.put("folders_"+count+"_comma", ",");
count++; count++;
} catch (final IOException e) {
} }
} }

@ -1,5 +1,4 @@
import java.io.IOException;
import java.util.Date; import java.util.Date;
import java.util.Iterator; import java.util.Iterator;
@ -29,11 +28,10 @@ public class all {
final boolean extendedXML = (post != null && post.containsKey("extendedXML")); final boolean extendedXML = (post != null && post.containsKey("extendedXML"));
int count=0; int count=0;
BookmarksDB.Bookmark bookmark;
Date date; Date date;
while(it.hasNext()){ while(it.hasNext()){
try { BookmarksDB.Bookmark bookmark=switchboard.bookmarksDB.getBookmark(it.next());
bookmark=switchboard.bookmarksDB.getBookmark(it.next()); if (bookmark != null) {
prop.putXML("posts_"+count+"_url", bookmark.getUrl()); prop.putXML("posts_"+count+"_url", bookmark.getUrl());
prop.putXML("posts_"+count+"_title", bookmark.getTitle()); prop.putXML("posts_"+count+"_title", bookmark.getTitle());
prop.putXML("posts_"+count+"_description", bookmark.getDescription()); prop.putXML("posts_"+count+"_description", bookmark.getDescription());
@ -48,7 +46,6 @@ public class all {
prop.put("posts_"+count+"_isExtended_private", Boolean.toString(!bookmark.getPublic())); prop.put("posts_"+count+"_isExtended_private", Boolean.toString(!bookmark.getPublic()));
} }
count++; count++;
} catch (final IOException e) {
} }
} }
prop.put("posts", count); prop.put("posts", count);

@ -1,6 +1,5 @@
import java.io.IOException;
import java.text.ParseException; import java.text.ParseException;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -8,7 +7,7 @@ import java.util.List;
import net.yacy.cora.date.ISO8601Formatter; import net.yacy.cora.date.ISO8601Formatter;
import net.yacy.cora.order.Digest; import net.yacy.cora.order.Digest;
import net.yacy.cora.protocol.RequestHeader; import net.yacy.cora.protocol.RequestHeader;
import net.yacy.data.BookmarksDB; import net.yacy.data.BookmarksDB.Bookmark;
import net.yacy.search.Switchboard; import net.yacy.search.Switchboard;
import net.yacy.server.serverObjects; import net.yacy.server.serverObjects;
import net.yacy.server.serverSwitch; import net.yacy.server.serverSwitch;
@ -45,10 +44,9 @@ public class get {
} }
final List<String> bookmark_hashes = switchboard.bookmarksDB.getDate(Long.toString(parsedDate.getTime())).getBookmarkList(); final List<String> bookmark_hashes = switchboard.bookmarksDB.getDate(Long.toString(parsedDate.getTime())).getBookmarkList();
BookmarksDB.Bookmark bookmark = null;
for (final String bookmark_hash : bookmark_hashes){ for (final String bookmark_hash : bookmark_hashes){
try { Bookmark bookmark = switchboard.bookmarksDB.getBookmark(bookmark_hash);
bookmark=switchboard.bookmarksDB.getBookmark(bookmark_hash); if (bookmark != null) {
if (ISO8601Formatter.FORMATTER.format(new Date(bookmark.getTimeStamp())).equals(date) && if (ISO8601Formatter.FORMATTER.format(new Date(bookmark.getTimeStamp())).equals(date) &&
tag==null || bookmark.getTags().contains(tag) && tag==null || bookmark.getTags().contains(tag) &&
isAdmin || bookmark.getPublic()){ isAdmin || bookmark.getPublic()){
@ -66,7 +64,6 @@ public class get {
} }
count++; count++;
} }
} catch (final IOException e) {
} }
} }
prop.put("posts", count); prop.put("posts", count);

@ -1,6 +1,4 @@
import java.io.IOException;
import net.yacy.cora.protocol.RequestHeader; import net.yacy.cora.protocol.RequestHeader;
import net.yacy.data.BookmarksDB.Bookmark; import net.yacy.data.BookmarksDB.Bookmark;
import net.yacy.search.Switchboard; import net.yacy.search.Switchboard;
@ -19,19 +17,18 @@ public class addTag_p {
prop.put("result", "0");//error prop.put("result", "0");//error
//rename tags //rename tags
if(post != null && isAdmin) { if(post != null && isAdmin) {
if (post.containsKey("selectTag") && post.containsKey("addTag")) { if (post.containsKey("selectTag") && post.containsKey("addTag")) {
switchboard.bookmarksDB.addTag(post.get("selectTag"), post.get("addTag")); switchboard.bookmarksDB.addTag(post.get("selectTag"), post.get("addTag"));
prop.put("result", "1");//success prop.put("result", "1");//success
} else if (post.containsKey("urlhash") && post.containsKey("addTag")) { } else if (post.containsKey("urlhash") && post.containsKey("addTag")) {
Bookmark bm; Bookmark bm = switchboard.bookmarksDB.getBookmark(post.get("urlhash"));
try { if (bm != null) {
bm = switchboard.bookmarksDB.getBookmark(post.get("urlhash"));
bm.addTag(post.get("addTag")); bm.addTag(post.get("addTag"));
prop.put("result", "1");//success prop.put("result", "1");//success
} catch (final IOException e) { } else {
prop.put("result", "0");//success prop.put("result", "0");//success
} }
} }
} }
// return rewrite properties // return rewrite properties
return prop; return prop;

@ -1,6 +1,5 @@
import java.io.IOException;
import java.util.Date; import java.util.Date;
import java.util.Iterator; import java.util.Iterator;
@ -104,11 +103,10 @@ public class xbel {
return count; return count;
} }
private static int print_XBEL(final Iterator<String> bit, int count) { private static int print_XBEL(final Iterator<String> bit, int count) {
BookmarksDB.Bookmark bookmark;
Date date; Date date;
while(bit.hasNext()){ while(bit.hasNext()){
try { BookmarksDB.Bookmark bookmark=switchboard.bookmarksDB.getBookmark(bit.next());
bookmark=switchboard.bookmarksDB.getBookmark(bit.next()); if (bookmark != null) {
date=new Date(bookmark.getTimeStamp()); date=new Date(bookmark.getTimeStamp());
prop.put("xbel_"+count+"_elements", "<bookmark id=\"" + bookmark.getUrlHash() prop.put("xbel_"+count+"_elements", "<bookmark id=\"" + bookmark.getUrlHash()
+ "\" href=\"" + CharacterCoding.unicode2xml(bookmark.getUrl(), true) + "\" href=\"" + CharacterCoding.unicode2xml(bookmark.getUrl(), true)
@ -138,9 +136,8 @@ public class xbel {
count++; count++;
prop.put("xbel_"+count+"_elements", "</bookmark>"); prop.put("xbel_"+count+"_elements", "</bookmark>");
count++; count++;
} catch (final IOException e) {
} }
} }
return count; return count;
} }
} }

@ -16,7 +16,7 @@ import net.yacy.cora.document.encoding.UTF8;
import net.yacy.cora.protocol.ClientIdentification; import net.yacy.cora.protocol.ClientIdentification;
import net.yacy.cora.protocol.RequestHeader; import net.yacy.cora.protocol.RequestHeader;
import net.yacy.cora.util.ConcurrentLog; import net.yacy.cora.util.ConcurrentLog;
import net.yacy.data.BookmarksDB; import net.yacy.data.BookmarksDB.Bookmark;
import net.yacy.data.UserDB; import net.yacy.data.UserDB;
import net.yacy.data.WorkTables; import net.yacy.data.WorkTables;
import net.yacy.data.ymark.MonitoredReader; import net.yacy.data.ymark.MonitoredReader;
@ -173,10 +173,9 @@ public class import_ymark {
return prop; return prop;
} }
final Iterator<String> bit=sb.bookmarksDB.getBookmarksIterator(isAdmin); final Iterator<String> bit=sb.bookmarksDB.getBookmarksIterator(isAdmin);
BookmarksDB.Bookmark bookmark;
while(bit.hasNext()){ while(bit.hasNext()){
try { Bookmark bookmark=sb.bookmarksDB.getBookmark(bit.next());
bookmark=sb.bookmarksDB.getBookmark(bit.next()); if (bookmark != null) {
final YMarkEntry bmk_entry = new YMarkEntry(false); final YMarkEntry bmk_entry = new YMarkEntry(false);
bmk_entry.put(YMarkEntry.BOOKMARK.URL.key(), bookmark.getUrl()); bmk_entry.put(YMarkEntry.BOOKMARK.URL.key(), bookmark.getUrl());
try { try {
@ -197,7 +196,6 @@ public class import_ymark {
} catch (final IOException e) { } catch (final IOException e) {
ConcurrentLog.logException(e); ConcurrentLog.logException(e);
} }
} catch (final IOException e1) {
} }
} }
} else if(post.containsKey("importer") && post.get("importer").equals("dmoz")) { } else if(post.containsKey("importer") && post.get("importer").equals("dmoz")) {

@ -24,7 +24,6 @@
// along with this program; if not, write to the Free Software // along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
import java.io.IOException;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import java.util.Collection; import java.util.Collection;
import java.util.Date; import java.util.Date;
@ -137,11 +136,8 @@ public class yacysearchitem {
final String urlhash = ASCII.String(result.hash()); final String urlhash = ASCII.String(result.hash());
if (authenticated) { // only needed if authorized if (authenticated) { // only needed if authorized
boolean bookmarkexists; boolean bookmarkexists;
try { // check url exists in bookkmarks // check url exists in bookkmarks
bookmarkexists = sb.bookmarksDB.getBookmark(urlhash) != null; bookmarkexists = sb.bookmarksDB.getBookmark(urlhash) != null;
} catch (IOException ex) {
bookmarkexists = false;
}
prop.put("content_authorized_bookmark", !bookmarkexists); prop.put("content_authorized_bookmark", !bookmarkexists);
// bookmark icon check for YMarks // bookmark icon check for YMarks
//prop.put("content_authorized_bookmark", sb.tables.bookmarks.hasBookmark("admin", urlhash) ? "0" : "1"); //prop.put("content_authorized_bookmark", sb.tables.bookmarks.hasBookmark("admin", urlhash) ? "0" : "1");

@ -83,7 +83,7 @@
<compilation-unit> <compilation-unit>
<package-root>source</package-root> <package-root>source</package-root>
<package-root>htroot</package-root> <package-root>htroot</package-root>
<classpath mode="compile">lib/J7Zip-modified.jar;lib/apache-mime4j-0.6.jar;lib/bcmail-jdk15-1.46.jar;lib/bcprov-jdk15-1.46.jar;lib/chardet.jar;lib/commons-codec-1.10.jar;lib/commons-compress-1.9.jar;lib/commons-fileupload-1.3.1.jar;lib/commons-io-2.4.jar;lib/commons-jxpath-1.3.jar;lib/commons-lang-2.6.jar;lib/commons-logging-1.2.jar;lib/fontbox-1.8.9.jar;lib/geronimo-stax-api_1.0_spec-1.0.1.jar;lib/guava-18.0.jar;lib/htmllexer.jar;lib/httpclient-4.4.jar;lib/httpcore-4.4.1.jar;lib/httpmime-4.4.jar;lib/icu4j-core.jar;lib/jakarta-oro-2.0.8.jar;lib/jaudiotagger-2.0.4-20111207.115108-15.jar;lib/javax.servlet-api-3.1.0.jar;lib/jcifs-1.3.17.jar;lib/jcl-over-slf4j-1.7.9.jar;lib/jempbox-1.8.9.jar;lib/jetty-client-9.2.10.v20150310.jar;lib/jetty-continuation-9.2.10.v20150310.jar;lib/jetty-deploy-9.2.10.v20150310.jar;lib/jetty-http-9.2.10.v20150310.jar;lib/jetty-io-9.2.10.v20150310.jar;lib/jetty-jmx-9.2.10.v20150310.jar;lib/jetty-proxy-9.2.10.v20150310.jar;lib/jetty-security-9.2.10.v20150310.jar;lib/jetty-server-9.2.10.v20150310.jar;lib/jetty-servlet-9.2.10.v20150310.jar;lib/jetty-servlets-9.2.10.v20150310.jar;lib/jetty-util-9.2.10.v20150310.jar;lib/jetty-webapp-9.2.10.v20150310.jar;lib/jetty-xml-9.2.10.v20150310.jar;lib/jsch-0.1.51.jar;lib/json-simple-1.1.1.jar;lib/jsoup-1.8.2.jar;lib/log4j-over-slf4j-1.7.9.jar;lib/lucene-analyzers-common-4.10.3.jar;lib/lucene-analyzers-phonetic-4.10.3.jar;lib/lucene-classification-4.10.3.jar;lib/lucene-codecs-4.10.3.jar;lib/lucene-core-4.10.3.jar;lib/lucene-facet-4.10.3.jar;lib/lucene-grouping-4.10.3.jar;lib/lucene-highlighter-4.10.3.jar;lib/lucene-join-4.10.3.jar;lib/lucene-memory-4.10.3.jar;lib/lucene-misc-4.10.3.jar;lib/lucene-queries-4.10.3.jar;lib/lucene-queryparser-4.10.3.jar;lib/lucene-spatial-4.10.3.jar;lib/lucene-suggest-4.10.3.jar;lib/metadata-extractor-2.8.1.jar;lib/noggit-0.5.jar;lib/org.restlet.jar;lib/pdfbox-1.8.9.jar;lib/poi-3.11-20141221.jar;lib/poi-scratchpad-3.11-20141221.jar;lib/slf4j-api-1.7.9.jar;lib/slf4j-jdk14-1.7.9.jar;lib/solr-core-4.10.3.jar;lib/solr-solrj-4.10.3.jar;lib/spatial4j-0.4.1.jar;lib/webcat-0.1-swf.jar;lib/weupnp-0.1.2.jar;lib/wstx-asl-3.2.9.jar;lib/xercesImpl.jar;lib/xml-apis.jar;lib/xmpcore-5.1.2.jar;lib/zookeeper-3.4.6.jar</classpath> <classpath mode="compile">lib/J7Zip-modified.jar;lib/apache-mime4j-0.6.jar;lib/bcmail-jdk15-1.46.jar;lib/bcprov-jdk15-1.46.jar;lib/chardet.jar;lib/commons-codec-1.10.jar;lib/commons-compress-1.9.jar;lib/commons-fileupload-1.3.1.jar;lib/commons-io-2.4.jar;lib/commons-jxpath-1.3.jar;lib/commons-lang-2.6.jar;lib/commons-logging-1.2.jar;lib/fontbox-1.8.9.jar;lib/geronimo-stax-api_1.0_spec-1.0.1.jar;lib/guava-18.0.jar;lib/htmllexer.jar;lib/httpclient-4.4.jar;lib/httpcore-4.4.1.jar;lib/httpmime-4.4.jar;lib/icu4j-core.jar;lib/jakarta-oro-2.0.8.jar;lib/jaudiotagger-2.0.4-20111207.115108-15.jar;lib/javax.servlet-api-3.1.0.jar;lib/jcifs-1.3.17.jar;lib/jcl-over-slf4j-1.7.9.jar;lib/jempbox-1.8.9.jar;lib/jetty-client-9.2.10.v20150310.jar;lib/jetty-continuation-9.2.10.v20150310.jar;lib/jetty-deploy-9.2.10.v20150310.jar;lib/jetty-http-9.2.10.v20150310.jar;lib/jetty-io-9.2.10.v20150310.jar;lib/jetty-jmx-9.2.10.v20150310.jar;lib/jetty-proxy-9.2.10.v20150310.jar;lib/jetty-security-9.2.10.v20150310.jar;lib/jetty-server-9.2.10.v20150310.jar;lib/jetty-servlet-9.2.10.v20150310.jar;lib/jetty-servlets-9.2.10.v20150310.jar;lib/jetty-util-9.2.10.v20150310.jar;lib/jetty-webapp-9.2.10.v20150310.jar;lib/jetty-xml-9.2.10.v20150310.jar;lib/jsch-0.1.52.jar;lib/json-simple-1.1.1.jar;lib/jsoup-1.8.2.jar;lib/log4j-over-slf4j-1.7.9.jar;lib/lucene-analyzers-common-4.10.3.jar;lib/lucene-analyzers-phonetic-4.10.3.jar;lib/lucene-classification-4.10.3.jar;lib/lucene-codecs-4.10.3.jar;lib/lucene-core-4.10.3.jar;lib/lucene-facet-4.10.3.jar;lib/lucene-grouping-4.10.3.jar;lib/lucene-highlighter-4.10.3.jar;lib/lucene-join-4.10.3.jar;lib/lucene-memory-4.10.3.jar;lib/lucene-misc-4.10.3.jar;lib/lucene-queries-4.10.3.jar;lib/lucene-queryparser-4.10.3.jar;lib/lucene-spatial-4.10.3.jar;lib/lucene-suggest-4.10.3.jar;lib/metadata-extractor-2.8.1.jar;lib/noggit-0.5.jar;lib/org.restlet.jar;lib/pdfbox-1.8.9.jar;lib/poi-3.11-20141221.jar;lib/poi-scratchpad-3.11-20141221.jar;lib/slf4j-api-1.7.9.jar;lib/slf4j-jdk14-1.7.9.jar;lib/solr-core-4.10.3.jar;lib/solr-solrj-4.10.3.jar;lib/spatial4j-0.4.1.jar;lib/webcat-0.1-swf.jar;lib/weupnp-0.1.2.jar;lib/wstx-asl-3.2.9.jar;lib/xercesImpl.jar;lib/xml-apis.jar;lib/xmpcore-5.1.2.jar;lib/zookeeper-3.4.6.jar</classpath>
<built-to>lib/yacycore.jar</built-to> <built-to>lib/yacycore.jar</built-to>
<source-level>1.7</source-level> <source-level>1.7</source-level>
</compilation-unit> </compilation-unit>

@ -431,7 +431,7 @@
<dependency> <dependency>
<groupId>com.jcraft</groupId> <groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId> <artifactId>jsch</artifactId>
<version>0.1.51</version> <version>0.1.52</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.googlecode.json-simple</groupId> <groupId>com.googlecode.json-simple</groupId>

@ -134,14 +134,9 @@ public class BookmarksDB {
*/ */
public Bookmark createorgetBookmark(final String url, final String user){ public Bookmark createorgetBookmark(final String url, final String user){
if (url == null || url.isEmpty()) return null; if (url == null || url.isEmpty()) return null;
Bookmark bk;
try { try {
try { DigestURL durl = new DigestURL((url.indexOf("://") < 0) ? "http://" + url : url);
DigestURL durl = new DigestURL((url.indexOf("://") < 0) ? "http://" + url : url); Bookmark bk = this.getBookmark(ASCII.String(durl.hash()));
bk = this.getBookmark(ASCII.String(durl.hash()));
} catch (IOException ex) {
bk = null;
}
if (bk == null) { if (bk == null) {
bk = new Bookmark(url); bk = new Bookmark(url);
} }
@ -166,21 +161,28 @@ public class BookmarksDB {
} }
} }
public Bookmark getBookmark(final String urlHash) throws IOException { /**
* Get bookmark for urlHash
* @param urlHash
* @return bookmark or null if not exist
*/
public Bookmark getBookmark(final String urlHash) {
try { try {
final Map<String, String> map = this.bookmarks.get(ASCII.getBytes(urlHash)); final Map<String, String> map = this.bookmarks.get(ASCII.getBytes(urlHash));
if (map == null) throw new IOException("cannot get bookmark for url hash " + urlHash); if (map == null) {
return new Bookmark(map); ConcurrentLog.info("BOOKMARKS", "cannot get bookmark for url hash " + urlHash);
return null;
} else {
return new Bookmark(map);
}
} catch (final Throwable e) { } catch (final Throwable e) {
throw new IOException(e.getMessage()); return null;
} }
} }
public boolean removeBookmark(final String urlHash){ public boolean removeBookmark(final String urlHash){
Bookmark bookmark; Bookmark bookmark = getBookmark(urlHash);
try { if (bookmark == null) {
bookmark = getBookmark(urlHash);
} catch (final IOException e1) {
return false; return false;
} }
final Set<String> tagSet = bookmark.getTags(); final Set<String> tagSet = bookmark.getTags();
@ -193,10 +195,9 @@ public class BookmarksDB {
putTag(tag); putTag(tag);
} }
} }
Bookmark b; Bookmark b = getBookmark(urlHash);
try { try {
b = getBookmark(urlHash); if (b != null) this.bookmarks.delete(ASCII.getBytes(urlHash));
this.bookmarks.delete(ASCII.getBytes(urlHash));
} catch (final IOException e) { } catch (final IOException e) {
b = null; b = null;
} }
@ -241,12 +242,9 @@ public class BookmarksDB {
for (byte[] hash: hashes) set.add(ASCII.String(hash)); for (byte[] hash: hashes) set.add(ASCII.String(hash));
} else { } else {
for (byte[] hash: hashes) { for (byte[] hash: hashes) {
try { Bookmark bm = getBookmark(ASCII.String(hash));
Bookmark bm = getBookmark(ASCII.String(hash)); if (bm != null && bm.getPublic()) {
if (bm != null && bm.getPublic()) { set.add(bm.getUrlHash());
set.add(bm.getUrlHash());
}
} catch (final IOException e) {
} }
} }
} }
@ -322,24 +320,20 @@ public class BookmarksDB {
final TreeSet<Tag> set=new TreeSet<Tag>((comp == SORT_SIZE) ? tagSizeComparator : tagComparator); final TreeSet<Tag> set=new TreeSet<Tag>((comp == SORT_SIZE) ? tagSizeComparator : tagComparator);
Iterator<String> it=null; Iterator<String> it=null;
final Iterator<String> bit=getBookmarksIterator(tagName, priv); final Iterator<String> bit=getBookmarksIterator(tagName, priv);
Bookmark bm;
Tag tag; Tag tag;
Set<String> tagSet; Set<String> tagSet;
while (bit.hasNext()) { while (bit.hasNext()) {
try { Bookmark bm = getBookmark(bit.next());
bm = getBookmark(bit.next()); if (bm == null) continue;
if (bm == null) continue; tagSet = bm.getTags();
tagSet = bm.getTags(); it = tagSet.iterator();
it = tagSet.iterator(); while (it.hasNext()) {
while (it.hasNext()) { tag = getTag(BookmarkHelper.tagHash(it.next()));
tag=getTag(BookmarkHelper.tagHash(it.next()) ); if ((priv || tag.hasPublicItems()) && tag != null) {
if((priv ||tag.hasPublicItems()) && tag != null){ set.add(tag);
set.add(tag);
}
} }
} catch (final IOException e) {
} }
} }
return set.iterator(); return set.iterator();
} }
@ -367,18 +361,18 @@ public class BookmarksDB {
final RowHandleSet urlHashes = oldTag.getUrlHashes(); // preserve urlHashes of oldTag final RowHandleSet urlHashes = oldTag.getUrlHashes(); // preserve urlHashes of oldTag
removeTag(BookmarkHelper.tagHash(oldName)); // remove oldHash from TagsDB removeTag(BookmarkHelper.tagHash(oldName)); // remove oldHash from TagsDB
Bookmark bookmark;
Set<String> tagSet = new TreeSet<String>(String.CASE_INSENSITIVE_ORDER); Set<String> tagSet = new TreeSet<String>(String.CASE_INSENSITIVE_ORDER);
for (final byte[] urlHash : urlHashes) { // looping through all bookmarks which were tagged with oldName for (final byte[] urlHash : urlHashes) { // looping through all bookmarks which were tagged with oldName
try { Bookmark bookmark = getBookmark(ASCII.String(urlHash));
bookmark = getBookmark(ASCII.String(urlHash)); if (bookmark != null) {
tagSet = bookmark.getTags(); tagSet = bookmark.getTags();
tagSet.remove(oldName); tagSet.remove(oldName);
bookmark.setTags(tagSet, true); // might not be needed, but doesn't hurt bookmark.setTags(tagSet, true); // might not be needed, but doesn't hurt
if(!"".equals(newName)) bookmark.addTag(newName); if (!"".equals(newName)) {
bookmark.addTag(newName);
}
saveBookmark(bookmark); saveBookmark(bookmark);
} catch (final IOException e) { }
}
} }
return true; return true;
} }
@ -387,13 +381,11 @@ public class BookmarksDB {
public void addTag(final String selectTag, final String newTag) { public void addTag(final String selectTag, final String newTag) {
Bookmark bookmark; for (final byte[] urlHash : getTag(BookmarkHelper.tagHash(selectTag)).getUrlHashes()) { // looping through all bookmarks which were tagged with selectTag
for (final byte[] urlHash : getTag(BookmarkHelper.tagHash(selectTag)).getUrlHashes()) { // looping through all bookmarks which were tagged with selectTag Bookmark bookmark = getBookmark(ASCII.String(urlHash));
try { if (bookmark != null) {
bookmark = getBookmark(ASCII.String(urlHash));
bookmark.addTag(newTag); bookmark.addTag(newTag);
saveBookmark(bookmark); saveBookmark(bookmark);
} catch (final IOException e) {
} }
} }
} }
@ -487,15 +479,12 @@ public class BookmarksDB {
this.entry.put(BOOKMARK_URL, url.toNormalform(false)); this.entry.put(BOOKMARK_URL, url.toNormalform(false));
this.tagNames = new HashSet<String>(); this.tagNames = new HashSet<String>();
this.timestamp = System.currentTimeMillis(); this.timestamp = System.currentTimeMillis();
Bookmark oldBm;
try { Bookmark oldBm = getBookmark(this.urlHash);
oldBm = getBookmark(this.urlHash); if (oldBm != null && oldBm.entry.containsKey(BOOKMARK_TIMESTAMP)) {
if(oldBm!=null && oldBm.entry.containsKey(BOOKMARK_TIMESTAMP)){ this.entry.put(BOOKMARK_TIMESTAMP, oldBm.entry.get(BOOKMARK_TIMESTAMP)); //preserve timestamp on edit
this.entry.put(BOOKMARK_TIMESTAMP, oldBm.entry.get(BOOKMARK_TIMESTAMP)); //preserve timestamp on edit } else {
}else{ this.entry.put(BOOKMARK_TIMESTAMP, String.valueOf(System.currentTimeMillis()));
this.entry.put(BOOKMARK_TIMESTAMP, String.valueOf(System.currentTimeMillis()));
}
} catch (final IOException e) {
} }
final BookmarkDate.Entry bmDate=BookmarksDB.this.dates.getDate(this.entry.get(BOOKMARK_TIMESTAMP)); final BookmarkDate.Entry bmDate=BookmarksDB.this.dates.getDate(this.entry.get(BOOKMARK_TIMESTAMP));
bmDate.add(this.urlHash); bmDate.add(this.urlHash);
@ -706,12 +695,7 @@ public class BookmarksDB {
@Override @Override
public Bookmark next() { public Bookmark next() {
try { return getBookmark(UTF8.String(this.bookmarkIter.next()));
return getBookmark(UTF8.String(this.bookmarkIter.next()));
} catch (final IOException e) {
this.bookmarkIter.remove();
return null;
}
} }
@Override @Override
@ -736,19 +720,16 @@ public class BookmarksDB {
@Override @Override
public int compare(final String obj1, final String obj2) { public int compare(final String obj1, final String obj2) {
try { Bookmark bm1 = getBookmark(obj1);
Bookmark bm1 = getBookmark(obj1); Bookmark bm2 = getBookmark(obj2);
Bookmark bm2 = getBookmark(obj2); if (bm1 == null || bm2 == null) {
if (bm1 == null || bm2 == null) { return 0; //XXX: i think this should not happen? maybe this needs further tracing of the bug
return 0; //XXX: i think this should not happen? maybe this needs further tracing of the bug }
} if (this.newestFirst){
if (this.newestFirst){ if (bm2.getTimeStamp() - bm1.getTimeStamp() >0) return 1;
if (bm2.getTimeStamp() - bm1.getTimeStamp() >0) return 1; return -1;
return -1;
}
if (bm1.getTimeStamp() - bm2.getTimeStamp() > 0) return 1;
} catch (final IOException e) {
} }
if (bm1.getTimeStamp() - bm2.getTimeStamp() > 0) return 1;
return -1; return -1;
} }
} }

@ -17,7 +17,7 @@
<pathelement location="${build}" /> <pathelement location="${build}" />
<!-- main lib needed to parse rss/atom feed files --> <!-- main lib needed to parse rss/atom feed files -->
<pathelement location="${lib}/jsch-0.1.21.jar" /> <pathelement location="${lib}/jsch-0.1.52.jar" />
</classpath> </classpath>
</javac> </javac>
</target> </target>
@ -26,7 +26,7 @@
<target name="zip" depends="compile"> <target name="zip" depends="compile">
<tar destfile="${parserArchive}" compression="gzip"> <tar destfile="${parserArchive}" compression="gzip">
<tarfileset dir="${lib}" <tarfileset dir="${lib}"
includes="jsch-0.1.21.*" includes="jsch-0.1.52.*"
prefix="${releaseDir}/lib/" prefix="${releaseDir}/lib/"
dirmode="755" mode="644"/> dirmode="755" mode="644"/>
<tarfileset dir="${src}/net/yacy/peers/operation/" <tarfileset dir="${src}/net/yacy/peers/operation/"

Loading…
Cancel
Save