mirror of
https://github.com/google/santa.git
synced 2026-04-24 03:00:12 -04:00
* * Added Xcode project + pods * Cleaned up unused SNTXPCUnprivilegedControlInterface MachServices id. * Change santad's MachServices id to be compatible with the default SystemExtension namespace template. * pods * bazel * switch MachService name for 10.15+ * build with SystemExensions framework * build with Xcode 11 * launchd.plist fix * use @available * * Request SystemExtension activation on a background thread. * Create a constant for the "com.google.santa.daemon" SystemExtension id.
85 lines
2.9 KiB
Objective-C
85 lines
2.9 KiB
Objective-C
/// Copyright 2015 Google Inc. All rights reserved.
|
|
///
|
|
/// 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
|
|
///
|
|
/// http://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/SNTXPCUnprivilegedControlInterface.h"
|
|
|
|
///
|
|
/// Protocol implemented by santad and utilized by santactl (privileged operations)
|
|
///
|
|
@protocol SNTDaemonControlXPC <SNTUnprivilegedDaemonControlXPC>
|
|
|
|
///
|
|
/// Kernel ops
|
|
///
|
|
- (void)flushCache:(void (^)(BOOL))reply;
|
|
|
|
///
|
|
/// Database ops
|
|
///
|
|
- (void)databaseRuleAddRules:(NSArray *)rules
|
|
cleanSlate:(BOOL)cleanSlate
|
|
reply:(void (^)(NSError *error))reply;
|
|
- (void)databaseEventsPending:(void (^)(NSArray *events))reply;
|
|
- (void)databaseRemoveEventsWithIDs:(NSArray *)ids;
|
|
- (void)databaseRuleForBinarySHA256:(NSString *)binarySHA256
|
|
certificateSHA256:(NSString *)certificateSHA256
|
|
reply:(void (^)(SNTRule *))reply;
|
|
|
|
///
|
|
/// Config ops
|
|
///
|
|
- (void)setClientMode:(SNTClientMode)mode reply:(void (^)(void))reply;
|
|
- (void)setXsrfToken:(NSString *)token reply:(void (^)(void))reply;
|
|
- (void)setFullSyncLastSuccess:(NSDate *)date reply:(void (^)(void))reply;
|
|
- (void)setRuleSyncLastSuccess:(NSDate *)date reply:(void (^)(void))reply;
|
|
- (void)setSyncCleanRequired:(BOOL)cleanReqd reply:(void (^)(void))reply;
|
|
- (void)setWhitelistPathRegex:(NSString *)pattern reply:(void (^)(void))reply;
|
|
- (void)setBlacklistPathRegex:(NSString *)pattern reply:(void (^)(void))reply;
|
|
- (void)setEnableBundles:(BOOL)bundlesEnabled reply:(void (^)(void))reply;
|
|
- (void)setEnableTransitiveWhitelisting:(BOOL)enabled reply:(void (^)(void))reply;
|
|
|
|
///
|
|
/// Syncd Ops
|
|
///
|
|
- (void)setSyncdListener:(NSXPCListenerEndpoint *)listener;
|
|
- (void)postRuleSyncNotificationWithCustomMessage:(NSString *)message reply:(void (^)(void))reply;
|
|
|
|
@end
|
|
|
|
@interface SNTXPCControlInterface : NSObject
|
|
|
|
///
|
|
/// Returns the MachService ID for this service.
|
|
///
|
|
+ (NSString *)serviceID;
|
|
|
|
///
|
|
/// Returns the SystemExtension ID for this service.
|
|
///
|
|
+ (NSString *)systemExtensionID;
|
|
|
|
///
|
|
/// Returns an initialized NSXPCInterface for the SNTUnprivilegedDaemonControlXPC protocol.
|
|
/// Ensures any methods that accept custom classes as arguments are set-up before returning
|
|
///
|
|
+ (NSXPCInterface *)controlInterface;
|
|
|
|
///
|
|
/// Retrieve a pre-configured MOLXPCConnection for communicating with santad.
|
|
/// Connections just needs any handlers set and then can be resumed and used.
|
|
///
|
|
+ (MOLXPCConnection *)configuredConnection;
|
|
|
|
@end
|