|
|
|
@ -38,9 +38,6 @@ import java.util.List;
|
|
|
|
|
import jcifs.smb.SmbException;
|
|
|
|
|
import jcifs.smb.SmbFile;
|
|
|
|
|
import jcifs.smb.SmbFileInputStream;
|
|
|
|
|
|
|
|
|
|
import de.anomic.crawler.CrawlProfile;
|
|
|
|
|
|
|
|
|
|
import net.yacy.cora.document.Classification;
|
|
|
|
|
import net.yacy.cora.document.MultiProtocolURI;
|
|
|
|
|
import net.yacy.cora.protocol.HeaderFramework;
|
|
|
|
@ -53,6 +50,7 @@ import net.yacy.kelondro.logging.Log;
|
|
|
|
|
import net.yacy.kelondro.util.FileUtils;
|
|
|
|
|
import net.yacy.search.Switchboard;
|
|
|
|
|
import net.yacy.search.index.Segments;
|
|
|
|
|
import de.anomic.crawler.CrawlProfile;
|
|
|
|
|
|
|
|
|
|
public class SMBLoader {
|
|
|
|
|
|
|
|
|
@ -65,7 +63,7 @@ public class SMBLoader {
|
|
|
|
|
public SMBLoader(final Switchboard sb, final Log log) {
|
|
|
|
|
this.sb = sb;
|
|
|
|
|
this.log = log;
|
|
|
|
|
maxFileSize = sb.getConfigLong("crawler.smb.maxFileSize", -1l);
|
|
|
|
|
this.maxFileSize = sb.getConfigLong("crawler.smb.maxFileSize", -1l);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -75,7 +73,7 @@ public class SMBLoader {
|
|
|
|
|
|
|
|
|
|
RequestHeader requestHeader = new RequestHeader();
|
|
|
|
|
if (request.referrerhash() != null) {
|
|
|
|
|
DigestURI ur = sb.getURL(Segments.Process.LOCALCRAWLING, request.referrerhash());
|
|
|
|
|
DigestURI ur = this.sb.getURL(Segments.Process.LOCALCRAWLING, request.referrerhash());
|
|
|
|
|
if (ur != null) requestHeader.put(RequestHeader.REFERER, ur.toNormalform(true, false));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -109,13 +107,14 @@ public class SMBLoader {
|
|
|
|
|
ResponseHeader responseHeader = new ResponseHeader();
|
|
|
|
|
responseHeader.put(HeaderFramework.LAST_MODIFIED, HeaderFramework.formatRFC1123(new Date()));
|
|
|
|
|
responseHeader.put(HeaderFramework.CONTENT_TYPE, "text/html");
|
|
|
|
|
final CrawlProfile profile = sb.crawler.getActive(request.profileHandle().getBytes());
|
|
|
|
|
final CrawlProfile profile = this.sb.crawler.getActive(request.profileHandle().getBytes());
|
|
|
|
|
Response response = new Response(
|
|
|
|
|
request,
|
|
|
|
|
requestHeader,
|
|
|
|
|
responseHeader,
|
|
|
|
|
"200",
|
|
|
|
|
profile,
|
|
|
|
|
false,
|
|
|
|
|
content.toString().getBytes());
|
|
|
|
|
|
|
|
|
|
return response;
|
|
|
|
@ -137,25 +136,26 @@ public class SMBLoader {
|
|
|
|
|
}
|
|
|
|
|
String parserError = null;
|
|
|
|
|
if ((acceptOnlyParseable && (parserError = TextParser.supports(url, mime)) != null) ||
|
|
|
|
|
(size > maxFileSize && maxFileSize >= 0)) {
|
|
|
|
|
(size > this.maxFileSize && this.maxFileSize >= 0)) {
|
|
|
|
|
// we know that we cannot process that file before loading
|
|
|
|
|
// only the metadata is returned
|
|
|
|
|
|
|
|
|
|
if (parserError != null) {
|
|
|
|
|
log.logInfo("No parser available in SMB crawler: '" + parserError + "' for URL " + request.url().toString() + ": parsing only metadata");
|
|
|
|
|
this.log.logInfo("No parser available in SMB crawler: '" + parserError + "' for URL " + request.url().toString() + ": parsing only metadata");
|
|
|
|
|
} else {
|
|
|
|
|
log.logInfo("Too big file in SMB crawler with size = " + size + " Bytes for URL " + request.url().toString() + ": parsing only metadata");
|
|
|
|
|
this.log.logInfo("Too big file in SMB crawler with size = " + size + " Bytes for URL " + request.url().toString() + ": parsing only metadata");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// create response with metadata only
|
|
|
|
|
responseHeader.put(HeaderFramework.CONTENT_TYPE, "text/plain");
|
|
|
|
|
final CrawlProfile profile = sb.crawler.getActive(request.profileHandle().getBytes());
|
|
|
|
|
final CrawlProfile profile = this.sb.crawler.getActive(request.profileHandle().getBytes());
|
|
|
|
|
Response response = new Response(
|
|
|
|
|
request,
|
|
|
|
|
requestHeader,
|
|
|
|
|
responseHeader,
|
|
|
|
|
"200",
|
|
|
|
|
profile,
|
|
|
|
|
false,
|
|
|
|
|
url.toTokens().getBytes());
|
|
|
|
|
return response;
|
|
|
|
|
}
|
|
|
|
@ -166,13 +166,14 @@ public class SMBLoader {
|
|
|
|
|
is.close();
|
|
|
|
|
|
|
|
|
|
// create response with loaded content
|
|
|
|
|
final CrawlProfile profile = sb.crawler.getActive(request.profileHandle().getBytes());
|
|
|
|
|
final CrawlProfile profile = this.sb.crawler.getActive(request.profileHandle().getBytes());
|
|
|
|
|
Response response = new Response(
|
|
|
|
|
request,
|
|
|
|
|
requestHeader,
|
|
|
|
|
responseHeader,
|
|
|
|
|
"200",
|
|
|
|
|
profile,
|
|
|
|
|
false,
|
|
|
|
|
b);
|
|
|
|
|
return response;
|
|
|
|
|
}
|
|
|
|
|