From c5cab025cef52c171d913f1840a24ce93f483298 Mon Sep 17 00:00:00 2001 From: Bo Xu Date: Fri, 19 Sep 2014 19:16:31 -0700 Subject: Add FPDF_GetSecurityHandlerRevision Security handler revision number is needed to interpret file permission. BUG=None R=thestig@chromium.org Review URL: https://codereview.chromium.org/589813002 --- fpdfsdk/include/fpdfview.h | 10 ++++++++++ fpdfsdk/src/fpdfview.cpp | 11 +++++++++++ 2 files changed, 21 insertions(+) (limited to 'fpdfsdk') diff --git a/fpdfsdk/include/fpdfview.h b/fpdfsdk/include/fpdfview.h index 1b7ae2e251..4dcdcf620a 100644 --- a/fpdfsdk/include/fpdfview.h +++ b/fpdfsdk/include/fpdfview.h @@ -260,6 +260,16 @@ DLLEXPORT unsigned long STDCALL FPDF_GetLastError(); // DLLEXPORT unsigned long STDCALL FPDF_GetDocPermissions(FPDF_DOCUMENT document); +// Function: FPDF_GetSecurityHandlerRevision +// Get the revision for security handler. +// Parameters: +// document - Handle to document. Returned by FPDF_LoadDocument function. +// Return value: +// The security handler revision number. Please refer to PDF Reference for +// detailed description. If the document is not protected, -1 will be returned. +// +DLLEXPORT int STDCALL FPDF_GetSecurityHandlerRevision(FPDF_DOCUMENT document); + // Function: FPDF_GetPageCount // Get total number of pages in a document. // Parameters: diff --git a/fpdfsdk/src/fpdfview.cpp b/fpdfsdk/src/fpdfview.cpp index 70494e02a2..49dabe300b 100644 --- a/fpdfsdk/src/fpdfview.cpp +++ b/fpdfsdk/src/fpdfview.cpp @@ -340,6 +340,17 @@ DLLEXPORT unsigned long STDCALL FPDF_GetDocPermissions(FPDF_DOCUMENT document) return pDict->GetInteger("P"); } +DLLEXPORT int STDCALL FPDF_GetSecurityHandlerRevision(FPDF_DOCUMENT document) +{ + if (document == NULL) return -1; + CPDF_Document*pDoc = (CPDF_Document*)document; + CPDF_Parser* pParser = (CPDF_Parser*)pDoc->GetParser(); + CPDF_Dictionary* pDict = pParser->GetEncryptDict(); + if (pDict == NULL) return -1; + + return pDict->GetInteger("R"); +} + DLLEXPORT int STDCALL FPDF_GetPageCount(FPDF_DOCUMENT document) { if (document == NULL) return 0; -- cgit v1.2.3