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.

94 lines
2.5 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)logMessageFromDate:(NSDate *)date text:(NSString *)text
  41. {
  42. return [[self alloc] initWithDate:date sender:nil text:text messageID:0];
  43. }
  44. - (id)initWithDate:(NSDate *)date sender:(NSString *)sender text:(NSString *)text messageID:(long long)identifier
  45. {
  46. self = [super init];
  47. if (self) {
  48. _date = date;
  49. _sender = sender;
  50. _messageText = text;
  51. _messageID = identifier;
  52. }
  53. return self;
  54. }
  55. - (BOOL)isEqual:(id)object
  56. {
  57. if ([object isKindOfClass:[self class]]) {
  58. if (self.messageID) {
  59. // Only ASL uses messageID, otherwise it is 0
  60. return self.messageID == [object messageID];
  61. } else {
  62. // Test message texts and dates for OS Log
  63. return [self.messageText isEqual:[object messageText]] &&
  64. [self.date isEqualToDate:[object date]];
  65. }
  66. }
  67. return NO;
  68. }
  69. - (NSUInteger)hash
  70. {
  71. return (NSUInteger)self.messageID;
  72. }
  73. - (NSString *)description
  74. {
  75. NSString *escaped = [self.messageText stringByReplacingOccurrencesOfString:@"\n" withString:@"\\n"];
  76. return [NSString stringWithFormat:@"(%@) %@", @(self.messageText.length), escaped];
  77. }
  78. @end