diff dcclib/sign.c @ 0:c7f6b056b673

First import of vendor version
author Peter Gervai <grin@grin.hu>
date Tue, 10 Mar 2009 13:49:58 +0100
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/dcclib/sign.c	Tue Mar 10 13:49:58 2009 +0100
@@ -0,0 +1,80 @@
+/* Distributed Checksum Clearinghouse
+ *
+ * message authentication
+ *
+ * Copyright (c) 2008 by Rhyolite Software, LLC
+ *
+ * This agreement is not applicable to any entity which sells anti-spam
+ * solutions to others or provides an anti-spam solution as part of a
+ * security solution sold to other entities, or to a private network
+ * which employs the DCC or uses data provided by operation of the DCC
+ * but does not provide corresponding data to other users.
+ *
+ * Permission to use, copy, modify, and distribute this software without
+ * changes for any purpose with or without fee is hereby granted, provided
+ * that the above copyright notice and this permission notice appear in all
+ * copies and any distributed versions or copies are either unchanged
+ * or not called anything similar to "DCC" or "Distributed Checksum
+ * Clearinghouse".
+ *
+ * Parties not eligible to receive a license under this agreement can
+ * obtain a commercial license to use DCC by contacting Rhyolite Software
+ * at sales@rhyolite.com.
+ *
+ * A commercial license would be for Distributed Checksum and Reputation
+ * Clearinghouse software.  That software includes additional features.  This
+ * free license for Distributed ChecksumClearinghouse Software does not in any
+ * way grant permision to use Distributed Checksum and Reputation Clearinghouse
+ * software
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND RHYOLITE SOFTWARE, LLC DISCLAIMS ALL
+ * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL RHYOLITE SOFTWARE, LLC
+ * BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES
+ * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
+ * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
+ * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
+ * SOFTWARE.
+ *
+ * Rhyolite Software DCC 1.3.103-1.13 $Revision$
+ */
+
+#include "dcc_defs.h"
+#include "dcc_md5.h"
+#include <string.h>
+
+
+/* sign a DCC packet */
+void
+dcc_sign(const char *passwd,
+	 int passwd_len,
+	 void *pkt,
+	 u_int pkt_len)			/* including signature */
+{
+	MD5_CTX ctx;
+
+	MD5Init(&ctx);
+	MD5Update(&ctx, passwd, passwd_len);
+	MD5Update(&ctx, pkt, pkt_len-sizeof(DCC_SIGNATURE));
+	MD5Final(&((u_char*)pkt)[pkt_len-sizeof(DCC_SIGNATURE)], &ctx);
+}
+
+
+
+/* check the signature of a DCC packet */
+u_char					/* 0=forgery, 1=good signature */
+dcc_ck_signature(const char *passwd,
+		 int passwd_len,
+		 const void *pkt,
+		 u_int pkt_len)		/* including signature */
+{
+	MD5_CTX ctx;
+	DCC_SIGNATURE signature;
+
+	MD5Init(&ctx);
+	MD5Update(&ctx, passwd, passwd_len);
+	MD5Update(&ctx, pkt, pkt_len-sizeof(DCC_SIGNATURE));
+	MD5Final(signature, &ctx);
+	return !memcmp(signature, &((char*)pkt)[pkt_len-sizeof(DCC_SIGNATURE)],
+		       sizeof(signature));
+}