mirror of https://github.com/oxen-io/session-ios
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			92 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Objective-C
		
	
			
		
		
	
	
			92 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Objective-C
		
	
| //
 | |
| //  Copyright (c) 2018 Open Whisper Systems. All rights reserved.
 | |
| //
 | |
| 
 | |
| #import "OWSScrubbingLogFormatter.h"
 | |
| 
 | |
| NS_ASSUME_NONNULL_BEGIN
 | |
| 
 | |
| @implementation OWSScrubbingLogFormatter
 | |
| 
 | |
| - (NSRegularExpression *)phoneRegex
 | |
| {
 | |
|     static NSRegularExpression *regex = nil;
 | |
|     static dispatch_once_t onceToken;
 | |
|     dispatch_once(&onceToken, ^{
 | |
|         NSError *error;
 | |
|         regex = [NSRegularExpression regularExpressionWithPattern:@"\\+\\d{7,12}(\\d{3})"
 | |
|                                                           options:NSRegularExpressionCaseInsensitive
 | |
|                                                             error:&error];
 | |
|         if (error || !regex) {
 | |
|             OWSFail(@"could not compile regular expression: %@", error);
 | |
|         }
 | |
|     });
 | |
|     return regex;
 | |
| }
 | |
| 
 | |
| - (NSRegularExpression *)dataRegex
 | |
| {
 | |
|     static NSRegularExpression *regex = nil;
 | |
|     static dispatch_once_t onceToken;
 | |
|     dispatch_once(&onceToken, ^{
 | |
|         NSError *error;
 | |
|         regex = [NSRegularExpression regularExpressionWithPattern:@"<([\\da-f]{2})[\\da-f]{6}( [\\da-f]{8})*>"
 | |
|                                                           options:NSRegularExpressionCaseInsensitive
 | |
|                                                             error:&error];
 | |
|         if (error || !regex) {
 | |
|             OWSFail(@"could not compile regular expression: %@", error);
 | |
|         }
 | |
|     });
 | |
|     return regex;
 | |
| }
 | |
| 
 | |
| - (NSRegularExpression *)ipV4AddressRegex
 | |
| {
 | |
|     static NSRegularExpression *regex = nil;
 | |
|     static dispatch_once_t onceToken;
 | |
|     dispatch_once(&onceToken, ^{
 | |
|         // NOTE: The group matches the last quad of the IPv4 address.
 | |
|         NSError *error;
 | |
|         regex = [NSRegularExpression regularExpressionWithPattern:@"\\d+\\.\\d+\\.\\d+\\.(\\d+)"
 | |
|                                                           options:NSRegularExpressionCaseInsensitive
 | |
|                                                             error:&error];
 | |
|         if (error || !regex) {
 | |
|             OWSFail(@"could not compile regular expression: %@", error);
 | |
|         }
 | |
|     });
 | |
|     return regex;
 | |
| }
 | |
| 
 | |
| - (NSString *__nullable)formatLogMessage:(DDLogMessage *)logMessage
 | |
| {
 | |
|     NSString *logString = [super formatLogMessage:logMessage];
 | |
| 
 | |
|     NSRegularExpression *phoneRegex = self.phoneRegex;
 | |
|     logString = [phoneRegex stringByReplacingMatchesInString:logString
 | |
|                                                      options:0
 | |
|                                                        range:NSMakeRange(0, [logString length])
 | |
|                                                 withTemplate:@"[ REDACTED_PHONE_NUMBER:xxx$1 ]"];
 | |
| 
 | |
| 
 | |
|     // We capture only the first two characters of the hex string for logging.
 | |
|     // example log line: "Called someFunction with nsData: <01234567 89abcdef>"
 | |
|     //  scrubbed output: "Called someFunction with nsData: [ REDACTED_DATA:01 ]"
 | |
|     NSRegularExpression *dataRegex = self.dataRegex;
 | |
|     logString = [dataRegex stringByReplacingMatchesInString:logString
 | |
|                                                     options:0
 | |
|                                                       range:NSMakeRange(0, [logString length])
 | |
|                                                withTemplate:@"[ REDACTED_DATA:$1... ]"];
 | |
| 
 | |
|     NSRegularExpression *ipV4AddressRegex = self.ipV4AddressRegex;
 | |
|     logString = [ipV4AddressRegex stringByReplacingMatchesInString:logString
 | |
|                                                            options:0
 | |
|                                                              range:NSMakeRange(0, [logString length])
 | |
|                                                       withTemplate:@"[ REDACTED_IPV4_ADDRESS:...$1 ]"];
 | |
| 
 | |
|     return logString;
 | |
| }
 | |
| 
 | |
| @end
 | |
| 
 | |
| NS_ASSUME_NONNULL_END
 |