From 0f436d9a223e24184eaea2a2c4be90151fd3260a Mon Sep 17 00:00:00 2001 From: Jeffrey Stedfast Date: Tue, 17 Apr 2001 22:18:25 +0000 Subject: New source files to handle Pkcs7 encryption, decryption, signing, and 2001-04-17 Jeffrey Stedfast * camel-pkcs7-context.[c,h]: New source files to handle Pkcs7 encryption, decryption, signing, and verifying. Not yet complete. I'm sensing this is going to take a while seeing as how NSS is just so well documented. svn path=/trunk/; revision=9435 --- camel/camel-pkcs7-context.h | 73 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 camel/camel-pkcs7-context.h (limited to 'camel/camel-pkcs7-context.h') diff --git a/camel/camel-pkcs7-context.h b/camel/camel-pkcs7-context.h new file mode 100644 index 0000000000..200ba527a0 --- /dev/null +++ b/camel/camel-pkcs7-context.h @@ -0,0 +1,73 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ +/* + * Authors: Jeffrey Stedfast + * + * Copyright 2001 Ximian, Inc. (www.ximian.com) + * + * This program 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 2 of the License, or + * (at your option) any later version. + * + * 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 Street #330, Boston, MA 02111-1307, USA. + * + */ + +#ifndef CAMEL_PKCS7_CONTEXT_H +#define CAMEL_PKCS7_CONTEXT_H + +#include +#include +#include +#include + +#ifdef __cplusplus +extern "C" { +#pragma } +#endif /* __cplusplus */ + +#define CAMEL_PKCS7_CONTEXT_TYPE (camel_pkcs7_context_get_type ()) +#define CAMEL_PKCS7_CONTEXT(obj) (CAMEL_CHECK_CAST((obj), CAMEL_PKCS7_CONTEXT_TYPE, CamelPkcs7Context)) +#define CAMEL_PKCS7_CONTEXT_CLASS(k) (CAMEL_CHECK_CLASS_CAST ((k), CAMEL_PKCS7_CONTEXT_TYPE, CamelPkcs7ContextClass)) +#define CAMEL_IS_PKCS7_CONTEXT(o) (CAMEL_CHECK_TYPE((o), CAMEL_PKCS7_CONTEXT_TYPE)) + +typedef struct _CamelPkcs7Context { + CamelCipherContext parent_object; + + struct _CamelPkcs7ContextPrivate *priv; + +} CamelPkcs7Context; + +typedef struct _CamelPkcs7ContextClass { + CamelCipherContextClass parent_class; + +} CamelPkcs7ContextClass; + + +CamelType camel_pkcs7_context_get_type (void); + +CamelPkcs7Context *camel_pkcs7_context_new (CamelSession *session, const char *certdb_path); + +/* PKCS7 routines */ +#define camel_pkcs7_sign(c, u, h, i, o, e) camel_cipher_sign (CAMEL_CIPHER_CONTEXT (c), u, h, i, o, e) + +#define camel_pkcs7_clearsign(c, u, h, i, o, e) camel_cipher_clearsign (CAMEL_CIPHER_CONTEXT (c), u, h, i, o, e) + +#define camel_pkcs7_verify(c, i, s, e) camel_cipher_verify (CAMEL_CIPHER_CONTEXT (c), i, s, e) + +#define camel_pkcs7_encrypt(c, s, u, r, i, o, e) camel_cipher_encrypt (CAMEL_CIPHER_CONTEXT (c), s, u, r, i, o, e) + +#define camel_pkcs7_decrypt(c, i, o, e) camel_cipher_decrypt (CAMEL_CIPHER_CONTEXT (c), i, o, e) + +#ifdef __cplusplus +} +#endif /* __cplusplus */ + +#endif /* CAMEL_PKCS7_CONTEXT_H */ -- cgit v1.2.3