1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-08 12:44:23 +01:00

Include cmacros.am for common flags.

(libexec_PROGRAMS): Put gpg-protect-tool there.
This commit is contained in:
Werner Koch 2004-02-12 09:27:36 +00:00
parent 53d1156682
commit f5c3d2712b
3 changed files with 81 additions and 45 deletions

View File

@ -1,3 +1,8 @@
2004-02-12 Werner Koch <wk@gnupg.org>
* Makefile.am: Include cmacros.am for common flags.
(libexec_PROGRAMS): Put gpg-protect-tool there.
2004-02-10 Werner Koch <wk@gnupg.org> 2004-02-10 Werner Koch <wk@gnupg.org>
* minip12.c (parse_bag_encrypted_data): Finished implementation. * minip12.c (parse_bag_encrypted_data): Finished implementation.

View File

@ -1,4 +1,4 @@
# Copyright (C) 2001, 2003 Free Software Foundation, Inc. # Copyright (C) 2001, 2003, 2004 Free Software Foundation, Inc.
# #
# This file is part of GnuPG. # This file is part of GnuPG.
# #
@ -18,14 +18,14 @@
## Process this file with automake to produce Makefile.in ## Process this file with automake to produce Makefile.in
localedir = $(datadir)/locale
INCLUDES = -I../intl -DLOCALEDIR=\"$(localedir)\"
bin_PROGRAMS = gpg-agent bin_PROGRAMS = gpg-agent
pkglib_PROGRAMS = gpg-protect-tool libexec_PROGRAMS = gpg-protect-tool
AM_CPPFLAGS = -I$(top_srcdir)/common $(LIBGCRYPT_CFLAGS) \ AM_CPPFLAGS = -I$(top_srcdir)/common -I$(top_srcdir)/intl
$(LIBASSUAN_CFLAGS) $(PTH_CFLAGS)
include $(top_srcdir)/am/cmacros.am
AM_CFLAGS = $(LIBGCRYPT_CFLAGS) $(LIBASSUAN_CFLAGS) $(PTH_CFLAGS)
gpg_agent_SOURCES = \ gpg_agent_SOURCES = \
gpg-agent.c agent.h \ gpg-agent.c agent.h \

View File

@ -98,6 +98,9 @@ static unsigned char const oid_pkcs_12_pkcs_8ShroudedKeyBag[11] = {
0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x0A, 0x01, 0x02 }; 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x0A, 0x01, 0x02 };
static unsigned char const oid_pkcs_12_CertBag[11] = { static unsigned char const oid_pkcs_12_CertBag[11] = {
0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x0A, 0x01, 0x03 }; 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x0A, 0x01, 0x03 };
static unsigned char const oid_pkcs_12_CrlBag[11] = {
0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x0A, 0x01, 0x04 };
static unsigned char const oid_pbeWithSHAAnd3_KeyTripleDES_CBC[10] = { static unsigned char const oid_pbeWithSHAAnd3_KeyTripleDES_CBC[10] = {
0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x01, 0x03 }; 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x0C, 0x01, 0x03 };
static unsigned char const oid_pbeWithSHAAnd40BitRC2_CBC[10] = { static unsigned char const oid_pbeWithSHAAnd40BitRC2_CBC[10] = {
@ -490,6 +493,8 @@ parse_bag_encrypted_data (const unsigned char *buffer, size_t length,
/* Loop over all certificates inside the bab. */ /* Loop over all certificates inside the bab. */
while (n) while (n)
{ {
int isbag = 0;
where = "certbag.nextcert"; where = "certbag.nextcert";
if (ti.class || ti.tag != TAG_SEQUENCE) if (ti.class || ti.tag != TAG_SEQUENCE)
goto bailout; goto bailout;
@ -497,59 +502,78 @@ parse_bag_encrypted_data (const unsigned char *buffer, size_t length,
where = "certbag.objectidentifier"; where = "certbag.objectidentifier";
if (parse_tag (&p, &n, &ti)) if (parse_tag (&p, &n, &ti))
goto bailout; goto bailout;
if (ti.class || ti.tag != TAG_OBJECT_ID if (ti.class || ti.tag != TAG_OBJECT_ID)
|| ti.length != DIM(oid_pkcs_12_CertBag) goto bailout;
|| memcmp (p, oid_pkcs_12_CertBag, if ( ti.length == DIM(oid_pkcs_12_CertBag)
DIM(oid_pkcs_12_CertBag))) && !memcmp (p, oid_pkcs_12_CertBag, DIM(oid_pkcs_12_CertBag)))
{
p += DIM(oid_pkcs_12_CertBag);
n -= DIM(oid_pkcs_12_CertBag);
}
else if ( ti.length == DIM(oid_pkcs_12_CrlBag)
&& !memcmp (p, oid_pkcs_12_CrlBag, DIM(oid_pkcs_12_CrlBag)))
{
p += DIM(oid_pkcs_12_CrlBag);
n -= DIM(oid_pkcs_12_CrlBag);
isbag = 1;
}
else
goto bailout; goto bailout;
p += DIM(oid_pkcs_12_CertBag);
n -= DIM(oid_pkcs_12_CertBag);
where = "certbag.before.certheader"; where = "certbag.before.certheader";
if (parse_tag (&p, &n, &ti)) if (parse_tag (&p, &n, &ti))
goto bailout; goto bailout;
if (ti.class != CONTEXT || ti.tag) if (ti.class != CONTEXT || ti.tag)
goto bailout; goto bailout;
if (parse_tag (&p, &n, &ti)) if (isbag)
goto bailout; {
if (ti.class || ti.tag != TAG_SEQUENCE) log_info ("skipping unsupported crlBag\n");
goto bailout; p += ti.length;
if (parse_tag (&p, &n, &ti)) n -= ti.length;
goto bailout; }
if (ti.class || ti.tag != TAG_OBJECT_ID else
|| ti.length != DIM(oid_x509Certificate_for_pkcs_12) {
|| memcmp (p, oid_x509Certificate_for_pkcs_12, if (parse_tag (&p, &n, &ti))
DIM(oid_x509Certificate_for_pkcs_12))) goto bailout;
goto bailout; if (ti.class || ti.tag != TAG_SEQUENCE)
p += DIM(oid_x509Certificate_for_pkcs_12); goto bailout;
n -= DIM(oid_x509Certificate_for_pkcs_12); if (parse_tag (&p, &n, &ti))
goto bailout;
if (ti.class || ti.tag != TAG_OBJECT_ID
|| ti.length != DIM(oid_x509Certificate_for_pkcs_12)
|| memcmp (p, oid_x509Certificate_for_pkcs_12,
DIM(oid_x509Certificate_for_pkcs_12)))
goto bailout;
p += DIM(oid_x509Certificate_for_pkcs_12);
n -= DIM(oid_x509Certificate_for_pkcs_12);
where = "certbag.before.octetstring"; where = "certbag.before.octetstring";
if (parse_tag (&p, &n, &ti)) if (parse_tag (&p, &n, &ti))
goto bailout; goto bailout;
if (ti.class != CONTEXT || ti.tag) if (ti.class != CONTEXT || ti.tag)
goto bailout; goto bailout;
if (parse_tag (&p, &n, &ti)) if (parse_tag (&p, &n, &ti))
goto bailout; goto bailout;
if (ti.class || ti.tag != TAG_OCTET_STRING || ti.ndef) if (ti.class || ti.tag != TAG_OCTET_STRING || ti.ndef)
goto bailout; goto bailout;
/* Return the certificate. */ /* Return the certificate. */
if (certcb) if (certcb)
certcb (certcbarg, p, ti.length); certcb (certcbarg, p, ti.length);
p += ti.length; p += ti.length;
n -= ti.length; n -= ti.length;
}
/* Ugly hack to cope with the padding: Forget about a rest of /* Ugly hack to cope with the padding: Forget about the rest if
sie les than the cipher's block length. */ that it is less than the cipher's block length. */
if (n < 8) if (n < 8)
n = 0; n = 0;
/* Skip the optional SET with the pkcs12 cert attributes. */ /* Skip the optional SET with the pkcs12 cert attributes. */
if (n) if (n)
{ {
where = "certbag.attributes"; where = "bag.attributes";
if (parse_tag (&p, &n, &ti)) if (parse_tag (&p, &n, &ti))
goto bailout; goto bailout;
if (!ti.class && ti.tag == TAG_SEQUENCE) if (!ti.class && ti.tag == TAG_SEQUENCE)
@ -691,6 +715,13 @@ parse_bag_data (const unsigned char *buffer, size_t length, int startoffset,
startoffset = 0; startoffset = 0;
buffer = p = plain; buffer = p = plain;
{
FILE *fp = fopen ("tmp-3des-plain.der", "wb");
if (!fp || fwrite (p, n, 1, fp) != 1)
exit (2);
fclose (fp);
}
where = "decrypted-text"; where = "decrypted-text";
if (parse_tag (&p, &n, &ti) || ti.class || ti.tag != TAG_SEQUENCE) if (parse_tag (&p, &n, &ti) || ti.class || ti.tag != TAG_SEQUENCE)
goto bailout; goto bailout;