VirtualBox

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

最後變更 在這個檔案從18263是 11982,由 vboxsync 提交於 16 年 前

All: license header changes for 2.0 (OSE headers, add Sun GPL/LGPL disclaimer)

  • 屬性 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-2007
5 Copyright (C) Jay Sorg 2006-2007
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 2 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, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20*/
21
22/*
23 * Sun GPL Disclaimer: For the avoidance of doubt, except that if any license choice
24 * other than GPL or LGPL is available it will apply instead, Sun elects to use only
25 * the General Public License version 2 (GPLv2) at this time for any software where
26 * a choice of GPL license versions is made available with the language indicating
27 * that GPLv2 or any later version may be used, or where a choice of which version
28 * of the GPL is applied is otherwise unspecified.
29 */
30
31#ifndef _SSL_H
32#define _SSL_H
33
34#include <openssl/rc4.h>
35#include <openssl/md5.h>
36#include <openssl/sha.h>
37#include <openssl/bn.h>
38#include <openssl/x509v3.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
73#endif
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

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