1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
/* $Id: authsaslclientcramsha1.c,v 1.3 2005/02/21 03:34:19 mrsam Exp $ */
/*
** Copyright 2000 Double Precision, Inc. See COPYING for
** distribution information.
*/
#include "courier_auth_config.h"
#include "courierauthsasl.h"
#if HAVE_HMACLIB
#include "libhmac/hmac.h"
#endif
#include "authsaslclient.h"
#include <stdlib.h>
#include <stdio.h>
#include <ctype.h>
#include <string.h>
#include <errno.h>
#if HAVE_HMACLIB
extern int authsaslclient_cram(const struct authsaslclientinfo *,
const char *,
const struct hmac_hashinfo *);
int authsaslclient_cramsha1(const struct authsaslclientinfo *info)
{
const char *p=(*info->start_conv_func)("CRAM-SHA1", NULL, info->conv_func_arg);
if (!p) return (AUTHSASL_CANCELLED);
return ( authsaslclient_cram(info, p, &hmac_sha1));
}
int authsaslclient_cramsha256(const struct authsaslclientinfo *info)
{
const char *p=(*info->start_conv_func)("CRAM-SHA256", NULL,
info->conv_func_arg);
if (!p) return (AUTHSASL_CANCELLED);
return ( authsaslclient_cram(info, p, &hmac_sha256));
}
#else
int authsaslclient_cramsha1(const struct authsaslclientinfo *info)
{
return (AUTHSASL_NOMETHODS);
}
int authsaslclient_cramsha256(const struct authsaslclientinfo *info)
{
return (AUTHSASL_NOMETHODS);
}
#endif
|