summaryrefslogtreecommitdiff
path: root/source/pdf/pdf-crypt.c
diff options
context:
space:
mode:
authorRobin Watts <robin.watts@artifex.com>2017-02-22 16:01:44 +0000
committerRobin Watts <robin.watts@artifex.com>2017-02-23 11:19:00 +0000
commit840ee1d02e7a723e9781d385ed3c6bc853ab5aa7 (patch)
treed4aad6f3d8becf9c82994fd60c9fa77a3206ebf8 /source/pdf/pdf-crypt.c
parent6477d336520e3278b56a39c4fd98f220522cb962 (diff)
downloadmupdf-840ee1d02e7a723e9781d385ed3c6bc853ab5aa7.tar.xz
Improve return codes from pdf_authenticate_password.
Customer request to enable finer control based on which password authenticates.
Diffstat (limited to 'source/pdf/pdf-crypt.c')
-rw-r--r--source/pdf/pdf-crypt.c39
1 files changed, 24 insertions, 15 deletions
diff --git a/source/pdf/pdf-crypt.c b/source/pdf/pdf-crypt.c
index 1499e39e..aad7324e 100644
--- a/source/pdf/pdf-crypt.c
+++ b/source/pdf/pdf-crypt.c
@@ -759,25 +759,34 @@ int
pdf_authenticate_password(fz_context *ctx, pdf_document *doc, const char *pwd_utf8)
{
char password[2048];
+ int auth;
- if (doc->crypt)
+ if (!doc->crypt)
+ return 1; /* No password required */
+
+ password[0] = 0;
+ if (pwd_utf8)
{
- password[0] = 0;
- if (pwd_utf8)
- {
- if (doc->crypt->r <= 4)
- pdf_docenc_from_utf8(password, pwd_utf8, sizeof password);
- else
- pdf_saslprep_from_utf8(password, pwd_utf8, sizeof password);
- }
+ if (doc->crypt->r <= 4)
+ pdf_docenc_from_utf8(password, pwd_utf8, sizeof password);
+ else
+ pdf_saslprep_from_utf8(password, pwd_utf8, sizeof password);
+ }
- if (pdf_authenticate_user_password(ctx, doc->crypt, (unsigned char *)password, strlen(password)))
- return 1;
- if (pdf_authenticate_owner_password(ctx, doc->crypt, (unsigned char *)password, strlen(password)))
- return 1;
- return 0;
+ auth = 0;
+ if (pdf_authenticate_user_password(ctx, doc->crypt, (unsigned char *)password, strlen(password)))
+ auth = 2;
+ if (pdf_authenticate_owner_password(ctx, doc->crypt, (unsigned char *)password, strlen(password)))
+ auth |= 4;
+ else if (auth & 2)
+ {
+ /* We need to reauthenticate the user password,
+ * because the failed attempt to authenticate
+ * the owner password will have invalidated the
+ * stored keys. */
+ (void)pdf_authenticate_user_password(ctx, doc->crypt, (unsigned char *)password, strlen(password));
}
- return 1;
+ return auth;
}
int