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_RTL_CIPHER_H
21 #define INCLUDED_RTL_CIPHER_H
23 #include <sal/config.h>
25 #include <sal/saldllapi.h>
26 #include <sal/types.h>
32 /*========================================================================
34 * rtlCipher interface.
36 *======================================================================*/
37 /** Cipher Handle opaque type.
39 typedef void* rtlCipher
;
42 /** Cipher Algorithm enumeration.
43 @see rtl_cipher_create()
45 enum __rtl_CipherAlgorithm
47 rtl_Cipher_AlgorithmBF
,
48 rtl_Cipher_AlgorithmARCFOUR
,
49 rtl_Cipher_AlgorithmInvalid
,
50 rtl_Cipher_Algorithm_FORCE_EQUAL_SIZE
= SAL_MAX_ENUM
53 /** Cipher Algorithm type.
55 typedef enum __rtl_CipherAlgorithm rtlCipherAlgorithm
;
58 /** Cipher Mode enumeration.
59 @see rtl_cipher_create()
65 rtl_Cipher_ModeStream
,
66 rtl_Cipher_ModeInvalid
,
67 rtl_Cipher_Mode_FORCE_EQUAL_SIZE
= SAL_MAX_ENUM
72 typedef enum __rtl_CipherMode rtlCipherMode
;
75 /** Cipher Direction enumeration.
76 @see rtl_cipher_init()
78 enum __rtl_CipherDirection
80 rtl_Cipher_DirectionBoth
,
81 rtl_Cipher_DirectionDecode
,
82 rtl_Cipher_DirectionEncode
,
83 rtl_Cipher_DirectionInvalid
,
84 rtl_Cipher_Direction_FORCE_EQUAL_SIZE
= SAL_MAX_ENUM
87 /** Cipher Direction type.
89 typedef enum __rtl_CipherDirection rtlCipherDirection
;
92 /** Error Code enumeration.
94 enum __rtl_CipherError
97 rtl_Cipher_E_Argument
,
98 rtl_Cipher_E_Algorithm
,
99 rtl_Cipher_E_Direction
,
101 rtl_Cipher_E_BufferSize
,
103 rtl_Cipher_E_Unknown
,
104 rtl_Cipher_E_FORCE_EQUAL_SIZE
= SAL_MAX_ENUM
109 typedef enum __rtl_CipherError rtlCipherError
;
112 /** Create a cipher handle for the given algorithm and mode.
113 @see rtlCipherAlgorithm
116 @param Algorithm [in] cipher algorithm.
117 @param Mode [in] cipher mode.
118 @return Cipher handle, or 0 upon failure.
120 SAL_DLLPUBLIC rtlCipher SAL_CALL
rtl_cipher_create (
121 rtlCipherAlgorithm Algorithm
,
123 ) SAL_THROW_EXTERN_C();
126 /** Inititialize a cipher for the given direction.
127 @see rtlCipherDirection
129 @param Cipher [in] cipher handle.
130 @param Direction [in] cipher direction.
131 @param pKeyData [in] key material buffer.
132 @param nKeyLen [in] key material length in bytes.
133 @param pArgData [in] initialization vector buffer.
134 @param nArgLen [in] initialization vector length in bytes.
135 @return rtl_Cipher_E_None upon success.
137 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_init (
139 rtlCipherDirection Direction
,
140 const sal_uInt8
*pKeyData
, sal_Size nKeyLen
,
141 const sal_uInt8
*pArgData
, sal_Size nArgLen
142 ) SAL_THROW_EXTERN_C();
145 /** Encode a buffer under a given cipher algorithm.
146 @pre Initialized for a compatible cipher direction.
147 @see rtl_cipher_init()
149 @param Cipher [in] cipher handle.
150 @param pData [in] plaintext buffer.
151 @param nDatLen [in] plaintext length in bytes.
152 @param pBuffer [out] ciphertext buffer.
153 @param nBufLen [in] ciphertext length in bytes.
154 @return rtl_Cipher_E_None upon success.
156 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_encode (
158 const void *pData
, sal_Size nDatLen
,
159 sal_uInt8
*pBuffer
, sal_Size nBufLen
160 ) SAL_THROW_EXTERN_C();
163 /** Decode a buffer under a given cipher algorithm.
164 @pre Initialized for a compatible cipher direction.
165 @see rtl_cipher_init()
167 @param Cipher [in] cipher handle.
168 @param pData [in] ciphertext buffer.
169 @param nDatLen [in] ciphertext length in bytes.
170 @param pBuffer [out] plaintext buffer.
171 @param nBufLen [in] plaintext length in bytes.
172 @return rtl_Cipher_E_None upon success.
174 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_decode (
176 const void *pData
, sal_Size nDatLen
,
177 sal_uInt8
*pBuffer
, sal_Size nBufLen
178 ) SAL_THROW_EXTERN_C();
181 /** Destroy a cipher handle.
182 @param Cipher [in] cipher handle to be destroyed.
183 @return None. Cipher handle destroyed and invalid.
185 SAL_DLLPUBLIC
void SAL_CALL
rtl_cipher_destroy (
187 ) SAL_THROW_EXTERN_C();
190 /*========================================================================
192 * rtl_cipherBF (Blowfish) interface.
194 *======================================================================*/
195 /** Create a Blowfish cipher handle for the given mode.
197 The Blowfish block cipher algorithm is specified in
198 Bruce Schneier: Applied Cryptography, 2nd edition, ch. 14.3
200 @see rtl_cipher_create()
202 SAL_DLLPUBLIC rtlCipher SAL_CALL
rtl_cipher_createBF (
204 ) SAL_THROW_EXTERN_C();
207 /** Inititialize a Blowfish cipher for the given direction.
208 @see rtl_cipher_init()
210 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_initBF (
212 rtlCipherDirection Direction
,
213 const sal_uInt8
*pKeyData
, sal_Size nKeyLen
,
214 const sal_uInt8
*pArgData
, sal_Size nArgLen
215 ) SAL_THROW_EXTERN_C();
218 /** Encode a buffer under the Blowfish cipher algorithm.
219 @see rtl_cipher_encode()
221 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_encodeBF (
223 const void *pData
, sal_Size nDatLen
,
224 sal_uInt8
*pBuffer
, sal_Size nBufLen
225 ) SAL_THROW_EXTERN_C();
228 /** Decode a buffer under the Blowfish cipher algorithm.
229 @see rtl_cipher_decode()
231 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_decodeBF (
233 const void *pData
, sal_Size nDatLen
,
234 sal_uInt8
*pBuffer
, sal_Size nBufLen
235 ) SAL_THROW_EXTERN_C();
238 /** Destroy a Blowfish cipher handle.
239 @see rtl_cipher_destroy()
241 SAL_DLLPUBLIC
void SAL_CALL
rtl_cipher_destroyBF (
243 ) SAL_THROW_EXTERN_C();
246 /*========================================================================
248 * rtl_cipherARCFOUR (RC4) interface.
250 *======================================================================*/
251 /** Create a RC4 cipher handle for the given mode.
253 The RC4 symmetric stream cipher algorithm is specified in
254 Bruce Schneier: Applied Cryptography, 2nd edition, ch. 17.1
256 @see rtl_cipher_create()
258 @param Mode [in] cipher mode. Must be rtl_Cipher_ModeStream.
259 @return Cipher handle, or 0 upon failure.
261 SAL_DLLPUBLIC rtlCipher SAL_CALL
rtl_cipher_createARCFOUR (
263 ) SAL_THROW_EXTERN_C();
266 /** Inititialize a RC4 cipher for the given direction.
267 @see rtl_cipher_init()
269 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_initARCFOUR (
271 rtlCipherDirection Direction
,
272 const sal_uInt8
*pKeyData
, sal_Size nKeyLen
,
273 const sal_uInt8
*pArgData
, sal_Size nArgLen
274 ) SAL_THROW_EXTERN_C();
277 /** Encode a buffer under the RC4 cipher algorithm.
278 @see rtl_cipher_encode()
280 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_encodeARCFOUR (
282 const void *pData
, sal_Size nDatLen
,
283 sal_uInt8
*pBuffer
, sal_Size nBufLen
284 ) SAL_THROW_EXTERN_C();
287 /** Decode a buffer under the RC4 cipher algorithm.
288 @see rtl_cipher_decode()
290 SAL_DLLPUBLIC rtlCipherError SAL_CALL
rtl_cipher_decodeARCFOUR (
292 const void *pData
, sal_Size nDatLen
,
293 sal_uInt8
*pBuffer
, sal_Size nBufLen
294 ) SAL_THROW_EXTERN_C();
297 /** Destroy a RC4 cipher handle.
298 @see rtl_cipher_destroy()
300 SAL_DLLPUBLIC
void SAL_CALL
rtl_cipher_destroyARCFOUR (
302 ) SAL_THROW_EXTERN_C();
305 /*========================================================================
309 *======================================================================*/
315 #endif /* ! INCLUDED_RTL_CIPHER_H */
317 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */