Added:
isc_buffer_base(b) (pointer)
isc_buffer_current(b) (pointer)
isc_buffer_active(b) (pointer)
isc_buffer_used(b) (pointer)
isc_buffer_length(b) (int)
isc_buffer_usedlength(b) (int)
isc_buffer_consumedlength(b) (int)
isc_buffer_remaininglength(b) (int)
isc_buffer_activelength(b) (int)
isc_buffer_availablelength(b) (int)
Removed:
ISC_BUFFER_USEDCOUNT(b)
ISC_BUFFER_AVAILABLECOUNT(b)
isc_buffer_type(b)
Changed names:
isc_buffer_used(b, r) ->
isc_buffer_usedregion(b, r)
isc_buffer_available(b, r) ->
isc_buffer_available_region(b, r)
isc_buffer_consumed(b, r) ->
isc_buffer_consumedregion(b, r)
isc_buffer_active(b, r) ->
isc_buffer_activeregion(b, r)
isc_buffer_remaining(b, r) ->
isc_buffer_remainingregion(b, r)
Buffer types were removed, so the ISC_BUFFERTYPE_*
macros are no more, and the type argument to
isc_buffer_init and isc_buffer_allocate were removed.
isc_buffer_putstr is now void (instead of isc_result_t)
and requires that the caller ensure that there
is enough available buffer space for the string.
99 lines
2.6 KiB
C
99 lines
2.6 KiB
C
#if defined(OPENSSL)
|
|
|
|
/*
|
|
* Portions Copyright (c) 1995-1998 by Network Associates, Inc.
|
|
*
|
|
* Permission to use, copy modify, and distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND NETWORK ASSOCIATES
|
|
* DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL
|
|
* NETWORK ASSOCIATES BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING
|
|
* FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
|
|
* NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
|
|
* WITH THE USE OR PERFORMANCE OF THE SOFTWARE.
|
|
*/
|
|
|
|
/*
|
|
* Principal Author: Brian Wellington
|
|
* $Id: opensslmd5_link.c,v 1.5 2000/04/27 00:02:58 tale Exp $
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <memory.h>
|
|
|
|
#include <isc/assertions.h>
|
|
#include <isc/buffer.h>
|
|
#include <isc/int.h>
|
|
#include <isc/region.h>
|
|
|
|
#include "dst_internal.h"
|
|
#include "dst_parse.h"
|
|
|
|
#include <openssl/crypto.h>
|
|
#include <openssl/bn.h>
|
|
#include <openssl/md5.h>
|
|
|
|
/*
|
|
* dst_s_md5
|
|
* Call MD5 functions to digest a block of data.
|
|
* There are three steps to signing, INIT (initialize structures),
|
|
* UPDATE (hash (more) data), FINAL (generate a digest). This
|
|
* routine performs one or more of these steps.
|
|
* Parameters
|
|
* mode DST_SIGMODE_{INIT_UPDATE_FINAL|ALL}
|
|
* context the context to use for this computation
|
|
* data data to be signed
|
|
* digest buffer to store digest
|
|
* mctx memory context for temporary allocations
|
|
* Returns
|
|
* ISC_R_SUCCESS Success
|
|
* !ISC_R_SUCCESS Failure
|
|
*/
|
|
isc_result_t
|
|
dst_s_md5(const unsigned int mode, void **context, isc_region_t *data,
|
|
isc_buffer_t *digest, isc_mem_t *mctx)
|
|
{
|
|
isc_region_t r;
|
|
MD5_CTX *ctx = NULL;
|
|
|
|
if (mode & DST_SIGMODE_INIT) {
|
|
ctx = (MD5_CTX *) isc_mem_get(mctx, sizeof(MD5_CTX));
|
|
if (ctx == NULL)
|
|
return (ISC_R_NOMEMORY);
|
|
}
|
|
else if (context != NULL)
|
|
ctx = (MD5_CTX *) *context;
|
|
REQUIRE (ctx != NULL);
|
|
|
|
if (mode & DST_SIGMODE_INIT)
|
|
MD5_Init(ctx);
|
|
|
|
if (mode & DST_SIGMODE_UPDATE)
|
|
MD5_Update(ctx, data->base, data->length);
|
|
|
|
if (mode & DST_SIGMODE_FINAL) {
|
|
isc_buffer_availableregion(digest, &r);
|
|
if (r.length < MD5_DIGEST_LENGTH)
|
|
return (ISC_R_NOSPACE);
|
|
|
|
MD5_Final(r.base, ctx);
|
|
isc_buffer_add(digest, MD5_DIGEST_LENGTH);
|
|
isc_mem_put(mctx, ctx, sizeof(MD5_CTX));
|
|
}
|
|
else
|
|
*context = ctx;
|
|
|
|
return (ISC_R_SUCCESS);
|
|
}
|
|
|
|
#endif
|