aboutsummaryrefslogtreecommitdiffstats
path: root/camel/camel-multipart-signed.h
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2002-05-31 09:05:47 +0800
committerMichael Zucci <zucchi@src.gnome.org>2002-05-31 09:05:47 +0800
commit1c309b14c41ba3305bc72404fa290769251fda4a (patch)
tree6eb6042a5fe1d8695cd1508e2b7c1c0e98b5e0ef /camel/camel-multipart-signed.h
parent29a8c80e9323ef2406c2b237a6a6058639fd4cb2 (diff)
downloadgsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar
gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar.gz
gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar.bz2
gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar.lz
gsoc2013-evolution-1c309b14c41ba3305bc72404fa290769251fda4a.tar.xz
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.h103
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 */
+
+