Mercurial > dovecot > core-2.2
view src/lib-sasl/mech-plain.c @ 22633:9284bdc3c5c5
director: Don't recreate timeout on every user lookup
Recreate it only when the timeout should change.
author | Timo Sirainen <timo.sirainen@dovecot.fi> |
---|---|
date | Sat, 04 Nov 2017 01:34:02 +0200 |
parents | 2e2563132d5f |
children | cb108f786fb4 |
line wrap: on
line source
/* Copyright (c) 2013-2017 Dovecot authors, see the included COPYING file */ #include "lib.h" #include "str.h" #include "dsasl-client-private.h" struct plain_dsasl_client { struct dsasl_client client; bool output_sent; }; static int mech_plain_input(struct dsasl_client *_client, const unsigned char *input ATTR_UNUSED, unsigned int input_len, const char **error_r) { struct plain_dsasl_client *client = (struct plain_dsasl_client *)_client; if (!client->output_sent) { if (input_len > 0) { *error_r = "Server sent non-empty initial response"; return -1; } } else { *error_r = "Server didn't finish authentication"; return -1; } return 0; } static int mech_plain_output(struct dsasl_client *_client, const unsigned char **output_r, unsigned int *output_len_r, const char **error_r) { struct plain_dsasl_client *client = (struct plain_dsasl_client *)_client; string_t *str; if (_client->set.authid == NULL) { *error_r = "authid not set"; return -1; } if (_client->password == NULL) { *error_r = "password not set"; return -1; } str = str_new(_client->pool, 64); if (_client->set.authzid != NULL) str_append(str, _client->set.authzid); str_append_c(str, '\0'); str_append(str, _client->set.authid); str_append_c(str, '\0'); str_append(str, _client->password); *output_r = str_data(str); *output_len_r = str_len(str); client->output_sent = TRUE; return 0; } const struct dsasl_client_mech dsasl_client_mech_plain = { .name = "PLAIN", .struct_size = sizeof(struct plain_dsasl_client), .input = mech_plain_input, .output = mech_plain_output };