diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 09:59:15 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 09:59:15 +0000 |
commit | 8de1ee1b2b676b0d07586f0752750dd6b0fb7511 (patch) | |
tree | dd46fd7dc3863045696cd0e48032d8a36fa0daf5 /g10/mdfilter.c | |
parent | Initial commit. (diff) | |
download | gnupg2-8de1ee1b2b676b0d07586f0752750dd6b0fb7511.tar.xz gnupg2-8de1ee1b2b676b0d07586f0752750dd6b0fb7511.zip |
Adding upstream version 2.2.27.upstream/2.2.27upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'g10/mdfilter.c')
-rw-r--r-- | g10/mdfilter.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/g10/mdfilter.c b/g10/mdfilter.c new file mode 100644 index 0000000..f3318f1 --- /dev/null +++ b/g10/mdfilter.c @@ -0,0 +1,73 @@ +/* mdfilter.c - filter data and calculate a message digest + * Copyright (C) 1998, 1999, 2000, 2001 Free Software Foundation, Inc. + * + * This file is part of GnuPG. + * + * GnuPG is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * GnuPG is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, see <https://www.gnu.org/licenses/>. + */ + +#include <config.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <errno.h> + +#include "gpg.h" +#include "../common/status.h" +#include "../common/iobuf.h" +#include "../common/util.h" +#include "filter.h" + + + +/**************** + * This filter is used to collect a message digest + */ +int +md_filter( void *opaque, int control, + IOBUF a, byte *buf, size_t *ret_len) +{ + size_t size = *ret_len; + md_filter_context_t *mfx = opaque; + int i, rc=0; + + if( control == IOBUFCTRL_UNDERFLOW ) { + if( mfx->maxbuf_size && size > mfx->maxbuf_size ) + size = mfx->maxbuf_size; + i = iobuf_read( a, buf, size ); + if( i == -1 ) i = 0; + if( i ) { + gcry_md_write(mfx->md, buf, i ); + if( mfx->md2 ) + gcry_md_write(mfx->md2, buf, i ); + } + else + rc = -1; /* eof */ + *ret_len = i; + } + else if( control == IOBUFCTRL_DESC ) + mem2str (buf, "md_filter", *ret_len); + return rc; +} + + +void +free_md_filter_context( md_filter_context_t *mfx ) +{ + gcry_md_close(mfx->md); + gcry_md_close(mfx->md2); + mfx->md = NULL; + mfx->md2 = NULL; + mfx->maxbuf_size = 0; +} |