1 |
pippijn |
1.1 |
/* |
2 |
pippijn |
1.3 |
* Copyright © 2006 Atheme Development Group |
3 |
pippijn |
1.2 |
* Rights to this code are as documented in doc/pod/license.pod. |
4 |
pippijn |
1.1 |
* |
5 |
|
|
* Data structures for SASL plugin use. |
6 |
|
|
* |
7 |
pippijn |
1.3 |
* $Id: sasl.h,v 1.2 2007-07-21 01:29:07 pippijn Exp $ |
8 |
pippijn |
1.1 |
*/ |
9 |
|
|
|
10 |
|
|
#ifndef SASL_H |
11 |
|
|
#define SASL_H |
12 |
|
|
|
13 |
|
|
struct sasl_mechanism_t; |
14 |
|
|
|
15 |
pippijn |
1.3 |
struct sasl_session_t : zero_initialised |
16 |
pippijn |
1.1 |
{ |
17 |
|
|
char uid[IDLEN]; |
18 |
|
|
char *buf, *p; |
19 |
|
|
int len, flags; |
20 |
|
|
|
21 |
|
|
sasl_mechanism_t *mechptr; |
22 |
|
|
void *mechdata; |
23 |
|
|
|
24 |
|
|
char *username; |
25 |
|
|
}; |
26 |
|
|
|
27 |
pippijn |
1.3 |
struct sasl_message_t : zero_initialised |
28 |
pippijn |
1.1 |
{ |
29 |
|
|
char *uid; |
30 |
|
|
char mode; |
31 |
|
|
char *buf; |
32 |
|
|
}; |
33 |
|
|
|
34 |
pippijn |
1.3 |
struct sasl_mechanism_t : zero_initialised |
35 |
pippijn |
1.1 |
{ |
36 |
pippijn |
1.3 |
char const *name; |
37 |
pippijn |
1.1 |
int (*mech_start) (sasl_session_t *sptr, char **buffer, int *buflen); |
38 |
|
|
int (*mech_step) (sasl_session_t *sptr, char *message, int length, char **buffer, int *buflen); |
39 |
|
|
void (*mech_finish) (sasl_session_t *sptr); |
40 |
pippijn |
1.3 |
|
41 |
|
|
sasl_mechanism_t (char const * const mechname, |
42 |
|
|
int (*start) (sasl_session_t *sptr, char **buffer, int *buflen), |
43 |
|
|
int (*step) (sasl_session_t *sptr, char *message, int length, char **buffer, int *buflen), |
44 |
|
|
void (*finish) (sasl_session_t *sptr)) |
45 |
|
|
: name (mechname), mech_start (start), mech_step (step), mech_finish (finish) |
46 |
|
|
{ |
47 |
|
|
} |
48 |
pippijn |
1.1 |
}; |
49 |
|
|
|
50 |
|
|
#define ASASL_FAIL 0 /* client supplied invalid credentials / screwed up their formatting */ |
51 |
|
|
#define ASASL_MORE 1 /* everything looks good so far, but we're not done yet */ |
52 |
|
|
#define ASASL_DONE 2 /* client successfully authenticated */ |
53 |
|
|
|
54 |
|
|
#define ASASL_MARKED_FOR_DELETION 1 /* see delete_stale() in saslserv/main.c */ |
55 |
|
|
#define ASASL_NEED_LOG 2 /* user auth success needs to be logged still */ |
56 |
|
|
|
57 |
|
|
#endif |