gpgme_get_sig_key() problems
Gordon Worley
redbird@rbisland.cx
Thu Aug 8 17:08:02 2002
On Thursday, August 8, 2002, at 03:28 AM, Marcus Brinkmann wrote:
> On Tue, Aug 06, 2002 at 12:09:48PM -0400, Gordon Worley wrote:
>> Hi. I'm having problems with getting the keys that correspond to
>> signatures when there are multiple signatures. I have, in my example
>> file, three signatures (my main key, my Mac GPG key, and a test key
>> that
>> I created) on the data. When I call gpgme_get_sig_key(), it sometimes
>> does not return a key when the index is valid (it will report index out
>> of bounds). After a few seconds, though, it will work. This only
>> happens sometimes, though.
>
> This is strange. Seems to me like there is a timing problem in the
> code,
> although I can not see it. Can you provide us witha test program that
> shows
> the problem on your machine? Maybe I can also get more input by
> letting you
> run a modified version of GPGME that prints out some debugging output
> if we
> can not reproduce it here.
Well, I don't have enough experience working with GPGME itself (I use
our Objective C wrapper) to write a test program, but here are the
relevant bits of code that I call in the process of trying to get the
signatures' keys.
//In my end-user program
NSMutableArray *keys = [NSMutableArray array];
for (i = 0; i < [signatures count]; i++) {
[keys addObject: [(GPGSignature *)[signatures objectAtIndex: i]
key]];
}
////////////////////////////////////////
//in GPGME.framework
//this is a GPGSignature method
- (GPGKey *) key
{
//NSLog(@"%d", _index);
return [_context keyOfSignatureAtIndex:_index];
}
////////////////////////////////////////
//Also in GPGME.framework
//This is a GPGContext method (that's what the _context above is)
- (GPGKey *) keyOfSignatureAtIndex:(int)index
{
GpgmeKey aGpgmeKey;
GpgmeError anError = gpgme_get_sig_key(_context, index, &aGpgmeKey);
GPGKey *key;
//NSLog(@"keyOfSignatureAtIndex: %d", index);
if(anError == GPGME_EOF)
return nil;
if(anError != GPGME_No_Error)
[[NSException exceptionWithGPGError:anError userInfo:nil] raise];
NSAssert(aGpgmeKey != NULL, @"### No gpgmeKey but no error?!");
key = [[GPGKey alloc] initWithInternalRepresentation:aGpgmeKey];
// Key returned by gpgme_get_sig_key() has one reference;
// Wrapper also takes a reference on it,
// thus we can remove one reference, safely.
gpgme_key_unref(aGpgmeKey);
return [key autorelease];
}
/////////////////////////////////////////
Sorry, that's probably not much help, but maybe it will give some
indication of what's happening.
From my own debugging, I thought that maybe a truly invalid index was
being passed, but checking the index through the call chain shows that
it is always correct and there isn't a one off error or something like
then when I ask for the key.
As you suggest, my guess is a timing error of some sort, since it only
sometimes happens. We recently had a problem like this of our own with
passphrases, and it turned out to be an error with Objective C's
autorelease pool. If you are using some kind of similar garbage
collection method (if any at all), maybe that could be causing problems?
If you need me to run GPGME with extra debugging code, just point me to
the right sources.
--
Gordon Worley - Mac GPG Project
http://macgpg.sourceforge.net/ ``Doveriai no proveriai.''
redbird@rbisland.cx --Russian proverb
PGP: 0xBBD3B003