Security News
GitHub Removes Malicious Pull Requests Targeting Open Source Repositories
GitHub removed 27 malicious pull requests attempting to inject harmful code across multiple open source repositories, in another round of low-effort attacks.
@conscia/tika
Advanced tools
Apache Tika bridge. Text extraction, metadata extraction, mimetype detection and language detection.
Provides text extraction, metadata extraction, mime-type detection, text-encoding detection and language detection. All via a native Java bridge with the Apache Tika content-analysis toolkit. Bundles Tika 1.21.
Depends on node-java, which itself requires the JDK and Python 2 (not 3) to compile.
Requires JDK 7. Run node version
to check the version that node-java
is using. If the wrong version is
reported even if you installed JDK 1.7, make sure JAVA_HOME
is set to the correct path then delete node_modules/java
and rerun npm install
.
var tika = require('tika');
var options = {
// Hint the content-type. This is optional but would help Tika choose a parser in some cases.
contentType: 'application/pdf'
};
tika.text('test/data/file.pdf', options, function(err, text) {
console.log(text);
});
We can even extract directly from the Web. If the server returns a content-type header, it will be passed to Tika as a hint.
tika.text('http://www.ohchr.org/EN/UDHR/Documents/UDHR_Translations/eng.pdf', function(err, text) {
// ...
});
Or extract text using OCR (requires Tesseract).
tika.text('test/data/ocr/simple.jpg', {
ocrLanguage: 'eng'
}, function(err, text) {
// ...
});
All methods that accept a uri
parameter accept relative or absolute file paths and http:
, https:
or ftp:
URLs.
The available options are the following.
contentType
to provide a hint to Tika on which parser to use.outputEncoding
to specify the text output encoding. Defaults to UTF-8.password
to set a password to be used for encrypted files.maxLength
to specify a max number of character to extract.ocrLanguage
to set the language used by Tesseract. This option is required to enable OCR.ocrPath
to set the path to the Tesseract binaries.ocrMaxFileSize
to set maximum file size in bytes to submit to OCR.ocrMinFileSize
to set minimum file size in bytes to submit to OCR.ocrPageSegmentationMode
to set the Tesseract page segmentation mode.ocrTimeout
to set the maximum time in seconds to wait for the Tesseract process to terminate.ocrStrategy
to set an OCR strategy — especially useful if you want to extract text in images in PDF (use ocr_only
in that case).ocrOutputType
to set the OCR output type (either txt
or hocr
).pdfAverageCharTolerance
see PDFTextStripper.setAverageCharTolerance(float)
.pdfEnableAutoSpace
to set whether the parser should estimate where spaces should be inserted between words (true
by default).pdfExtractAcroFormContent
to set whether content should be extracted from AcroForms at the end of the document (true
by default).pdfExtractAnnotationText
to set whether to extract text from annotations (true
by default).pdfExtractInlineImages
to set whether to extract inline embedded OBX images (true
by default).pdfExtractUniqueInlineImagesOnly
as multiple pages within a PDF file might refer to the same underlying image.pdfSortByPosition
to set whether to sort text tokens by their x/y position before extracting text.pdfSpacingTolerance
see PDFTextStripper.setSpacingTolerance(float)
.pdfSuppressDuplicateOverlappingText
to set whether the parse should try to remove duplicated text over the same region.Extract both text and metadata from a file.
tika.extract('test/data/file.pdf', function(err, text, meta) {
console.log(text); // Logs 'Just some text'.
console.log(meta.producer[0]); // Logs 'LibreOffice 4.1'.
});
Extract text from a file.
tika.text('test/data/file.pdf', function(err, text) {
console.log(text);
});
Get an XHTML representation of the text extracted from a file.
tika.xhtml('test/data/file.pdf', function(err, xhtml) {
console.log(xhtml);
});
Extract metadata from a file. Returns an object with names as keys and arrays as values.
tika.meta('test/data/file.pdf', function(err, meta) {
console.log(meta.producer[0]); // Logs 'LibreOffice 4.1'.
});
Detect the content-type (MIME type) of a file.
tika.type('test/data/file.pdf', function(err, contentType) {
console.log(contentType); // Logs 'application/pdf'.
});
Detect the character set (text encoding) of a file.
tika.charset('test/data/file.txt', function(err, charset) {
console.log(charset); // Logs 'ISO-8859-1'.
});
Detect the content-type and character set of a file.
The character set will be appended to the mime-type if available.
tika.typeAndCharset('test/data/file.txt', function(err, typeAndCharset) {
console.log(typeAndCharset); // Logs 'text/plain; charset=ISO-8859-1'.
});
Detect the language a given string is written in.
tika.language('This is just some text in English.', function(err, language, reasonablyCertain) {
console.log(language); // Logs 'en'.
console.log(reasonablyCertain); // Logs true or false.
});
Developed by Matthew Caruana Galizia at the ICIJ.
Please feel free to submit an issue or pull request. Don't forget to add your name to the CONTRIBUTORS
file.
Copyright (c) 2013 The Center for Public Integrity®. See LICENSE
.
Apache Tika JAR distributed under the Apache License, Version 2.0.
FAQs
Apache Tika bridge. Text extraction, metadata extraction, mimetype detection and language detection.
The npm package @conscia/tika receives a total of 23 weekly downloads. As such, @conscia/tika popularity was classified as not popular.
We found that @conscia/tika demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
GitHub removed 27 malicious pull requests attempting to inject harmful code across multiple open source repositories, in another round of low-effort attacks.
Security News
RubyGems.org has added a new "maintainer" role that allows for publishing new versions of gems. This new permission type is aimed at improving security for gem owners and the service overall.
Security News
Node.js will be enforcing stricter semver-major PR policies a month before major releases to enhance stability and ensure reliable release candidates.