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.
		
		
		
		
		
			
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Objective-C
		
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Objective-C
		
	
| //
 | |
| //  Copyright (c) 2017 Open Whisper Systems. All rights reserved.
 | |
| //
 | |
| 
 | |
| #import "OWSScrubbingLogFormatter.h"
 | |
| 
 | |
| NS_ASSUME_NONNULL_BEGIN
 | |
| 
 | |
| @implementation OWSScrubbingLogFormatter
 | |
| 
 | |
| - (NSString *__nullable)formatLogMessage:(DDLogMessage *)logMessage
 | |
| {
 | |
|     NSString *logString = [super formatLogMessage:logMessage];
 | |
|     NSRegularExpression *phoneRegex =
 | |
|         [NSRegularExpression regularExpressionWithPattern:@"\\+\\d{7,12}(\\d{3})"
 | |
|                                                   options:NSRegularExpressionCaseInsensitive
 | |
|                                                     error:nil];
 | |
| 
 | |
|     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 =
 | |
|         [NSRegularExpression regularExpressionWithPattern:@"<([\\da-f]{2})[\\da-f]{6}( [\\da-f]{8})*>"
 | |
|                                                   options:NSRegularExpressionCaseInsensitive
 | |
|                                                     error:nil];
 | |
| 
 | |
|     logString = [dataRegex stringByReplacingMatchesInString:logString
 | |
|                                                     options:0
 | |
|                                                       range:NSMakeRange(0, [logString length])
 | |
|                                                withTemplate:@"[ REDACTED_DATA:$1... ]"];
 | |
| 
 | |
|     return logString;
 | |
| }
 | |
| 
 | |
| @end
 | |
| 
 | |
| NS_ASSUME_NONNULL_END
 |