updates.
[silc.git] / lib / silcclient / protocol.h
1 /*
2
3   protocol.h
4
5   Author: Pekka Riikonen <priikone@poseidon.pspt.fi>
6
7   Copyright (C) 1997 - 2000 Pekka Riikonen
8
9   This program is free software; you can redistribute it and/or modify
10   it under the terms of the GNU General Public License as published by
11   the Free Software Foundation; either version 2 of the License, or
12   (at your option) any later version.
13   
14   This program is distributed in the hope that it will be useful,
15   but WITHOUT ANY WARRANTY; without even the implied warranty of
16   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17   GNU General Public License for more details.
18
19 */
20
21 #ifndef PROTOCOL_H
22 #define PROTOCOL_H
23
24 /* SILC client protocol types */
25 #define SILC_PROTOCOL_CLIENT_NONE               0
26 #define SILC_PROTOCOL_CLIENT_CONNECTION_AUTH    1
27 #define SILC_PROTOCOL_CLIENT_KEY_EXCHANGE       2
28 /* #define SILC_PROTOCOL_CLIENT_MAX             255 */
29
30 /* Internal context for key exchange protocol */
31 typedef struct {
32   void *client;
33   SilcSocketConnection sock;
34   SilcRng rng;
35   int responder;
36
37   void *dest_id;                    /* Destination ID from packet */
38   SilcIdType dest_id_type;          /* Destination ID type */
39
40   SilcTask timeout_task;
41   SilcPacketContext *packet;
42
43   SilcSKESendPacketCb send_packet;  /* SKE's packet sending callback */
44   SilcSKE ske;                      /* The SKE object */
45   SilcSKEKeyMaterial *keymat;       /* The negotiated key material */
46   void *context;                    /* Internal context */
47 } SilcClientKEInternalContext;
48
49 /* Internal context for connection authentication protocol */
50 typedef struct {
51   void *client;
52   SilcSocketConnection sock;
53
54   /* SKE object from Key Exchange protocol. */
55   SilcSKE ske;
56
57   /* Auth method that must be used. This is resolved before this
58      connection authentication protocol is started. */
59   SilcProtocolAuthMeth auth_meth;
60
61   /* Destinations ID from KE protocol context */
62   void *dest_id;
63   SilcIdType dest_id_type;
64
65   /* Authentication data if we alreay know it. This is filled before
66      starting the protocol if we know the authentication data. Otherwise
67      these are and remain NULL. */
68   unsigned char *auth_data;
69   unsigned int auth_data_len;
70
71   SilcTask timeout_task;
72 } SilcClientConnAuthInternalContext;
73
74 /* Prototypes */
75 void silc_client_protocols_register(void);
76 void silc_client_protocols_unregister(void);
77 void silc_client_protocol_ke_send_packet(SilcSKE ske,
78                                          SilcBuffer packet,
79                                          SilcPacketType type,
80                                          void *context);
81 void silc_client_protocol_ke_set_keys(SilcSKE ske,
82                                       SilcSocketConnection sock,
83                                       SilcSKEKeyMaterial *keymat,
84                                       SilcCipher cipher,
85                                       SilcPKCS pkcs,
86                                       SilcHash hash,
87                                       SilcHmac hmac);
88
89 #endif