VirtualBox

source: vbox/trunk/src/VBox/RDP/client/ssl.h@ 40598

最後變更 在這個檔案從40598是 37224,由 vboxsync 提交於 14 年 前

RDP/client: fix OSE

  • 屬性 svn:eol-style 設為 native
  • 屬性 svn:keywords 設為 Author Date Id Revision
檔案大小: 2.9 KB
 
1/* -*- c-basic-offset: 8 -*-
2 rdesktop: A Remote Desktop Protocol client.
3 Secure sockets abstraction layer
4 Copyright (C) Matthew Chapman 1999-2008
5 Copyright (C) Jay Sorg 2006-2008
6
7 This program is free software: you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>.
19*/
20
21/*
22 * Oracle GPL Disclaimer: For the avoidance of doubt, except that if any license choice
23 * other than GPL or LGPL is available it will apply instead, Oracle elects to use only
24 * the General Public License version 2 (GPLv2) at this time for any software where
25 * a choice of GPL license versions is made available with the language indicating
26 * that GPLv2 or any later version may be used, or where a choice of which version
27 * of the GPL is applied is otherwise unspecified.
28 */
29
30#ifndef _SSL_H
31#define _SSL_H
32
33#include <openssl/rc4.h>
34#include <openssl/md5.h>
35#include <openssl/sha.h>
36#include <openssl/bn.h>
37#include <openssl/x509v3.h>
38#include <openssl/hmac.h>
39
40#if defined(OPENSSL_VERSION_NUMBER) && (OPENSSL_VERSION_NUMBER >= 0x0090800f)
41#define D2I_X509_CONST const
42#else
43#define D2I_X509_CONST
44#endif
45
46#define SSL_RC4 RC4_KEY
47#define SSL_SHA1 SHA_CTX
48#define SSL_MD5 MD5_CTX
49#define SSL_CERT X509
50#define SSL_RKEY RSA
51
52void ssl_sha1_init(SSL_SHA1 * sha1);
53void ssl_sha1_update(SSL_SHA1 * sha1, uint8 * data, uint32 len);
54void ssl_sha1_final(SSL_SHA1 * sha1, uint8 * out_data);
55void ssl_md5_init(SSL_MD5 * md5);
56void ssl_md5_update(SSL_MD5 * md5, uint8 * data, uint32 len);
57void ssl_md5_final(SSL_MD5 * md5, uint8 * out_data);
58void ssl_rc4_set_key(SSL_RC4 * rc4, uint8 * key, uint32 len);
59void ssl_rc4_crypt(SSL_RC4 * rc4, uint8 * in_data, uint8 * out_data, uint32 len);
60void ssl_rsa_encrypt(uint8 * out, uint8 * in, int len, uint32 modulus_size, uint8 * modulus,
61 uint8 * exponent);
62SSL_CERT *ssl_cert_read(uint8 * data, uint32 len);
63void ssl_cert_free(SSL_CERT * cert);
64SSL_RKEY *ssl_cert_to_rkey(SSL_CERT * cert, uint32 * key_len);
65RD_BOOL ssl_certs_ok(SSL_CERT * server_cert, SSL_CERT * cacert);
66int ssl_cert_print_fp(FILE * fp, SSL_CERT * cert);
67void ssl_rkey_free(SSL_RKEY * rkey);
68int ssl_rkey_get_exp_mod(SSL_RKEY * rkey, uint8 * exponent, uint32 max_exp_len, uint8 * modulus,
69 uint32 max_mod_len);
70RD_BOOL ssl_sig_ok(uint8 * exponent, uint32 exp_len, uint8 * modulus, uint32 mod_len,
71 uint8 * signature, uint32 sig_len);
72
73void ssl_hmac_md5(const void *key, int key_len,
74 const unsigned char *msg, int msg_len, unsigned char *md);
75
76#endif
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette