SecItemAdd e SecItemCopyMatching retorna o código de erro -34018 (errSecMissingEntitlement)

Às vezes, quando eu executar um aplicativo no dispositivo do Xcode eu tentaria acessar o keychain mas falhar devido ao erro -34018. Isso não corresponde a nenhum dos códigos de erro de chaveiro documentados e não pode ser reproduzido consistentemente. (acontece talvez 30% do tempo, e não está claro para mim porque isso acontece). O que dificulta muito a depuração deste problema é a total falta de documentação. Alguma idéia do que causa isso e como corrigi-lo? Estou usando o Xcode 5 e executando o iOS 7.0.4 no dispositivo.

Há uma questão em aberto sobre isso aqui:https://github.com/soffes/sskeychain/issues/52

EDIT: Adicionando código de acesso de chaveiro por solicitação

Estou usando oSSKeychain biblioteca para interface com chaveiro. Aqui está o trecho.

#define SERVICE @"default"

@implementation SSKeychain (EXT)

+ (void)setValue:(NSString *)value forKey:(NSString *)key {
    NSError *error = nil;
    BOOL success = NO;
    if (value) {
        success = [self setPassword:value forService:SERVICE account:key error:&error];
    } else {
        success = [self deletePasswordForService:SERVICE account:key error:&error];
    }
    NSAssert(success, @"Unable to set keychain value %@ for key %@ error %@", value, key, error);
    if (!success) {
        LogError(@"Unable to set value to keychain %@", error);
    }
    LogTrace(@"Will set keychain account %@. is to nil? %d", key, value == nil);
    if (value == nil)
        LogWarn(@"Setting keychain %@ to nil!!!", key);
}

+ (NSString *)valueForKey:(NSString *)key {
    NSError *error = nil;
    NSString *value = [self passwordForService:SERVICE account:key error:&error];
    if (error && error.code != errSecItemNotFound) {
        NSAssert(!error, @"Unable to retrieve keychain value for key %@ error %@", key, error);
        LogError(@"Unable to retrieve keychain value for key %@ error %@", key, error);
    }
    return value;
}

+ (BOOL)removeAllValues {
    LogInfo(@"Completely Reseting Keychain");
    return [[self accountsForService:SERVICE] all:^BOOL(NSDictionary *accountInfo) {
        return [self deletePasswordForService:SERVICE account:accountInfo[@"acct"]];
    }];
}

@end

A maior parte do tempo é muito boa. Às vezes, eu bato as falhas de asserção onde não consigo gravar nem ler de keychain, causando falha crítica de asserção.

questionAnswers(19)

yourAnswerToTheQuestion