]> git.xonotic.org Git - xonotic/d0_blind_id.git/commitdiff
also add d0_blind_id_verify_private_id
authorRudolf Polzer <divverent@xonotic.org>
Fri, 9 Dec 2011 11:30:21 +0000 (12:30 +0100)
committerRudolf Polzer <divverent@xonotic.org>
Fri, 9 Dec 2011 11:30:21 +0000 (12:30 +0100)
Makefile.am
configure.ac
d0_blind_id.c
d0_blind_id.h

index 3cb22c7101a2a3153372f7e42d7647c49ba87969..99122c43ff15077f8e30c8e4e5db005c280fff46 100644 (file)
@@ -23,7 +23,7 @@ else
 libd0_blind_id_la_SOURCES += d0_bignum-gmp.c
 endif
 endif
-libd0_blind_id_la_LDFLAGS = -versioninfo 6:0:6
+libd0_blind_id_la_LDFLAGS = -versioninfo 7:0:7
 libd0_blind_id_la_CFLAGS = -fvisibility=hidden -Wold-style-definition -Wstrict-prototypes -Wsign-compare -Wdeclaration-after-statement
 library_includedir = $(includedir)/d0_blind_id
 library_include_HEADERS = d0_blind_id.h d0.h
index 5c98c6565401510ad44476e0d89aea2d18244633..83a8258b3c23e0ff03e148c08e98bdf898d9d824 100644 (file)
@@ -1,4 +1,4 @@
-AC_INIT([d0_blind_id],[0.4],[divVerent@xonotic.org])
+AC_INIT([d0_blind_id],[0.5],[divVerent@xonotic.org])
 AC_CONFIG_MACRO_DIR([m4])
 AM_INIT_AUTOMAKE([-Wall foreign])
 AC_PROG_CC
index 68d3c64e5cba3263e451ea7ed9498e407c48b184..57ca8fd0594242d11c3f8507571321f16edb3e02 100644 (file)
@@ -1440,6 +1440,23 @@ fail:
        return 0;
 }
 
+D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_verify_private_id(const d0_blind_id_t *ctx)
+{
+       USINGTEMPS(); // temps: temp0 = order, temp1 = g^s
+       USING(schnorr_G); USING(schnorr_s); USING(schnorr_g_to_s);
+
+       LOCKTEMPS();
+       CHECK(d0_dl_get_order(temp0, ctx->schnorr_G));
+       CHECK(d0_bignum_mod_pow(temp1, four, ctx->schnorr_s, ctx->schnorr_G));
+       CHECK(!d0_bignum_cmp(temp1, ctx->schnorr_g_to_s));
+       UNLOCKTEMPS();
+       return 1;
+
+fail:
+       UNLOCKTEMPS();
+       return 0;
+}
+
 d0_blind_id_t *d0_blind_id_new(void)
 {
        d0_blind_id_t *b = d0_malloc(sizeof(d0_blind_id_t));
index c4f772a1ff5ff893f6b993b47b1ce11c6f39a12d..bf838f43093aceadcd2d20071684f1e7148a4332 100644 (file)
@@ -76,6 +76,7 @@ D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_sign_with_private_id_verify(
 D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_sign_with_private_id_verify_detached(d0_blind_id_t *ctx, D0_BOOL is_first, D0_BOOL recv_modulus, const char *inbuf, size_t inbuflen, const char *msg, size_t msglen, D0_BOOL *status);
 D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_fingerprint64_public_id(const d0_blind_id_t *ctx, char *outbuf, size_t *outbuflen);
 D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_verify_public_id(const d0_blind_id_t *ctx, D0_BOOL *status);
+D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_verify_private_id(const d0_blind_id_t *ctx);
 D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_sessionkey_public_id(const d0_blind_id_t *ctx, char *outbuf, size_t *outbuflen); // can only be done after successful key exchange, this performs a modpow; key length is limited by SHA_DIGESTSIZE for now; also ONLY valid after successful d0_blind_id_authenticate_with_private_id_verify/d0_blind_id_fingerprint64_public_id
 
 D0_EXPORT D0_WARN_UNUSED_RESULT D0_BOOL d0_blind_id_INITIALIZE(void);