1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_COMPHELPER_DOCPASSWORDHELPER_HXX
21 #define INCLUDED_COMPHELPER_DOCPASSWORDHELPER_HXX
23 #include <com/sun/star/beans/NamedValue.hpp>
24 #include <comphelper/comphelperdllapi.h>
26 #include <comphelper/docpasswordrequest.hxx>
28 namespace com
{ namespace sun
{ namespace star
{ namespace task
{ class XInteractionHandler
; } } } }
29 namespace com
{ namespace sun
{ namespace star
{ namespace beans
{ struct PropertyValue
; } } } }
31 namespace comphelper
{
33 enum DocPasswordVerifierResult
35 DocPasswordVerifierResult_OK
,
36 DocPasswordVerifierResult_WRONG_PASSWORD
,
37 DocPasswordVerifierResult_ABORT
42 /** Base class for a password verifier used by the DocPasswordHelper class
45 Users have to implement the virtual functions and pass an instance of the
46 verifier to one of the password request functions.
48 class COMPHELPER_DLLPUBLIC IDocPasswordVerifier
51 virtual ~IDocPasswordVerifier();
53 /** Will be called every time a password needs to be verified.
56 The password to be verified
58 @param o_rEncryptionData
59 Output parameter, that is filled with the EncryptionData generated
60 from the password. The data is filled only if the validation was
63 @return The result of the verification.
64 - DocPasswordVerifierResult_OK, if and only if the passed password
65 is valid and can be used to process the related document.
66 - DocPasswordVerifierResult_WRONG_PASSWORD, if the password is
67 wrong. The user may be asked again for a new password.
68 - DocPasswordVerifierResult_ABORT, if an unrecoverable error
69 occurred while password verification. The password request loop
72 virtual DocPasswordVerifierResult
verifyPassword( const OUString
& rPassword
, ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::NamedValue
>& o_rEncryptionData
) = 0;
74 /** Will be called every time an encryption data needs to be verified.
76 @param rEncryptionData
77 The data will be validated
79 @return The result of the verification.
80 - DocPasswordVerifierResult_OK, if and only if the passed encryption data
81 is valid and can be used to process the related document.
82 - DocPasswordVerifierResult_WRONG_PASSWORD, if the encryption data is
84 - DocPasswordVerifierResult_ABORT, if an unrecoverable error
85 occurred while data verification. The password request loop
88 virtual DocPasswordVerifierResult
verifyEncryptionData( const ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::NamedValue
>& o_rEncryptionData
) = 0;
94 /** Helper that asks for a document password and checks its validity.
96 class COMPHELPER_DLLPUBLIC DocPasswordHelper
101 /** This helper function generates the information related
102 to "Password to modify" provided by user. The result
103 sequence contains the hash and the algorithm-related
107 The string for which the info should be generated
110 The sequence containing the hash and the algorithm-related info
113 static ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::PropertyValue
>
114 GenerateNewModifyPasswordInfo( const OUString
& aPassword
);
118 /** This helper function allows to check whether
119 the "Password to modify" provided by user is the correct one.
122 The string containing the provided password
125 The sequence containing the hash and the algorithm-info
128 <TRUE/> if the password is correct one
132 static bool IsModifyPasswordCorrect(
133 const OUString
& aPassword
,
134 const ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::PropertyValue
>& aInfo
);
139 /** This helper function generates the hash code based on the algorithm
140 specified by MS for "Password to modify" feature of Word.
143 The string for which the hash should be calculated
146 The hash represented by sal_uInt32
149 static sal_uInt32
GetWordHashAsUINT32(
150 const OUString
& aString
);
154 /** This helper function generates the hash code based on the algorithm
155 specified by MS for "Password to modify" and passwords related to
156 table protection of Excel.
159 The string for which the hash should be calculated
162 The encoding that should be used to generate the 8-bit string
163 before the hash is generated
166 The hash represented by sal_uInt16
169 static sal_uInt16
GetXLHashAsUINT16(
170 const OUString
& aString
,
171 rtl_TextEncoding nEnc
= RTL_TEXTENCODING_UTF8
);
175 /** This helper function generates the hash code based on the algorithm
176 specified by MS for "Password to modify" and passwords related to
180 The string for which the hash should be calculated
183 The encoding that should be used to generate the 8-bit string
184 before the hash is generated
187 The hash represented by sequence of bytes in BigEndian form
190 static ::com::sun::star::uno::Sequence
< sal_Int8
> GetXLHashAsSequence(
191 const OUString
& aString
,
192 rtl_TextEncoding nEnc
= RTL_TEXTENCODING_UTF8
);
196 /** This helper function generates a random sequence of bytes of
200 static ::com::sun::star::uno::Sequence
< sal_Int8
> GenerateRandomByteSequence(
205 /** This helper function generates a byte sequence representing the
206 key digest value used by MSCodec_Std97 codec.
209 static ::com::sun::star::uno::Sequence
< sal_Int8
> GenerateStd97Key(
210 const OUString
& aPassword
,
211 const ::com::sun::star::uno::Sequence
< sal_Int8
>& aDocId
);
215 /** This helper function generates a byte sequence representing the
216 key digest value used by MSCodec_Std97 codec.
219 static ::com::sun::star::uno::Sequence
< sal_Int8
> GenerateStd97Key(
220 const sal_uInt16 pPassData
[16],
221 const ::com::sun::star::uno::Sequence
< sal_Int8
>& aDocId
);
223 /** This helper function generates a byte sequence representing the
224 key digest value used by MSCodec_Std97 codec.
227 static ::com::sun::star::uno::Sequence
< sal_Int8
> GenerateStd97Key(
228 const sal_uInt16 pPassData
[16],
229 const sal_uInt8 pDocId
[16] );
233 /** This helper function tries to request and verify a password to load a
236 First, the list of default passwords will be tried if provided. This is
237 needed by import filters for external file formats that have to check a
238 predefined password in some cases without asking the user for a
239 password. Every password is checked using the passed password verifier.
241 If not successful, the passed password of a medium is tried, that has
242 been set e.g. by an API call to load a document. If existing, the
243 password is checked using the passed password verifier.
245 If still not successful, the passed interaction handler is used to
246 request a password from the user. This will be repeated until the
247 passed password verifier validates the entered password, or if the user
248 chooses to cancel password input.
251 The password verifier used to check every processed password.
253 @param rMediaPassword
254 If not empty, will be passed to the password validator before
255 requesting a password from the user. This password usually should
256 be querried from a media descriptor.
258 @param rxInteractHandler
259 The interaction handler that will be used to request a password
260 from the user, e.g. by showing a password input dialog.
263 The name of the related document that will be shown in the password
267 The password request type that will be passed to the
268 DocPasswordRequest object created internally. See
269 docpasswordrequest.hxx for more details.
271 @param pDefaultPasswords
272 If not null, contains default passwords that will be tried before a
273 password will be requested from the media descriptor or the user.
275 @param pbIsDefaultPassword
276 (output parameter) If not null, the type of the found password will
277 be returned. True means the password has been found in the passed
278 list of default passwords. False means the password has been taken
279 from the rMediaPassword parameter or has been entered by the user.
282 If not empty, contains the password that has been validated by the
283 passed password verifier. If empty, no valid password has been
284 found, or the user has chossen to cancel password input.
286 static ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::NamedValue
> requestAndVerifyDocPassword(
287 IDocPasswordVerifier
& rVerifier
,
288 const ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::NamedValue
>& rMediaEncData
,
289 const OUString
& rMediaPassword
,
290 const ::com::sun::star::uno::Reference
<
291 ::com::sun::star::task::XInteractionHandler
>& rxInteractHandler
,
292 const OUString
& rDocumentName
,
293 DocPasswordRequestType eRequestType
,
294 const ::std::vector
< OUString
>* pDefaultPasswords
= 0,
295 bool* pbIsDefaultPassword
= 0 );
298 ~DocPasswordHelper();
303 } // namespace comphelper
307 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */