mirror of
https://github.com/google/santa.git
synced 2026-01-14 00:37:56 -05:00
* Fix an issue with santactl fileinfo by implementing NSSecureCoding for SNTRuleIdentifiers.
74 lines
2.3 KiB
Objective-C
74 lines
2.3 KiB
Objective-C
/// Copyright 2024 Google LLC
|
|
///
|
|
/// Licensed under the Apache License, Version 2.0 (the "License");
|
|
/// you may not use this file except in compliance with the License.
|
|
/// You may obtain a copy of the License at
|
|
///
|
|
/// https://www.apache.org/licenses/LICENSE-2.0
|
|
///
|
|
/// Unless required by applicable law or agreed to in writing, software
|
|
/// distributed under the License is distributed on an "AS IS" BASIS,
|
|
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
/// See the License for the specific language governing permissions and
|
|
/// limitations under the License.
|
|
|
|
#import "Source/common/SNTRuleIdentifiers.h"
|
|
|
|
@implementation SNTRuleIdentifiers
|
|
|
|
- (instancetype)initWithRuleIdentifiers:(struct RuleIdentifiers)identifiers {
|
|
self = [super init];
|
|
if (self) {
|
|
_cdhash = identifiers.cdhash;
|
|
_binarySHA256 = identifiers.binarySHA256;
|
|
_signingID = identifiers.signingID;
|
|
_certificateSHA256 = identifiers.certificateSHA256;
|
|
_teamID = identifiers.teamID;
|
|
}
|
|
return self;
|
|
}
|
|
|
|
- (struct RuleIdentifiers)toStruct {
|
|
return (struct RuleIdentifiers){.cdhash = self.cdhash,
|
|
.binarySHA256 = self.binarySHA256,
|
|
.signingID = self.signingID,
|
|
.certificateSHA256 = self.certificateSHA256,
|
|
.teamID = self.teamID};
|
|
}
|
|
|
|
#pragma mark NSSecureCoding
|
|
|
|
#pragma clang diagnostic push
|
|
#pragma clang diagnostic ignored "-Wobjc-literal-conversion"
|
|
#define ENCODE(obj, key) \
|
|
if (obj) [coder encodeObject:obj forKey:key]
|
|
#define DECODE(cls, key) [decoder decodeObjectOfClass:[cls class] forKey:key]
|
|
|
|
+ (BOOL)supportsSecureCoding {
|
|
return YES;
|
|
}
|
|
|
|
- (instancetype)initWithCoder:(NSCoder *)decoder {
|
|
self = [self init];
|
|
if (self) {
|
|
_cdhash = DECODE(NSString, @"cdhash");
|
|
_binarySHA256 = DECODE(NSString, @"binarySHA256");
|
|
_signingID = DECODE(NSString, @"signingID");
|
|
_certificateSHA256 = DECODE(NSString, @"certificateSHA256");
|
|
_teamID = DECODE(NSString, @"teamID");
|
|
}
|
|
return self;
|
|
}
|
|
|
|
- (void)encodeWithCoder:(NSCoder *)coder {
|
|
ENCODE(self.cdhash, @"cdhash");
|
|
ENCODE(self.binarySHA256, @"binarySHA256");
|
|
ENCODE(self.signingID, @"signingID");
|
|
ENCODE(self.certificateSHA256, @"certificateSHA256");
|
|
ENCODE(self.teamID, @"teamID");
|
|
}
|
|
|
|
#pragma clang diagnostic pop
|
|
|
|
@end
|