1
0
mirror of git://git.gnupg.org/gnupg.git synced 2024-11-04 20:38:50 +01:00
gnupg/g10/filter.h

162 lines
5.2 KiB
C
Raw Normal View History

1997-11-18 15:06:00 +01:00
/* filter.h
* Copyright (C) 1998, 1999, 2000, 2001, 2003,
* 2005 Free Software Foundation, Inc.
1997-11-18 15:06:00 +01:00
*
* This file is part of GnuPG.
1997-11-18 15:06:00 +01:00
*
* GnuPG is free software; you can redistribute it and/or modify
1997-11-18 15:06:00 +01:00
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* GnuPG is distributed in the hope that it will be useful,
1997-11-18 15:06:00 +01:00
* 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, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA.
1997-11-18 15:06:00 +01:00
*/
2002-06-29 15:46:34 +02:00
#ifndef G10_FILTER_H
#define G10_FILTER_H
2002-06-29 15:46:34 +02:00
#include "types.h"
#include "cipher.h"
1997-11-18 15:06:00 +01:00
typedef struct {
2002-06-29 15:46:34 +02:00
MD_HANDLE md; /* catch all */
MD_HANDLE md2; /* if we want to calculate an alternate hash */
1997-11-18 15:06:00 +01:00
size_t maxbuf_size;
} md_filter_context_t;
1997-11-21 15:53:57 +01:00
typedef struct {
/* these fields may be initialized */
int what; /* what kind of armor headers to write */
int only_keyblocks; /* skip all headers but ".... key block" */
const char *hdrlines; /* write these headerlines */
/* these fileds must be initialized to zero */
int no_openpgp_data; /* output flag: "No valid OpenPGP data found" */
/* the following fields must be initialized to zero */
int inp_checked; /* set if the input has been checked */
int inp_bypass; /* set if the input is not armored */
int in_cleartext; /* clear text message */
int not_dash_escaped; /* clear text is not dash escaped */
int hashes; /* detected hash algorithms */
int faked; /* we are faking a literal data packet */
int truncated; /* number of truncated lines */
int qp_detected;
int pgp2mode;
byte eol[3]; /* The end of line characters as a
zero-terminated string. Defaults
(eol[0]=='\0') to whatever the local
platform uses. */
byte *buffer; /* malloced buffer */
unsigned buffer_size; /* and size of this buffer */
unsigned buffer_len; /* used length of the buffer */
unsigned buffer_pos; /* read position */
1997-11-21 15:53:57 +01:00
byte radbuf[4];
int idx, idx2;
1997-11-21 15:53:57 +01:00
u32 crc;
int status; /* an internal state flag */
int cancel;
int any_data; /* any valid armored data seen */
int pending_lf; /* used together with faked */
1997-11-21 15:53:57 +01:00
} armor_filter_context_t;
2002-06-29 15:46:34 +02:00
struct unarmor_pump_s;
typedef struct unarmor_pump_s *UnarmorPump;
1997-11-18 15:06:00 +01:00
2002-06-29 15:46:34 +02:00
struct compress_filter_context_s {
1997-11-23 16:38:27 +01:00
int status;
void *opaque; /* (used for z_stream) */
byte *inbuf;
unsigned inbufsize;
byte *outbuf;
unsigned outbufsize;
1998-05-15 20:49:19 +02:00
int algo; /* compress algo */
int algo1hack;
int new_ctb;
2002-06-29 15:46:34 +02:00
void (*release)(struct compress_filter_context_s*);
};
typedef struct compress_filter_context_s compress_filter_context_t;
1997-11-23 16:38:27 +01:00
typedef struct {
DEK *dek;
u32 datalen;
2002-06-29 15:46:34 +02:00
CIPHER_HANDLE cipher_hd;
1997-11-23 16:38:27 +01:00
int header;
2002-06-29 15:46:34 +02:00
MD_HANDLE mdc_hash;
byte enchash[20];
int create_mdc; /* flag will be set by the cipher filter */
1997-11-23 16:38:27 +01:00
} cipher_filter_context_t;
typedef struct {
byte *buffer; /* malloced buffer */
unsigned buffer_size; /* and size of this buffer */
unsigned buffer_len; /* used length of the buffer */
unsigned buffer_pos; /* read position */
int truncated; /* number of truncated lines */
int not_dash_escaped;
int escape_from;
2002-06-29 15:46:34 +02:00
MD_HANDLE md;
int pending_lf;
int pending_esc;
} text_filter_context_t;
1997-11-23 16:38:27 +01:00
1998-01-02 21:40:10 +01:00
typedef struct {
char *what; /* description */
u32 last_time; /* last time reported */
unsigned long last; /* last amount reported */
unsigned long offset; /* current amount */
unsigned long total; /* total amount */
} progress_filter_context_t;
2002-06-29 15:46:34 +02:00
/* encrypt_filter_context_t defined in main.h */
1997-11-18 15:06:00 +01:00
/*-- mdfilter.c --*/
int md_filter( void *opaque, int control, IOBUF a, byte *buf, size_t *ret_len);
1997-11-24 12:04:11 +01:00
void free_md_filter_context( md_filter_context_t *mfx );
1997-11-18 15:06:00 +01:00
1997-11-21 15:53:57 +01:00
/*-- armor.c --*/
1998-02-16 21:05:02 +01:00
int use_armor_filter( IOBUF a );
1997-11-21 15:53:57 +01:00
int armor_filter( void *opaque, int control,
IOBUF chain, byte *buf, size_t *ret_len);
2002-06-29 15:46:34 +02:00
UnarmorPump unarmor_pump_new (void);
void unarmor_pump_release (UnarmorPump x);
int unarmor_pump (UnarmorPump x, int c);
1997-11-21 15:53:57 +01:00
1997-11-23 16:38:27 +01:00
/*-- compress.c --*/
void push_compress_filter(IOBUF out,compress_filter_context_t *zfx,int algo);
void push_compress_filter2(IOBUF out,compress_filter_context_t *zfx,
int algo,int rel);
1997-11-23 16:38:27 +01:00
/*-- cipher.c --*/
int cipher_filter( void *opaque, int control,
IOBUF chain, byte *buf, size_t *ret_len);
/*-- textfilter.c --*/
int text_filter( void *opaque, int control,
IOBUF chain, byte *buf, size_t *ret_len);
2002-06-29 15:46:34 +02:00
int copy_clearsig_text( IOBUF out, IOBUF inp, MD_HANDLE md,
int escape_dash, int escape_from, int pgp2mode );
/*-- progress.c --*/
int progress_filter (void *opaque, int control,
IOBUF a, byte *buf, size_t *ret_len);
void handle_progress (progress_filter_context_t *pfx,
IOBUF inp, const char *name);
1997-11-23 16:38:27 +01:00
2002-06-29 15:46:34 +02:00
#endif /*G10_FILTER_H*/