mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-10 13:04:23 +01:00
Be much more robust with mangled input files.
This commit is contained in:
parent
3034b6752e
commit
c5f838a968
@ -1,3 +1,7 @@
|
|||||||
|
2002-02-14 David Shaw <dshaw@jabberwocky.com>
|
||||||
|
|
||||||
|
* gpgkeys_ldap.c: Be much more robust with mangled input files.
|
||||||
|
|
||||||
2001-12-28 David Shaw <dshaw@jabberwocky.com>
|
2001-12-28 David Shaw <dshaw@jabberwocky.com>
|
||||||
|
|
||||||
* gpgkeys_mailto.in: Use the new OUTOFBAND indicator so gpg knows
|
* gpgkeys_mailto.in: Use the new OUTOFBAND indicator so gpg knows
|
||||||
@ -35,7 +39,7 @@
|
|||||||
gpgkeys_mailto (email keyserver helper)
|
gpgkeys_mailto (email keyserver helper)
|
||||||
|
|
||||||
|
|
||||||
Copyright 1998, 1999, 2000, 2001 Free Software Foundation, Inc.
|
Copyright 1998, 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This file is free software; as a special exception the author gives
|
This file is free software; as a special exception the author gives
|
||||||
unlimited permission to copy and/or distribute it, with or without
|
unlimited permission to copy and/or distribute it, with or without
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* gpgkeys_ldap.c - talk to a LDAP keyserver
|
/* gpgkeys_ldap.c - talk to a LDAP keyserver
|
||||||
* Copyright (C) 2001 Free Software Foundation, Inc.
|
* Copyright (C) 2001, 2002 Free Software Foundation, Inc.
|
||||||
*
|
*
|
||||||
* This file is part of GnuPG.
|
* This file is part of GnuPG.
|
||||||
*
|
*
|
||||||
@ -44,7 +44,7 @@ FILE *input=NULL,*output=NULL,*console=NULL;
|
|||||||
|
|
||||||
struct keylist
|
struct keylist
|
||||||
{
|
{
|
||||||
char *keystr;
|
char str[MAX_LINE];
|
||||||
struct keylist *next;
|
struct keylist *next;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -146,6 +146,7 @@ int send_key(LDAP *ldap,char *keyid)
|
|||||||
fail:
|
fail:
|
||||||
|
|
||||||
free(key[0]);
|
free(key[0]);
|
||||||
|
free(dn);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -220,7 +221,7 @@ int get_key(LDAP *ldap,char *getkey)
|
|||||||
{
|
{
|
||||||
while(keyptr!=NULL)
|
while(keyptr!=NULL)
|
||||||
{
|
{
|
||||||
if(strcasecmp(keyptr->keystr,vals[0])==0)
|
if(strcasecmp(keyptr->str,vals[0])==0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
keyptr=keyptr->next;
|
keyptr=keyptr->next;
|
||||||
@ -238,13 +239,8 @@ int get_key(LDAP *ldap,char *getkey)
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
keyptr->keystr=strdup(vals[0]);
|
strncpy(keyptr->str,vals[0],MAX_LINE);
|
||||||
if(keyptr->keystr==NULL)
|
keyptr->str[MAX_LINE-1]='\0';
|
||||||
{
|
|
||||||
fprintf(console,"gpgkeys: out of memory when deduping "
|
|
||||||
"key list\n");
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
keyptr->next=dupelist;
|
keyptr->next=dupelist;
|
||||||
dupelist=keyptr;
|
dupelist=keyptr;
|
||||||
@ -360,7 +356,6 @@ int get_key(LDAP *ldap,char *getkey)
|
|||||||
struct keylist *keyptr=dupelist;
|
struct keylist *keyptr=dupelist;
|
||||||
|
|
||||||
dupelist=keyptr->next;
|
dupelist=keyptr->next;
|
||||||
free(keyptr->keystr);
|
|
||||||
free(keyptr);
|
free(keyptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -705,55 +700,40 @@ int main(int argc,char *argv[])
|
|||||||
while(fgets(line,MAX_LINE,input)!=NULL && line[0]!='\n');
|
while(fgets(line,MAX_LINE,input)!=NULL && line[0]!='\n');
|
||||||
else if(action==GET || action==SEARCH)
|
else if(action==GET || action==SEARCH)
|
||||||
{
|
{
|
||||||
keylist=malloc(sizeof(struct keylist));
|
for(;;)
|
||||||
if(keylist==NULL)
|
|
||||||
{
|
{
|
||||||
fprintf(console,"gpgkeys: out of memory when building key list\n");
|
struct keylist *work;
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
keyptr=keylist;
|
if(fgets(line,MAX_LINE,input)==NULL)
|
||||||
|
break;
|
||||||
keyptr->keystr=malloc(MAX_LINE);
|
else
|
||||||
if(keyptr->keystr==NULL)
|
|
||||||
{
|
|
||||||
fprintf(console,"gpgkeys: out of memory when building key list\n");
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
while(fgets(keyptr->keystr,MAX_LINE,input)!=NULL)
|
|
||||||
{
|
|
||||||
int len;
|
|
||||||
|
|
||||||
if(keyptr->keystr[0]=='\n')
|
|
||||||
{
|
{
|
||||||
free(keyptr->keystr);
|
if(line[0]=='\n')
|
||||||
keyptr->keystr=NULL;
|
break;
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Trim the trailing \n */
|
work=malloc(sizeof(struct keylist));
|
||||||
len=strlen(keyptr->keystr);
|
if(work==NULL)
|
||||||
if(len>1)
|
{
|
||||||
keyptr->keystr[len-1]='\0';
|
fprintf(console,"gpgkeys: out of memory while "
|
||||||
|
"building key list\n");
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
keyptr->next=malloc(sizeof(struct keylist));
|
strcpy(work->str,line);
|
||||||
if(keyptr->next==NULL)
|
|
||||||
{
|
|
||||||
fprintf(console,"gpgkeys: out of memory when "
|
|
||||||
"building key list\n");
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
keyptr=keyptr->next;
|
/* Trim the trailing \n */
|
||||||
keyptr->next=NULL;
|
work->str[strlen(line)-1]='\0';
|
||||||
|
|
||||||
keyptr->keystr=malloc(MAX_LINE);
|
work->next=NULL;
|
||||||
if(keyptr->keystr==NULL)
|
|
||||||
{
|
/* Always attach at the end to keep the list in proper
|
||||||
fprintf(console,"gpgkeys: out of memory when "
|
order for searching */
|
||||||
"building key list\n");
|
if(keylist==NULL)
|
||||||
goto fail;
|
keylist=work;
|
||||||
|
else
|
||||||
|
keyptr->next=work;
|
||||||
|
|
||||||
|
keyptr=work;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -850,16 +830,15 @@ int main(int argc,char *argv[])
|
|||||||
case GET:
|
case GET:
|
||||||
keyptr=keylist;
|
keyptr=keylist;
|
||||||
|
|
||||||
while(keyptr->keystr!=NULL)
|
while(keyptr!=NULL)
|
||||||
{
|
{
|
||||||
struct keylist *current=keyptr;
|
struct keylist *current=keyptr;
|
||||||
|
|
||||||
get_key(ldap,current->keystr);
|
get_key(ldap,current->str);
|
||||||
|
|
||||||
keyptr=current->next;
|
keyptr=current->next;
|
||||||
|
|
||||||
/* Free it as we go */
|
/* Free it as we go */
|
||||||
free(current->keystr);
|
|
||||||
free(current);
|
free(current);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -888,9 +867,9 @@ int main(int argc,char *argv[])
|
|||||||
"enters words" */
|
"enters words" */
|
||||||
|
|
||||||
keyptr=keylist;
|
keyptr=keylist;
|
||||||
while(keyptr->keystr!=NULL)
|
while(keyptr!=NULL)
|
||||||
{
|
{
|
||||||
len+=strlen(keyptr->keystr)+1;
|
len+=strlen(keyptr->str)+1;
|
||||||
keyptr=keyptr->next;
|
keyptr=keyptr->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -901,16 +880,15 @@ int main(int argc,char *argv[])
|
|||||||
searchkey[0]='\0';
|
searchkey[0]='\0';
|
||||||
|
|
||||||
keyptr=keylist;
|
keyptr=keylist;
|
||||||
while(keyptr->keystr!=NULL)
|
while(keyptr!=NULL)
|
||||||
{
|
{
|
||||||
struct keylist *current=keyptr;
|
struct keylist *current=keyptr;
|
||||||
|
|
||||||
strcat(searchkey,current->keystr);
|
strcat(searchkey,current->str);
|
||||||
strcat(searchkey,"*");
|
strcat(searchkey,"*");
|
||||||
keyptr=current->next;
|
keyptr=current->next;
|
||||||
|
|
||||||
/* Free it as we go */
|
/* Free it as we go */
|
||||||
free(current->keystr);
|
|
||||||
free(current);
|
free(current);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user