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:
parent
53d1156682
commit
f5c3d2712b
@ -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.
|
||||||
|
@ -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 \
|
||||||
|
103
agent/minip12.c
103
agent/minip12.c
@ -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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user