@pdftron/pdfnet-node-samples 10.9.0 → 10.10.0-beta
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{samples/AddImageTest → AddImageTest}/AddImageTest.js +115 -115
- package/{samples/AdvancedImagingTest → AdvancedImagingTest}/AdvancedImagingTest.js +78 -78
- package/{samples/AnnotationTest → AnnotationTest}/AnnotationTest.js +641 -641
- package/{samples/BookmarkTest → BookmarkTest}/BookmarkTest.js +219 -219
- package/{samples/CAD2PDFTest → CAD2PDFTest}/CAD2PDFTest.js +79 -79
- package/{samples/ContentReplacerTest → ContentReplacerTest}/ContentReplacerTest.js +75 -75
- package/{samples/ConvertPrintTest → ConvertPrintTest}/ConvertPrintTest.js +153 -153
- package/{samples/ConvertTest → ConvertTest}/ConvertTest.js +203 -203
- package/{samples/DataExtractionTest → DataExtractionTest}/DataExtractionTest.js +214 -214
- package/{samples/DigitalSignaturesTest → DigitalSignaturesTest}/DigitalSignaturesTest.js +622 -527
- package/{samples/DocumentCreationTest → DocumentCreationTest}/DocumentCreationTest.js +409 -409
- package/{samples/ElementBuilderTest → ElementBuilderTest}/ElementBuilderTest.js +513 -513
- package/{samples/ElementEditTest → ElementEditTest}/ElementEditTest.js +110 -110
- package/{samples/ElementReaderAdvTest → ElementReaderAdvTest}/ElementReaderAdvTest.js +305 -305
- package/{samples/ElementReaderTest → ElementReaderTest}/ElementReaderTest.js +77 -77
- package/{samples/EncTest → EncTest}/EncTest.js +175 -175
- package/{samples/FDFTest → FDFTest}/FDFTest.js +218 -218
- package/{samples/HTML2PDFTest → HTML2PDFTest}/HTML2PDFTest.js +164 -164
- package/{samples/HighlightsTest → HighlightsTest}/HighlightsTest.js +97 -97
- package/{samples/ImageExtractTest → ImageExtractTest}/ImageExtractTest.js +129 -129
- package/{samples/ImpositionTest → ImpositionTest}/ImpositionTest.js +86 -86
- package/{samples/InteractiveFormsTest → InteractiveFormsTest}/InteractiveFormsTest.js +381 -381
- package/{samples/JBIG2Test → JBIG2Test}/JBIG2Test.js +88 -88
- package/{samples/LicenseKey → LicenseKey}/LicenseKey.js +11 -11
- package/{samples/LogicalStructureTest → LogicalStructureTest}/LogicalStructureTest.js +250 -250
- package/{samples/OCRTest → OCRTest}/OCRTest.js +235 -235
- package/{samples/OfficeTemplateTest → OfficeTemplateTest}/OfficeTemplateTest.js +79 -79
- package/{samples/OfficeToPDFTest → OfficeToPDFTest}/OfficeToPDFTest.js +125 -125
- package/{samples/OptimizerTest → OptimizerTest}/OptimizerTest.js +191 -191
- package/{samples/PDF2HtmlTest → PDF2HtmlTest}/PDF2HtmlTest.js +123 -123
- package/{samples/PDF2OfficeTest → PDF2OfficeTest}/PDF2OfficeTest.js +158 -158
- package/{samples/PDFATest → PDFATest}/PDFATest.js +85 -85
- package/{samples/PDFDocMemoryTest → PDFDocMemoryTest}/PDFDocMemoryTest.js +84 -84
- package/{samples/PDFDrawTest → PDFDrawTest}/PDFDrawTest.js +305 -305
- package/{samples/PDFLayersTest → PDFLayersTest}/PDFLayersTest.js +294 -294
- package/{samples/PDFPackageTest → PDFPackageTest}/PDFPackageTest.js +111 -111
- package/{samples/PDFPageTest → PDFPageTest}/PDFPageTest.js +189 -189
- package/{samples/PDFRedactTest → PDFRedactTest}/PDFRedactTest.js +74 -74
- package/{samples/PageLabelsTest → PageLabelsTest}/PageLabelsTest.js +138 -138
- package/{samples/PatternTest → PatternTest}/PatternTest.js +226 -226
- package/{samples/RectTest → RectTest}/RectTest.js +40 -40
- package/{samples/SDFTest → SDFTest}/SDFTest.js +87 -87
- package/{samples/StamperTest → StamperTest}/StamperTest.js +255 -255
- package/{samples/TestFiles → TestFiles}/Misc-Fixed.pfa +1166 -1166
- package/{samples/TestFiles → TestFiles}/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +34 -34
- package/{samples/TestFiles → TestFiles}/form1_annots.xfdf +33 -33
- package/{samples/TestFiles → TestFiles}/form1_data.xfdf +139 -139
- package/{samples/TestFiles → TestFiles}/my_stream.txt +2310 -2310
- package/{samples/TestFiles → TestFiles}/tiger.svg +378 -378
- package/{samples/TextExtractTest → TextExtractTest}/TextExtractTest.js +286 -286
- package/{samples/TextSearchTest → TextSearchTest}/TextSearchTest.js +121 -121
- package/{samples/U3DTest → U3DTest}/U3DTest.js +104 -104
- package/{samples/UndoRedoTest → UndoRedoTest}/UndoRedoTest.js +101 -101
- package/{samples/UnicodeWriteTest → UnicodeWriteTest}/UnicodeWriteTest.js +173 -173
- package/{samples/WebViewerConvertTest → WebViewerConvertTest}/WebViewerConvertTest.js +135 -135
- package/legal.txt +632 -0
- package/license.pdf +0 -0
- package/package.json +20 -21
- package/readme.md +38 -13
- package/{samples/runall.bat → runall.bat} +12 -12
- package/{samples/runall.sh → runall.sh} +15 -15
- /package/{samples/TestFiles → TestFiles}/BusinessCardTemplate.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/Fishermen.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/Font_licenses.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/GlobalSignRootForTST.cer +0 -0
- /package/{samples/TestFiles → TestFiles}/License.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/NotoSans_with_hindi.ttf +0 -0
- /package/{samples/TestFiles → TestFiles}/Output/empty +0 -0
- /package/{samples/TestFiles → TestFiles}/SYH_Letter.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/TigerText.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/US061222892-a.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/butterfly.png +0 -0
- /package/{samples/TestFiles → TestFiles}/credit card numbers.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/dice.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/dice.u3d +0 -0
- /package/{samples/TestFiles → TestFiles}/doc_to_sign.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/factsheet_Arabic.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/financial.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/fish.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/font.ttf +0 -0
- /package/{samples/TestFiles → TestFiles}/form1.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/form1_data.fdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields-scanned-withfields.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields-scanned.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/grayscale.tif +0 -0
- /package/{samples/TestFiles → TestFiles}/hindi_sample_utf16le.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/imagemask.dat +0 -0
- /package/{samples/TestFiles → TestFiles}/logo_red.png +0 -0
- /package/{samples/TestFiles → TestFiles}/lorem_ipsum.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/multipage.tif +0 -0
- /package/{samples/TestFiles → TestFiles}/newsletter.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/newsletter.xod +0 -0
- /package/{samples/TestFiles → TestFiles}/numbered.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/op_blend_test.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/palm.jp2 +0 -0
- /package/{samples/TestFiles → TestFiles}/paragraphs_and_tables.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/pdfnet.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.bmp +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.cer +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.pfx +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron_smart_substitution.plugin +0 -0
- /package/{samples/TestFiles → TestFiles}/peppers.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/signature.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-emf.emf +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-excel_2007.xlsx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-outlook.msg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-powerpoint_2007.pptx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-publisher.pub +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-rtf.rtf +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-text.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-visio.vsd +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage.html +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage.mht +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/colorschememapping.xml +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/filelist.xml +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image001.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image002.png +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image003.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image004.emz +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image005.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image006.png +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image007.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/oledata.mso +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/themedata.thmx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-word_2007.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-xps.xps +0 -0
- /package/{samples/TestFiles → TestFiles}/table.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/tagged.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/the_rime_of_the_ancient_mariner.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/tiger.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified_approved.pdf +0 -0
|
@@ -1,85 +1,85 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
-
// Consult legal.txt regarding legal and license information.
|
|
4
|
-
//---------------------------------------------------------------------------------------
|
|
5
|
-
|
|
6
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
7
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
8
|
-
|
|
9
|
-
((exports) => {
|
|
10
|
-
|
|
11
|
-
exports.runPDFA = () => {
|
|
12
|
-
|
|
13
|
-
const printResults = async (pdfa, filename) => {
|
|
14
|
-
|
|
15
|
-
const errorCount = await pdfa.getErrorCount();
|
|
16
|
-
if (errorCount === 0) {
|
|
17
|
-
console.log(filename + ': OK.');
|
|
18
|
-
} else {
|
|
19
|
-
console.log(filename + ' is NOT a valid PDFA.');
|
|
20
|
-
for (let i = 0; i < errorCount; i++) {
|
|
21
|
-
const errorCode = await pdfa.getError(i);
|
|
22
|
-
const errorMsg = await PDFNet.PDFACompliance.getPDFAErrorMessage(errorCode);
|
|
23
|
-
console.log(' - e_PDFA ' + errorCode + ': ' + errorMsg + '.');
|
|
24
|
-
const numRefs = await pdfa.getRefObjCount(errorCode);
|
|
25
|
-
if (numRefs > 0) {
|
|
26
|
-
const objs = [];
|
|
27
|
-
for (let j = 0; j < numRefs; j++) {
|
|
28
|
-
const objRef = await pdfa.getRefObj(errorCode, j);
|
|
29
|
-
objs.push(objRef);
|
|
30
|
-
}
|
|
31
|
-
console.log(' Objects: ' + objs.join(', '));
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
console.log('');
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
//---------------------------------------------------------------------------------------
|
|
39
|
-
// The following sample illustrates how to parse and check if a PDF document meets the
|
|
40
|
-
// PDFA standard, using the PDFACompliance class object.
|
|
41
|
-
//---------------------------------------------------------------------------------------
|
|
42
|
-
const main = async () => {
|
|
43
|
-
const inputPath = '../TestFiles/';
|
|
44
|
-
const outputPath = inputPath + 'Output/';
|
|
45
|
-
await PDFNet.setColorManagement(); // Enable color management (required for PDFA validation).
|
|
46
|
-
|
|
47
|
-
//-----------------------------------------------------------
|
|
48
|
-
// Example 1: PDF/A Validation
|
|
49
|
-
//-----------------------------------------------------------
|
|
50
|
-
try {
|
|
51
|
-
const filename = 'newsletter.pdf';
|
|
52
|
-
/* The max_ref_objs parameter to the PDFACompliance constructor controls the maximum number
|
|
53
|
-
of object numbers that are collected for particular error codes. The default value is 10
|
|
54
|
-
in order to prevent spam. If you need all the object numbers, pass 0 for max_ref_objs. */
|
|
55
|
-
const pdfa = await PDFNet.PDFACompliance.createFromFile(false, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
|
|
56
|
-
await printResults(pdfa, filename);
|
|
57
|
-
} catch (err) {
|
|
58
|
-
console.log(err);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
//-----------------------------------------------------------
|
|
62
|
-
// Example 2: PDF/A Conversion
|
|
63
|
-
//-----------------------------------------------------------
|
|
64
|
-
try {
|
|
65
|
-
let filename = 'fish.pdf';
|
|
66
|
-
const pdfa = await PDFNet.PDFACompliance.createFromFile(true, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
|
|
67
|
-
filename = 'pdfa.pdf';
|
|
68
|
-
await pdfa.saveAsFromFileName(outputPath + filename);
|
|
69
|
-
|
|
70
|
-
// Re-validate the document after the conversion...
|
|
71
|
-
const comp = await PDFNet.PDFACompliance.createFromFile(false, outputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
|
|
72
|
-
await printResults(comp, filename);
|
|
73
|
-
} catch (err) {
|
|
74
|
-
console.log(err);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
console.log('PDFACompliance test completed.')
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
|
|
81
|
-
};
|
|
82
|
-
exports.runPDFA();
|
|
83
|
-
})(exports);
|
|
84
|
-
// eslint-disable-next-line spaced-comment
|
|
85
|
-
//# sourceURL=PDFATest.js
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
7
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
8
|
+
|
|
9
|
+
((exports) => {
|
|
10
|
+
|
|
11
|
+
exports.runPDFA = () => {
|
|
12
|
+
|
|
13
|
+
const printResults = async (pdfa, filename) => {
|
|
14
|
+
|
|
15
|
+
const errorCount = await pdfa.getErrorCount();
|
|
16
|
+
if (errorCount === 0) {
|
|
17
|
+
console.log(filename + ': OK.');
|
|
18
|
+
} else {
|
|
19
|
+
console.log(filename + ' is NOT a valid PDFA.');
|
|
20
|
+
for (let i = 0; i < errorCount; i++) {
|
|
21
|
+
const errorCode = await pdfa.getError(i);
|
|
22
|
+
const errorMsg = await PDFNet.PDFACompliance.getPDFAErrorMessage(errorCode);
|
|
23
|
+
console.log(' - e_PDFA ' + errorCode + ': ' + errorMsg + '.');
|
|
24
|
+
const numRefs = await pdfa.getRefObjCount(errorCode);
|
|
25
|
+
if (numRefs > 0) {
|
|
26
|
+
const objs = [];
|
|
27
|
+
for (let j = 0; j < numRefs; j++) {
|
|
28
|
+
const objRef = await pdfa.getRefObj(errorCode, j);
|
|
29
|
+
objs.push(objRef);
|
|
30
|
+
}
|
|
31
|
+
console.log(' Objects: ' + objs.join(', '));
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
console.log('');
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
//---------------------------------------------------------------------------------------
|
|
39
|
+
// The following sample illustrates how to parse and check if a PDF document meets the
|
|
40
|
+
// PDFA standard, using the PDFACompliance class object.
|
|
41
|
+
//---------------------------------------------------------------------------------------
|
|
42
|
+
const main = async () => {
|
|
43
|
+
const inputPath = '../TestFiles/';
|
|
44
|
+
const outputPath = inputPath + 'Output/';
|
|
45
|
+
await PDFNet.setColorManagement(); // Enable color management (required for PDFA validation).
|
|
46
|
+
|
|
47
|
+
//-----------------------------------------------------------
|
|
48
|
+
// Example 1: PDF/A Validation
|
|
49
|
+
//-----------------------------------------------------------
|
|
50
|
+
try {
|
|
51
|
+
const filename = 'newsletter.pdf';
|
|
52
|
+
/* The max_ref_objs parameter to the PDFACompliance constructor controls the maximum number
|
|
53
|
+
of object numbers that are collected for particular error codes. The default value is 10
|
|
54
|
+
in order to prevent spam. If you need all the object numbers, pass 0 for max_ref_objs. */
|
|
55
|
+
const pdfa = await PDFNet.PDFACompliance.createFromFile(false, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
|
|
56
|
+
await printResults(pdfa, filename);
|
|
57
|
+
} catch (err) {
|
|
58
|
+
console.log(err);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
//-----------------------------------------------------------
|
|
62
|
+
// Example 2: PDF/A Conversion
|
|
63
|
+
//-----------------------------------------------------------
|
|
64
|
+
try {
|
|
65
|
+
let filename = 'fish.pdf';
|
|
66
|
+
const pdfa = await PDFNet.PDFACompliance.createFromFile(true, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
|
|
67
|
+
filename = 'pdfa.pdf';
|
|
68
|
+
await pdfa.saveAsFromFileName(outputPath + filename);
|
|
69
|
+
|
|
70
|
+
// Re-validate the document after the conversion...
|
|
71
|
+
const comp = await PDFNet.PDFACompliance.createFromFile(false, outputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
|
|
72
|
+
await printResults(comp, filename);
|
|
73
|
+
} catch (err) {
|
|
74
|
+
console.log(err);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
console.log('PDFACompliance test completed.')
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
|
|
81
|
+
};
|
|
82
|
+
exports.runPDFA();
|
|
83
|
+
})(exports);
|
|
84
|
+
// eslint-disable-next-line spaced-comment
|
|
85
|
+
//# sourceURL=PDFATest.js
|
|
@@ -1,85 +1,85 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
-
// Consult legal.txt regarding legal and license information.
|
|
4
|
-
//---------------------------------------------------------------------------------------
|
|
5
|
-
|
|
6
|
-
const fs = require('fs');
|
|
7
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
8
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
9
|
-
|
|
10
|
-
((exports) => {
|
|
11
|
-
'use strict';
|
|
12
|
-
|
|
13
|
-
exports.runPDFDocMemoryTest = () => {
|
|
14
|
-
const main = async () => {
|
|
15
|
-
const outputPath = '../TestFiles/Output/';
|
|
16
|
-
|
|
17
|
-
// The following sample illustrates how to read/write a PDF document from/to
|
|
18
|
-
// a memory buffer. This is useful for applications that work with dynamic PDF
|
|
19
|
-
// documents that don't need to be saved/read from a disk.
|
|
20
|
-
try {
|
|
21
|
-
// Read a PDF document in a memory buffer.
|
|
22
|
-
const file = await PDFNet.Filter.createMappedFileFromUString('../TestFiles/tiger.pdf');
|
|
23
|
-
const file_sz = await file.mappedFileFileSize();
|
|
24
|
-
|
|
25
|
-
const file_reader = await PDFNet.FilterReader.create(file);
|
|
26
|
-
|
|
27
|
-
const mem = await file_reader.read(file_sz);
|
|
28
|
-
const doc = await PDFNet.PDFDoc.createFromBuffer(mem);
|
|
29
|
-
|
|
30
|
-
doc.initSecurityHandler();
|
|
31
|
-
const num_pages = await doc.getPageCount();
|
|
32
|
-
|
|
33
|
-
const writer = await PDFNet.ElementWriter.create();
|
|
34
|
-
const reader = await PDFNet.ElementReader.create();
|
|
35
|
-
|
|
36
|
-
// Create a duplicate of every page but copy only path objects
|
|
37
|
-
for (let i = 1; i <= num_pages; ++i) {
|
|
38
|
-
const itr = await doc.getPageIterator(2 * i - 1);
|
|
39
|
-
|
|
40
|
-
const cur_page = await itr.current();
|
|
41
|
-
reader.beginOnPage(cur_page);
|
|
42
|
-
const new_page = await doc.pageCreate(await cur_page.getMediaBox());
|
|
43
|
-
itr.next();
|
|
44
|
-
doc.pageInsert(itr, new_page);
|
|
45
|
-
|
|
46
|
-
writer.beginOnPage(new_page);
|
|
47
|
-
var element;
|
|
48
|
-
while (element = await reader.next()) { // Read page contents
|
|
49
|
-
writer.writeElement(element);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
await writer.end();
|
|
53
|
-
await reader.end();
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
doc.save(outputPath + 'doc_memory_edit.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
57
|
-
|
|
58
|
-
// Save the document to a memory buffer.
|
|
59
|
-
const docbuf = await doc.saveMemoryBuffer(PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
60
|
-
|
|
61
|
-
// Write the contents of the buffer to the disk
|
|
62
|
-
fs.appendFileSync(outputPath + 'doc_memory_edit.txt', docbuf);
|
|
63
|
-
|
|
64
|
-
let dataStr = ''
|
|
65
|
-
// Read some data from the file stored in memory
|
|
66
|
-
reader.beginOnPage(await doc.getPage(1));
|
|
67
|
-
while (element = await reader.next()) {
|
|
68
|
-
if (await element.getType() == PDFNet.Element.Type.e_path) dataStr += 'Path, ';
|
|
69
|
-
}
|
|
70
|
-
reader.end();
|
|
71
|
-
console.log(dataStr);
|
|
72
|
-
|
|
73
|
-
console.log('\nDone. Result saved in doc_memory_edit.pdf and doc_memory_edit.txt ...');
|
|
74
|
-
} catch (err) {
|
|
75
|
-
console.log(err);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
79
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
80
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
81
|
-
};
|
|
82
|
-
exports.runPDFDocMemoryTest();
|
|
83
|
-
})(exports);
|
|
84
|
-
// eslint-disable-next-line spaced-comment
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2024 by Apryse Software Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
const fs = require('fs');
|
|
7
|
+
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
8
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
9
|
+
|
|
10
|
+
((exports) => {
|
|
11
|
+
'use strict';
|
|
12
|
+
|
|
13
|
+
exports.runPDFDocMemoryTest = () => {
|
|
14
|
+
const main = async () => {
|
|
15
|
+
const outputPath = '../TestFiles/Output/';
|
|
16
|
+
|
|
17
|
+
// The following sample illustrates how to read/write a PDF document from/to
|
|
18
|
+
// a memory buffer. This is useful for applications that work with dynamic PDF
|
|
19
|
+
// documents that don't need to be saved/read from a disk.
|
|
20
|
+
try {
|
|
21
|
+
// Read a PDF document in a memory buffer.
|
|
22
|
+
const file = await PDFNet.Filter.createMappedFileFromUString('../TestFiles/tiger.pdf');
|
|
23
|
+
const file_sz = await file.mappedFileFileSize();
|
|
24
|
+
|
|
25
|
+
const file_reader = await PDFNet.FilterReader.create(file);
|
|
26
|
+
|
|
27
|
+
const mem = await file_reader.read(file_sz);
|
|
28
|
+
const doc = await PDFNet.PDFDoc.createFromBuffer(mem);
|
|
29
|
+
|
|
30
|
+
doc.initSecurityHandler();
|
|
31
|
+
const num_pages = await doc.getPageCount();
|
|
32
|
+
|
|
33
|
+
const writer = await PDFNet.ElementWriter.create();
|
|
34
|
+
const reader = await PDFNet.ElementReader.create();
|
|
35
|
+
|
|
36
|
+
// Create a duplicate of every page but copy only path objects
|
|
37
|
+
for (let i = 1; i <= num_pages; ++i) {
|
|
38
|
+
const itr = await doc.getPageIterator(2 * i - 1);
|
|
39
|
+
|
|
40
|
+
const cur_page = await itr.current();
|
|
41
|
+
reader.beginOnPage(cur_page);
|
|
42
|
+
const new_page = await doc.pageCreate(await cur_page.getMediaBox());
|
|
43
|
+
itr.next();
|
|
44
|
+
doc.pageInsert(itr, new_page);
|
|
45
|
+
|
|
46
|
+
writer.beginOnPage(new_page);
|
|
47
|
+
var element;
|
|
48
|
+
while (element = await reader.next()) { // Read page contents
|
|
49
|
+
writer.writeElement(element);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
await writer.end();
|
|
53
|
+
await reader.end();
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
doc.save(outputPath + 'doc_memory_edit.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
57
|
+
|
|
58
|
+
// Save the document to a memory buffer.
|
|
59
|
+
const docbuf = await doc.saveMemoryBuffer(PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
60
|
+
|
|
61
|
+
// Write the contents of the buffer to the disk
|
|
62
|
+
fs.appendFileSync(outputPath + 'doc_memory_edit.txt', docbuf);
|
|
63
|
+
|
|
64
|
+
let dataStr = ''
|
|
65
|
+
// Read some data from the file stored in memory
|
|
66
|
+
reader.beginOnPage(await doc.getPage(1));
|
|
67
|
+
while (element = await reader.next()) {
|
|
68
|
+
if (await element.getType() == PDFNet.Element.Type.e_path) dataStr += 'Path, ';
|
|
69
|
+
}
|
|
70
|
+
reader.end();
|
|
71
|
+
console.log(dataStr);
|
|
72
|
+
|
|
73
|
+
console.log('\nDone. Result saved in doc_memory_edit.pdf and doc_memory_edit.txt ...');
|
|
74
|
+
} catch (err) {
|
|
75
|
+
console.log(err);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
79
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
80
|
+
}).then(function(){ return PDFNet.shutdown(); });
|
|
81
|
+
};
|
|
82
|
+
exports.runPDFDocMemoryTest();
|
|
83
|
+
})(exports);
|
|
84
|
+
// eslint-disable-next-line spaced-comment
|
|
85
85
|
//# sourceURL=PDFDocMemoryTest.js
|