Develop and Download Open Source Software

Browse Subversion Repository

Contents of /branches/ssh_chacha20poly1305/ttssh2/ttxssh/kex.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 6817 - (show annotations) (download) (as text)
Fri Jun 23 14:58:54 2017 UTC (6 years, 9 months ago) by maya
Original Path: trunk/ttssh2/ttxssh/kex.h
File MIME type: text/x-chdr
File size: 4051 byte(s)
関数を移動
1 /*
2 (C) 2011 TeraTerm Project
3 All rights reserved.
4
5 Redistribution and use in source and binary forms, with or without modification,
6 are permitted provided that the following conditions are met:
7
8 Redistributions of source code must retain the above copyright notice, this list of
9 conditions and the following disclaimer.
10
11 Redistributions in binary form must reproduce the above copyright notice, this list
12 of conditions and the following disclaimer in the documentation and/or other materials
13 provided with the distribution.
14
15 The name of Robert O'Callahan may not be used to endorse or promote products derived from
16 this software without specific prior written permission.
17
18 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' AND
19 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
21 THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
25 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
26 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29 #include "ttxssh.h"
30
31 #define GEX_GRP_MINSIZE 1024
32 #define GEX_GRP_MAXSIZE 8192
33
34 DH *dh_new_group1(void);
35 DH *dh_new_group14(void);
36 DH *dh_new_group15(void);
37 DH *dh_new_group16(void);
38 DH *dh_new_group17(void);
39 DH *dh_new_group18(void);
40 void dh_gen_key(PTInstVar pvar, DH *dh, int we_need /* bytes */ );
41 int dh_estimate(int bits);
42
43 unsigned char *kex_dh_hash(const EVP_MD *evp_md,
44 char *client_version_string,
45 char *server_version_string,
46 char *ckexinit, int ckexinitlen,
47 char *skexinit, int skexinitlen,
48 u_char *serverhostkeyblob, int sbloblen,
49 BIGNUM *client_dh_pub,
50 BIGNUM *server_dh_pub,
51 BIGNUM *shared_secret,
52 unsigned int *hashlen);
53 unsigned char *kex_dh_gex_hash(const EVP_MD *evp_md,
54 char *client_version_string,
55 char *server_version_string,
56 char *ckexinit, int ckexinitlen,
57 char *skexinit, int skexinitlen,
58 u_char *serverhostkeyblob, int sbloblen,
59 int kexgex_min,
60 int kexgex_bits,
61 int kexgex_max,
62 BIGNUM *kexgex_p,
63 BIGNUM *kexgex_g,
64 BIGNUM *client_dh_pub,
65 BIGNUM *server_dh_pub,
66 BIGNUM *shared_secret,
67 unsigned int *hashlen);
68 unsigned char *kex_ecdh_hash(const EVP_MD *evp_md,
69 const EC_GROUP *ec_group,
70 char *client_version_string,
71 char *server_version_string,
72 char *ckexinit, int ckexinitlen,
73 char *skexinit, int skexinitlen,
74 u_char *serverhostkeyblob, int sbloblen,
75 const EC_POINT *client_dh_pub,
76 const EC_POINT *server_dh_pub,
77 BIGNUM *shared_secret,
78 unsigned int *hashlen);
79
80 int dh_pub_is_valid(DH *dh, BIGNUM *dh_pub);
81 void kex_derive_keys(PTInstVar pvar, int need, u_char *hash, BIGNUM *shared_secret,
82 char *session_id, int session_id_len);

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26