MYSymmetricKey.h
author Jens Alfke <jens@mooseyard.com>
Sun Apr 19 22:05:51 2009 -0700 (2009-04-19)
changeset 15 2ac5704e229f
parent 13 6fd9177eb6da
child 16 c409dbc4f068
permissions -rw-r--r--
Added tag v0.3 for changeset 3af1d1c0ceb5
snej@0
     1
//
snej@0
     2
//  MYSymmetricKey.h
snej@0
     3
//  MYCrypto
snej@0
     4
//
snej@0
     5
//  Created by Jens Alfke on 4/2/09.
snej@0
     6
//  Copyright 2009 Jens Alfke. All rights reserved.
snej@0
     7
//
snej@0
     8
snej@0
     9
#import "MYKey.h"
snej@0
    10
#import <CommonCrypto/CommonCryptor.h>
snej@0
    11
snej@0
    12
snej@0
    13
@interface MYSymmetricKey : MYKey <MYEncryption, MYDecryption>
snej@12
    14
{
snej@12
    15
#if !MYCRYPTO_USE_IPHONE_API
snej@12
    16
    CSSM_KEY *_ownedCSSMKey;
snej@12
    17
#endif
snej@12
    18
}
snej@0
    19
snej@1
    20
/** Initializes a symmetric key from the given key data and algorithm. */
snej@1
    21
- (id) initWithKeyData: (NSData*)keyData
snej@1
    22
             algorithm: (CCAlgorithm)algorithm;
snej@1
    23
snej@1
    24
/** Randomly generates a new symmetric key, using the given algorithm and key-size in bits.
snej@1
    25
    The key is not added to any keychain; if you want to keep the key persistently, use
snej@1
    26
    the method of the same name in the MYKeychain class. */
snej@0
    27
+ (MYSymmetricKey*) generateSymmetricKeyOfSize: (unsigned)keySizeInBits
snej@0
    28
                                     algorithm: (CCAlgorithm)algorithm;
snej@0
    29
snej@14
    30
/** The key's algorithm. */
snej@14
    31
@property (readonly) CCAlgorithm algorithm;
snej@14
    32
snej@14
    33
/** The key's size/length, in bits. */
snej@14
    34
@property (readonly) unsigned keySizeInBits;
snej@14
    35
snej@14
    36
snej@14
    37
#if !TARGET_OS_IPHONE
snej@14
    38
snej@14
    39
- (NSData*) exportWrappedKeyWithPassphrasePrompt: (NSString*)prompt;
snej@14
    40
snej@12
    41
/** Converts a passphrase into a symmetric key.
snej@12
    42
    The same passphrase (and salt) will always return the same key, so you can use this method
snej@12
    43
    to encrypt and decrypt data using a user-entered passphrase, without having to store the key
snej@12
    44
    itself in the keychain.
snej@12
    45
    @param alertTitle  A title for the alert (this seems to be ignored by the OS).
snej@12
    46
    @param prompt  A prompt string displayed in the alert.
snej@12
    47
    @param creating  Is a new passphrase being created? If YES, the user will have to enter the
snej@12
    48
        passphrase twice, to check for errors, and the nifty passphrase-strength meter will be
snej@12
    49
        displayed. If NO, there's only one text-field, and an option to display its contents in
snej@12
    50
        the clear.
snej@12
    51
    @param salt  An arbitrary value whose data will be mixed in with the passphrase before
snej@12
    52
        hashing, to perturb the resulting bits. The purpose of this is to make it harder for
snej@12
    53
        an attacker to brute-force the key using a precompiled list of digests of common
snej@12
    54
        passwords. Changing the salt changes the key, so you need to pass the same value when
snej@12
    55
        re-deriving the key as you did when first generating it. */
snej@12
    56
 + (MYSymmetricKey*) generateFromUserPassphraseWithAlertTitle: (NSString*)alertTitle
snej@12
    57
                                                 alertPrompt: (NSString*)prompt
snej@12
    58
                                                    creating: (BOOL)creating
snej@12
    59
                                                        salt: (id)saltObj;
snej@12
    60
snej@12
    61
/** A utility that prompts for a passphrase, using the Security agent's nice modal panel,
snej@12
    62
    and returns the raw passphrase as a string.
snej@12
    63
    @param alertTitle  A title for the alert (this seems to be ignored by the OS).
snej@12
    64
    @param prompt  A prompt string displayed in the alert.
snej@12
    65
    @param creating  Is a new passphrase being created? 
snej@12
    66
        (See description in +generateFromUserPassphrase... method.) */
snej@12
    67
+ (NSString*) promptForPassphraseWithAlertTitle: (NSString*)alertTitle
snej@12
    68
                                    alertPrompt: (NSString*)prompt
snej@12
    69
                                       creating: (BOOL)creating;
snej@14
    70
#endif TARGET_OS_IPHONE
snej@12
    71
snej@0
    72
@end