You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

100 lines
2.6 KiB

  1. //
  2. // FLEXSystemLogMessage.m
  3. // FLEX
  4. //
  5. // Created by Ryan Olson on 1/25/15.
  6. // Copyright (c) 2015 f. All rights reserved.
  7. //
  8. #import "FLEXSystemLogMessage.h"
  9. @implementation FLEXSystemLogMessage
  10. + (instancetype)logMessageFromASLMessage:(aslmsg)aslMessage
  11. {
  12. NSDate *date = nil;
  13. NSString *sender = nil, *text = nil;
  14. long long identifier = 0;
  15. const char *timestamp = asl_get(aslMessage, ASL_KEY_TIME);
  16. if (timestamp) {
  17. NSTimeInterval timeInterval = [@(timestamp) integerValue];
  18. const char *nanoseconds = asl_get(aslMessage, ASL_KEY_TIME_NSEC);
  19. if (nanoseconds) {
  20. timeInterval += [@(nanoseconds) doubleValue] / NSEC_PER_SEC;
  21. }
  22. date = [NSDate dateWithTimeIntervalSince1970:timeInterval];
  23. }
  24. const char *s = asl_get(aslMessage, ASL_KEY_SENDER);
  25. if (s) {
  26. sender = @(s);
  27. }
  28. const char *messageText = asl_get(aslMessage, ASL_KEY_MSG);
  29. if (messageText) {
  30. text = @(messageText);
  31. }
  32. const char *messageID = asl_get(aslMessage, ASL_KEY_MSG_ID);
  33. if (messageID) {
  34. identifier = [@(messageID) longLongValue];
  35. }
  36. FLEXSystemLogMessage *message = [[self alloc] initWithDate:date sender:sender text:text messageID:identifier];
  37. message->_aslMessage = aslMessage;
  38. return message;
  39. }
  40. + (instancetype)logMessageFromOSLog:(os_log_message_t)logMessage
  41. {
  42. abort();
  43. return nil;
  44. }
  45. + (instancetype)logMessageFromDate:(NSDate *)date text:(NSString *)text
  46. {
  47. return [[self alloc] initWithDate:date sender:nil text:text messageID:0];
  48. }
  49. - (id)initWithDate:(NSDate *)date sender:(NSString *)sender text:(NSString *)text messageID:(long long)identifier
  50. {
  51. self = [super init];
  52. if (self) {
  53. _date = date;
  54. _sender = sender;
  55. _messageText = text;
  56. _messageID = identifier;
  57. }
  58. return self;
  59. }
  60. - (BOOL)isEqual:(id)object
  61. {
  62. if ([object isKindOfClass:[self class]]) {
  63. if (self.messageID) {
  64. // Only ASL uses messageID, otherwise it is 0
  65. return self.messageID == [object messageID];
  66. } else {
  67. // Test message texts and dates for OS Log
  68. return [self.messageText isEqual:[object messageText]] &&
  69. [self.date isEqualToDate:[object date]];
  70. }
  71. }
  72. return NO;
  73. }
  74. - (NSUInteger)hash
  75. {
  76. return (NSUInteger)self.messageID;
  77. }
  78. - (NSString *)description
  79. {
  80. NSString *escaped = [self.messageText stringByReplacingOccurrencesOfString:@"\n" withString:@"\\n"];
  81. return [NSString stringWithFormat:@"(%@) %@", @(self.messageText.length), escaped];
  82. }
  83. @end