lmco / laikaboss

Laika BOSS: Object Scanning System
Apache License 2.0
732 stars 155 forks source link

New Explode Module: EXPLODE_VBA #63

Open askkemp opened 7 years ago

askkemp commented 7 years ago

Note: jshlbrd also has a pull request for a module that does VBA extraction. My module in addition does file extraction (explode) and metadata for forms. Otherwise, they are similar.

explode_vba.py is a scanning module to explode the VBA inside objects. It uses olevba from decalage's oletools to perform the object extraction.

Quick note: Olevba has some object explosion built into the code. For example, it can look inside DOCX files for VBA. I tried to stay away from explosions done inside the decalage code and instead rely on Laika BOSS for explosion. To continue with the previous example, Laika BOSS will explode the ZIP and then this module will pick up the compressed VBA object and extract the macro from it.

Input are OLE document files and output is metadata and extracted objects. Most supported formats listed at https://bitbucket.org/decalage/oletools/wiki/olevba which use olevba's VBA_Parser module willw work as long as it is also configured in dispatch.yara

Here are my notes added to decalage's "Supported formats"

Output: Extracted and decompressed VBA objects (macro and forms). Module also adds basic metadata about the object when possible.

Below I use a Office 2007 Word sample (zip). I run olevba against the file which uses its native exploding code and shows that there are macros and forms. I then show the scan output from EXPLODE_VBA which shows the collected metadata. This is followed by examples of the actual extracted files.

By running the EXPLODE_VBA module in conjuction with EXPLODE_ZIP and EXPLODE_OLE, the macros are successfully extracted.

[user@localhost laikaboss]# file mysample.docx

mysample.docx: Microsoft Word 2007+
[user@localhost laikaboss]# hexdump -Cv mysample.docx | head
00000000  50 4b 03 04 14 00 06 00  08 00 00 00 21 00 84 98  |PK..........!...|
00000010  01 20 94 01 00 00 2a 06  00 00 13 00 08 02 5b 43  |. ....*.......[C|
00000020  6f 6e 74 65 6e 74 5f 54  79 70 65 73 5d 2e 78 6d  |ontent_Types].xm|
[user@localhost laikaboss]# olevba -a mysample.docx
olevba 0.50 - http://decalage.info/python/oletools
Flags        Filename
-----------  -----------------------------------------------------------------
OpX:MASIHB-- mysample.docx
===============================================================================
FILE: mysample.docx
Type: OpenXML
-------------------------------------------------------------------------------
VBA MACRO Dard.cls
in file: word/vbaProject.bin - OLE stream: u'VBA/Dard'
-------------------------------------------------------------------------------
VBA MACRO sTVOL.frm
in file: word/vbaProject.bin - OLE stream: u'VBA/sTVOL'
-------------------------------------------------------------------------------
VBA MACRO A0.bas
in file: word/vbaProject.bin - OLE stream: u'VBA/A0'
-------------------------------------------------------------------------------
VBA MACRO Ishimitsu.cls
in file: word/vbaProject.bin - OLE stream: u'VBA/Ishimitsu'
-------------------------------------------------------------------------------
VBA MACRO Module1.bas
in file: word/vbaProject.bin - OLE stream: u'VBA/Module1'
-------------------------------------------------------------------------------
VBA MACRO Module2.bas
in file: word/vbaProject.bin - OLE stream: u'VBA/Module2'
-------------------------------------------------------------------------------
VBA MACRO Class1.cls
in file: word/vbaProject.bin - OLE stream: u'VBA/Class1'
-------------------------------------------------------------------------------
VBA MACRO Z1.bas
in file: word/vbaProject.bin - OLE stream: u'VBA/Z1'
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
▒rundll32.exe
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
▒http://
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma/
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
setRequestHeader
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Microsoft.XMLHTTPPPAPAdodb.streaMPPAPshell.ApplicationPPAPWscript.shellPPAPProcessPPAPGeTPPAPTeMPPPAPTypePPAPopenPPAPwritePPAPresponseBodyPPAPsavetofilePPAP\shubert.aza
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hoOptionButton1der
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hoSend
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
ratatu
-------------------------------------------------------------------------------
VBA FORM STRING IN 'word/vbaProject.bin' - OLE stream: u'sTVOL/o'
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Tahoma

-> Metadata collected from Module

        "EXPLODE_VBA": {
          "Parsed_Macros_Metadata": [
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/Dard",
              "Type": "OLE",
              "VBA_filename": "Dard.cls"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/sTVOL",
              "Type": "OLE",
              "VBA_filename": "sTVOL.frm"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/A0",
              "Type": "OLE",
              "VBA_filename": "A0.bas"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/Ishimitsu",
              "Type": "OLE",
              "VBA_filename": "Ishimitsu.cls"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/Module1",
              "Type": "OLE",
              "VBA_filename": "Module1.bas"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/Module2",
              "Type": "OLE",
              "VBA_filename": "Module2.bas"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/Class1",
              "Type": "OLE",
              "VBA_filename": "Class1.cls"
            },
            {
              "VBA_project": [
                "('', 'PROJECT', 'VBA/dir')"
              ],
              "OLE_stream": "VBA/Z1",
              "Type": "OLE",
              "VBA_filename": "Z1.bas"
            }
          ],
          "VBA_Forms_Found_Streams": [
            "sTVOL/o"
          ]

-> Showing the files exploded and their filenames

[user@localhost laikaboss]# ls -lart ~/EXPLODED/0bf5e6c6-0dad-404c-a69e-30bf4a9962ce/ | grep e_vba
e_vba_6b35ca7ccdf6a2221cacab994faa4349_Z1.bas
e_vba_6b35ca7ccdf6a2221cacab994faa4349_Module2.bas
e_vba_6b35ca7ccdf6a2221cacab994faa4349_Dard.cls
e_vba_6b35ca7ccdf6a2221cacab994faa4349_A0.bas
e_vba_6b35ca7ccdf6a2221cacab994faa4349_sTVOL.frm
e_vba_6b35ca7ccdf6a2221cacab994faa4349_Ishimitsu.cls
e_vba_6b35ca7ccdf6a2221cacab994faa4349_Module1.bas
e_vba_6b35ca7ccdf6a2221cacab994faa4349_combined_forms.txt
e_vba_6b35ca7ccdf6a2221cacab994faa4349_Class1.cls

Dispatch.yara change to make this module run against OLEs, Word2003 XML, and MHTML.

rule type_is_msoffice2003
{
    meta:
        scan_modules = "EXPLODE_OLE(minFileSize=128) EXPLODE_VBA"
        file_type = "ole"
    strings:
        $a = { D0 CF 11 E0 A1 B1 1A E1 }
    condition:
        $a at 0
}

rule type_is_msoffice2003xml
{
    meta:
        scan_modules = "EXPLODE_VBA"
        file_type = "xml"
    strings:
       $a = { 3c 3f 78 6d 6c 20 76 65 72 73 69 6f 6e 3d } //<?xml version=        
       $b = "http://schemas.microsoft.com/office/word/2003/wordml"
    condition:
        $a at 0 and $b
}

rule type_is_msofficemhtml
{
    meta:
        scan_modules = "EXPLODE_VBA"
        file_type = "mhtml"
    strings:
        $a = "MIME-Version: 1.0"
        $b = "This document is a Single File Web Page, also known as a Web Archive file"
    condition:
        $a at 0 and $b
}