]> git.saurik.com Git - apple/security.git/blame - keychain/ckks/CKKSTLKShareRecord.h
Security-59306.41.2.tar.gz
[apple/security.git] / keychain / ckks / CKKSTLKShareRecord.h
CommitLineData
b54c578e
A
1/*
2 * Copyright (c) 2017 Apple Inc. All Rights Reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24#if OCTAGON
25
26#import <Foundation/Foundation.h>
27
28#import "keychain/ckks/CKKS.h"
29#import "keychain/ckks/CKKSItem.h"
30#import "keychain/ckks/CKKSKey.h"
31#import "keychain/ckks/CKKSPeer.h"
32#import "keychain/ckks/CKKSTLKShare.h"
33
34#import <SecurityFoundation/SFEncryptionOperation.h>
35#import <SecurityFoundation/SFKey.h>
36
37NS_ASSUME_NONNULL_BEGIN
38
39@interface CKKSTLKShareRecord : CKKSCKRecordHolder
40@property CKKSTLKShare* share;
41
42// Passthroughs to the underlying share
43@property (readonly) NSString* tlkUUID;
44
45@property (readonly) NSString* senderPeerID;
46
47@property (readonly) NSInteger epoch;
48@property (readonly) NSInteger poisoned;
49
50@property (readonly, nullable) NSData* wrappedTLK;
51@property (readonly, nullable) NSData* signature;
52
53- (instancetype)init NS_UNAVAILABLE;
54
55- (CKKSKey* _Nullable)recoverTLK:(id<CKKSSelfPeer>)recoverer trustedPeers:(NSSet<id<CKKSPeer>>*)peers error:(NSError**)error;
56
57+ (CKKSTLKShareRecord* _Nullable)share:(CKKSKey*)key
58 as:(id<CKKSSelfPeer>)sender
59 to:(id<CKKSPeer>)receiver
60 epoch:(NSInteger)epoch
61 poisoned:(NSInteger)poisoned
62 error:(NSError**)error;
63
64- (bool)signatureVerifiesWithPeerSet:(NSSet<id<CKKSPeer>>*)peerSet error:(NSError**)error;
65
66- (NSData*)dataForSigning;
67
68// Database loading
69+ (instancetype _Nullable)fromDatabase:(NSString*)uuid
70 receiverPeerID:(NSString*)receiverPeerID
71 senderPeerID:(NSString*)senderPeerID
72 zoneID:(CKRecordZoneID*)zoneID
73 error:(NSError* __autoreleasing*)error;
74+ (instancetype _Nullable)tryFromDatabase:(NSString*)uuid
75 receiverPeerID:(NSString*)receiverPeerID
76 senderPeerID:(NSString*)senderPeerID
77 zoneID:(CKRecordZoneID*)zoneID
78 error:(NSError**)error;
79+ (NSArray<CKKSTLKShareRecord*>*)allFor:(NSString*)receiverPeerID
80 keyUUID:(NSString*)uuid
81 zoneID:(CKRecordZoneID*)zoneID
82 error:(NSError* __autoreleasing*)error;
83+ (NSArray<CKKSTLKShareRecord*>*)allForUUID:(NSString*)uuid zoneID:(CKRecordZoneID*)zoneID error:(NSError**)error;
84+ (NSArray<CKKSTLKShareRecord*>*)allInZone:(CKRecordZoneID*)zoneID error:(NSError**)error;
85+ (instancetype _Nullable)tryFromDatabaseFromCKRecordID:(CKRecordID*)recordID error:(NSError**)error;
86
87// Returns a prefix that all every CKKSTLKShare CKRecord will have
88+ (NSString*)ckrecordPrefix;
89
90// For tests
91- (CKKSKey* _Nullable)unwrapUsing:(id<CKKSSelfPeer>)localPeer error:(NSError**)error;
92- (NSData* _Nullable)signRecord:(SFECKeyPair*)signingKey error:(NSError**)error;
93- (bool)verifySignature:(NSData*)signature verifyingPeer:(id<CKKSPeer>)peer error:(NSError**)error;
94@end
95
96NS_ASSUME_NONNULL_END
97
98#endif // OCTAGON