bump product version to 4.2.0.1
[LibreOffice.git] / include / comphelper / docpasswordhelper.hxx
blob8c160fd32e1f8bc8fa5592589e97a4c67f10c76d
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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>
25 #include <vector>
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
43 below.
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
50 public:
51 virtual ~IDocPasswordVerifier();
53 /** Will be called everytime a password needs to be verified.
55 @param rPassword
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
61 successful.
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
70 will be aborted.
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
83 wrong.
84 - DocPasswordVerifierResult_ABORT, if an unrecoverable error
85 occured while data verification. The password request loop
86 will be aborted.
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
98 public:
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
104 info.
106 @param aString
107 The string for which the info should be generated
109 @return
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.
121 @param aString
122 The string containing the provided password
124 @param aInfo
125 The sequence containing the hash and the algorithm-info
127 @return
128 <TRUE/> if the password is correct one
129 <FALSE/> otherwise
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.
142 @param aString
143 The string for which the hash should be calculated
145 @return
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.
158 @param aString
159 The string for which the hash should be calculated
161 @param nEnc
162 The encoding that should be used to generate the 8-bit string
163 before the hash is generated
165 @return
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
177 table protection.
179 @param aString
180 The string for which the hash should be calculated
182 @param nEnc
183 The encoding that should be used to generate the 8-bit string
184 before the hash is generated
186 @return
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
197 requested length.
200 static ::com::sun::star::uno::Sequence< sal_Int8 > GenerateRandomByteSequence(
201 sal_Int32 nLength );
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
226 protected document.
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.
242 @param rVerifier
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.
254 @param rDocumentName
255 The name of the related document that will be shown in the password
256 input dialog.
258 @param eRequestType
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.
273 @return
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 );
289 private:
290 ~DocPasswordHelper();
293 // ============================================================================
295 } // namespace comphelper
297 #endif
299 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */