diff options
author | Not Zed <NotZed@Ximian.com> | 2002-05-31 09:05:47 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2002-05-31 09:05:47 +0800 |
commit | 1c309b14c41ba3305bc72404fa290769251fda4a (patch) | |
tree | 6eb6042a5fe1d8695cd1508e2b7c1c0e98b5e0ef /camel/camel-multipart-signed.h | |
parent | 29a8c80e9323ef2406c2b237a6a6058639fd4cb2 (diff) | |
download | gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar.gz gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar.zst gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.zip |
Added a protocol field for users to use.
2002-05-30 Not Zed <NotZed@Ximian.com>
* camel-cipher-context.h: Added a protocol field for users to use.
* camel-stream-filter.c (do_read): Sigh, the pre-size is READ_PAD
not READ_SIZE. Big difference.
(READ_PAD): Bumped upto 128 from 64, so we can fit a typical line
in full.
* providers/imap/camel-imap-folder.c (get_content): Changed to
load multipart/signed as an opaque block into the right kind of
object.
* camel-multipart.h (struct _CamelMultipart): Removed the boundary
field. It wans't actually used anywhere.
* camel-seekable-substream.c
(camel_seekable_substream_new_with_seekable_stream_and_bounds):
Shortened this stupidly long name to just :new(), its the only way
its ever used. Fixed all callers.
* camel-multipart-signed.[ch]: new wrapper for multipart/signed
types. We need to treat the entire content as a blob of data for
transport purposes. This also cleans up a lot of the sign/verify
handling.
* camel-mime-part-utils.c
(camel_mime_part_construct_content_from_parser): Just call
camel_multipart_construct_from_parser for multipart parts, also
use a multipart_signed for multipart/signed types.
* camel-multipart.c (camel_multipart_construct_from_parser): New
virtual function for multiparts to buld themselves.
(construct_from_parser): Implement for normal multiparts.
(toplevel): Got rid of a warning, it'll never be an abstract
class.
* camel-pgp-context.c (pgp_hash_to_id):
(pgp_id_to_hash): Implement.
(camel_pgp_context_init): Init the pgp protocol specifier.
* camel-cipher-context.c (camel_cipher_id_to_hash):
(camel_cipher_hash_to_id): Util virtual methods to handle the
cipher id string.
* camel-mime-filter-canon.[ch]: A new filter, end/start of line
canonicalisation filter. Can escape "From " and strip trailing
whitespace, and canonicalise the end of line to crlf or to lf.
2002-05-29 Not Zed <NotZed@Ximian.com>
* camel-multipart.h (struct _CamelMultipart): Removed the
'parent', nothing used it, anywhere. Cleaned up some formatting
slightly.
svn path=/trunk/; revision=17057
Diffstat (limited to 'camel/camel-multipart-signed.h')
-rw-r--r-- | camel/camel-multipart-signed.h | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/camel/camel-multipart-signed.h b/camel/camel-multipart-signed.h new file mode 100644 index 0000000000..7371e370ed --- /dev/null +++ b/camel/camel-multipart-signed.h @@ -0,0 +1,103 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- + * camel-signed--multipart.h : class for a signed-multipart + * + * Authors: Michael Zucchi <notzed@ximian.com> + * + * Copyright 2002 Ximian, Inc. (www.ximian.com) + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of version 2 of the GNU General Public + * License as published by the Free Software Foundation. + * + * This program 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, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 + * USA + */ + +/* Should this be a subclass of multipart? + No, because we dont have different parts? + I'm not really sure yet ... ? */ + +#ifndef CAMEL_MULTIPART_SIGNED_H +#define CAMEL_MULTIPART_SIGNED_H 1 + +#ifdef __cplusplus +extern "C" { +#pragma } +#endif /* __cplusplus }*/ + +#include <camel/camel-multipart.h> +#include <camel/camel-cipher-context.h> + +#define CAMEL_MULTIPART_SIGNED_TYPE (camel_multipart_signed_get_type ()) +#define CAMEL_MULTIPART_SIGNED(obj) (CAMEL_CHECK_CAST((obj), CAMEL_MULTIPART_SIGNED_TYPE, CamelMultipartSigned)) +#define CAMEL_MULTIPART_SIGNED_CLASS(k) (CAMEL_CHECK_CLASS_CAST ((k), CAMEL_MULTIPART_SIGNED_TYPE, CamelMultipartSignedClass)) +#define CAMEL_IS_MULTIPART_SIGNED(o) (CAMEL_CHECK_TYPE((o), CAMEL_MULTIPART_SIGNED_TYPE)) + +/* +enum { + CAMEL_MULTIPART_EMPTY, + CAMEL_MULTIPART_CONST, + CAMEL_MULTIPART_SIGN, + CAMEL_MULTIPART_ENCR, +}; +*/ + +/* 'handy' enums for getting the internal parts of the multipart */ +enum { + CAMEL_MULTIPART_SIGNED_CONTENT, + CAMEL_MULTIPART_SIGNED_SIGNATURE, +}; + +typedef struct _CamelMultipartSigned CamelMultipartSigned; + +struct _CamelMultipartSigned +{ + CamelMultipart parent_object; + + /* these are the client visible parts, decoded forms of our data wrapper content */ + CamelMimePart *content; + CamelMimePart *signature; + + /* the raw content which must go over the wire, if we have generated it */ + /* perhaps this should jsut set data_wrapper->stream and update start1/end1 accordingly, as it is done + for other parts, or visa versa? */ + CamelStream *contentraw; + + /*int state;*/ + + /* just cache some info we use */ + char *protocol; + char *micalg; + + /* offset pointers of start of boundary in content object */ + off_t start1, end1; + off_t start2, end2; +}; + +typedef struct { + CamelMultipartClass parent_class; +} CamelMultipartSignedClass; + +/* Standard Camel function */ +CamelType camel_multipart_signed_get_type (void); + +/* public methods */ +CamelMultipartSigned *camel_multipart_signed_new (void); + +int camel_multipart_signed_sign (CamelMultipartSigned *mps, CamelCipherContext *context, CamelMimePart *content, const char *uiserid, CamelCipherHash hash, CamelException *ex); +CamelCipherValidity *camel_multipart_signed_verify (CamelMultipartSigned *mps, CamelCipherContext *context, CamelException *ex); + +#ifdef __cplusplus +} +#endif /* __cplusplus */ + +#endif /* CAMEL_MULTIPART_SIGNED_H */ + + |