mirror of
https://github.com/google/santa.git
synced 2026-04-24 03:00:12 -04:00
* WIP: UI: open cert modal, hookup silence checkbox. Add cert helper funcs. * Popup dialog on file access violation. Support config-based and custom messages. * Send message to TTY on file access rule violation * TTYWriter Write now takes an es_process_t. Fix async data lifespan issue. * Dedupe TTY message printing per process per rule * Some minor swift beautification * Remove main app from dock when showing file access dialog * Update header docs * Remove define guards for ObjC header file * Update Source/common/CertificateHelpers.h Co-authored-by: Russell Hancox <russellhancox@users.noreply.github.com> * Fix comment typo Co-authored-by: Russell Hancox <russellhancox@users.noreply.github.com> * Use #import for ObjC headers * Use #import for ObjC header Co-authored-by: Russell Hancox <russellhancox@users.noreply.github.com> * lint * Comment use of escape sequences --------- Co-authored-by: Russell Hancox <russellhancox@users.noreply.github.com>
43 lines
1.5 KiB
Objective-C
43 lines
1.5 KiB
Objective-C
/// Copyright 2023 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/CertificateHelpers.h"
|
|
|
|
#include <Security/SecCertificate.h>
|
|
|
|
NSString *Publisher(NSArray<MOLCertificate *> *certs, NSString *teamID) {
|
|
MOLCertificate *leafCert = [certs firstObject];
|
|
|
|
if ([leafCert.commonName isEqualToString:@"Apple Mac OS Application Signing"]) {
|
|
return [NSString stringWithFormat:@"App Store (Team ID: %@)", teamID];
|
|
} else if (leafCert.commonName && leafCert.orgName) {
|
|
return [NSString stringWithFormat:@"%@ - %@", leafCert.orgName, leafCert.commonName];
|
|
} else if (leafCert.commonName) {
|
|
return leafCert.commonName;
|
|
} else if (leafCert.orgName) {
|
|
return leafCert.orgName;
|
|
} else {
|
|
return nil;
|
|
}
|
|
}
|
|
|
|
NSArray<id> *CertificateChain(NSArray<MOLCertificate *> *certs) {
|
|
NSMutableArray *certArray = [NSMutableArray arrayWithCapacity:[certs count]];
|
|
for (MOLCertificate *cert in certs) {
|
|
[certArray addObject:(id)cert.certRef];
|
|
}
|
|
|
|
return certArray;
|
|
}
|