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
40 // ============================================================================
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 everytime 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 everytime 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 occured 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;
92 // ============================================================================
94 /** Helper that asks for a document password and checks its validity.
96 class COMPHELPER_DLLPUBLIC DocPasswordHelper
99 // ------------------------------------------------------------------------
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
);
116 // ------------------------------------------------------------------------
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 sal_Bool
IsModifyPasswordCorrect(
133 const OUString
& aPassword
,
134 const ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::PropertyValue
>& aInfo
);
137 // ------------------------------------------------------------------------
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
);
152 // ------------------------------------------------------------------------
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
);
173 // ------------------------------------------------------------------------
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
);
194 // ------------------------------------------------------------------------
196 /** This helper function generates a random sequence of bytes of
200 static ::com::sun::star::uno::Sequence
< sal_Int8
> GenerateRandomByteSequence(
203 // ------------------------------------------------------------------------
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
);
213 // ------------------------------------------------------------------------
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 // ------------------------------------------------------------------------
225 /** This helper function tries to request and verify a password to load a
228 First, the list of default passwords will be tried if provided. This is
229 needed by import filters for external file formats that have to check a
230 predefined password in some cases without asking the user for a
231 password. Every password is checked using the passed password verifier.
233 If not successful, the passed password of a medium is tried, that has
234 been set e.g. by an API call to load a document. If existing, the
235 password is checked using the passed password verifier.
237 If still not successful, the passed interaction handler is used to
238 request a password from the user. This will be repeated until the
239 passed password verifier validates the entered password, or if the user
240 chooses to cancel password input.
243 The password verifier used to check every processed password.
245 @param rMediaPassword
246 If not empty, will be passed to the password validator before
247 requesting a password from the user. This password usually should
248 be querried from a media descriptor.
250 @param rxInteractHandler
251 The interaction handler that will be used to request a password
252 from the user, e.g. by showing a password input dialog.
255 The name of the related document that will be shown in the password
259 The password request type that will be passed to the
260 DocPasswordRequest object created internally. See
261 docpasswordrequest.hxx for more details.
263 @param pDefaultPasswords
264 If not null, contains default passwords that will be tried before a
265 password will be requested from the media descriptor or the user.
267 @param pbIsDefaultPassword
268 (output parameter) If not null, the type of the found password will
269 be returned. True means the password has been found in the passed
270 list of default passwords. False means the password has been taken
271 from the rMediaPassword parameter or has been entered by the user.
274 If not empty, contains the password that has been validated by the
275 passed password verifier. If empty, no valid password has been
276 found, or the user has chossen to cancel password input.
278 static ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::NamedValue
> requestAndVerifyDocPassword(
279 IDocPasswordVerifier
& rVerifier
,
280 const ::com::sun::star::uno::Sequence
< ::com::sun::star::beans::NamedValue
>& rMediaEncData
,
281 const OUString
& rMediaPassword
,
282 const ::com::sun::star::uno::Reference
<
283 ::com::sun::star::task::XInteractionHandler
>& rxInteractHandler
,
284 const OUString
& rDocumentName
,
285 DocPasswordRequestType eRequestType
,
286 const ::std::vector
< OUString
>* pDefaultPasswords
= 0,
287 bool* pbIsDefaultPassword
= 0 );
290 ~DocPasswordHelper();
293 // ============================================================================
295 } // namespace comphelper
299 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */