示例#1
0
def createCmd(domain, user, path):
    '''
    Creates the cmd buffer to run. The path is the task to execute.
    '''
    req = tsch.SchRpcRegisterTask("00000200 00000000 03000000 00000000 00000000 00000000 03000000 00000000 61006100 00000000 47050000 00000000 00000000 00000000 47050000 00000000 3C003F00 78006D00 6C002000 76006500 72007300 69006F00 6E003D00 22003100 2E003000 22002000 65006E00 63006F00 64006900 6E006700 3D002200 55005400 46002D00 31003600 22003F00 3E000D00 0A003C00 54006100 73006B00 20007600 65007200 73006900 6F006E00 3D002200 31002E00 32002200 20007800 6D006C00 6E007300 3D002200 68007400 74007000 3A002F00 2F007300 63006800 65006D00 61007300 2E006D00 69006300 72006F00 73006F00 66007400 2E006300 6F006D00 2F007700 69006E00 64006F00 77007300 2F003200 30003000 34002F00 30003200 2F006D00 69007400 2F007400 61007300 6B002200 3E000D00 0A002000 20003C00 52006500 67006900 73007400 72006100 74006900 6F006E00 49006E00 66006F00 3E000D00 0A002000 20002000 20003C00 44006100 74006500 3E003200 30003100 37002D00 30003500 2D003100 30005400 30003600 3A003200 39003A00 32003800 3C002F00 44006100 74006500 3E000D00 0A002000 20002000 20003C00 41007500 74006800 6F007200 3E004100 64006D00 69006E00 69007300 74007200 61007400 6F007200 3C002F00 41007500 74006800 6F007200 3E000D00 0A002000 20003C00 2F005200 65006700 69007300 74007200 61007400 69006F00 6E004900 6E006600 6F003E00 0D000A00 20002000 3C005400 72006900 67006700 65007200 73003E00 0D000A00 20002000 20002000 3C005400 69006D00 65005400 72006900 67006700 65007200 3E000D00 0A002000 20002000 20002000 20003C00 53007400 61007200 74004200 6F007500 6E006400 61007200 79003E00 32003000 31003700 2D003000 35002D00 31003000 54003100 34003A00 30003000 3A003000 30003C00 2F005300 74006100 72007400 42006F00 75006E00 64006100 72007900 3E000D00 0A002000 20002000 20002000 20003C00 45006E00 61006200 6C006500 64003E00 74007200 75006500 3C002F00 45006E00 61006200 6C006500 64003E00 0D000A00 20002000 20002000 3C002F00 54006900 6D006500 54007200 69006700 67006500 72003E00 0D000A00 20002000 3C002F00 54007200 69006700 67006500 72007300 3E000D00 0A002000 20003C00 53006500 74007400 69006E00 67007300 3E000D00 0A002000 20002000 20003C00 4D007500 6C007400 69007000 6C006500 49006E00 73007400 61006E00 63006500 73005000 6F006C00 69006300 79003E00 49006700 6E006F00 72006500 4E006500 77003C00 2F004D00 75006C00 74006900 70006C00 65004900 6E007300 74006100 6E006300 65007300 50006F00 6C006900 63007900 3E000D00 0A002000 20002000 20003C00 44006900 73006100 6C006C00 6F007700 53007400 61007200 74004900 66004F00 6E004200 61007400 74006500 72006900 65007300 3E007400 72007500 65003C00 2F004400 69007300 61006C00 6C006F00 77005300 74006100 72007400 49006600 4F006E00 42006100 74007400 65007200 69006500 73003E00 0D000A00 20002000 20002000 3C005300 74006F00 70004900 66004700 6F006900 6E006700 4F006E00 42006100 74007400 65007200 69006500 73003E00 74007200 75006500 3C002F00 53007400 6F007000 49006600 47006F00 69006E00 67004F00 6E004200 61007400 74006500 72006900 65007300 3E000D00 0A002000 20002000 20003C00 41006C00 6C006F00 77004800 61007200 64005400 65007200 6D006900 6E006100 74006500 3E007400 72007500 65003C00 2F004100 6C006C00 6F007700 48006100 72006400 54006500 72006D00 69006E00 61007400 65003E00 0D000A00 20002000 20002000 3C005300 74006100 72007400 57006800 65006E00 41007600 61006900 6C006100 62006C00 65003E00 66006100 6C007300 65003C00 2F005300 74006100 72007400 57006800 65006E00 41007600 61006900 6C006100 62006C00 65003E00 0D000A00 20002000 20002000 3C005200 75006E00 4F006E00 6C007900 49006600 4E006500 74007700 6F007200 6B004100 76006100 69006C00 61006200 6C006500 3E006600 61006C00 73006500 3C002F00 52007500 6E004F00 6E006C00 79004900 66004E00 65007400 77006F00 72006B00 41007600 61006900 6C006100 62006C00 65003E00 0D000A00 20002000 20002000 3C004900 64006C00 65005300 65007400 74006900 6E006700 73003E00 0D000A00 20002000 20002000 20002000 3C004400 75007200 61007400 69006F00 6E003E00 50005400 31003000 4D003C00 2F004400 75007200 61007400 69006F00 6E003E00 0D000A00 20002000 20002000 20002000 3C005700 61006900 74005400 69006D00 65006F00 75007400 3E005000 54003100 48003C00 2F005700 61006900 74005400 69006D00 65006F00 75007400 3E000D00 0A002000 20002000 20002000 20003C00 53007400 6F007000 4F006E00 49006400 6C006500 45006E00 64003E00 74007200 75006500 3C002F00 53007400 6F007000 4F006E00 49006400 6C006500 45006E00 64003E00 0D000A00 20002000 20002000 20002000 3C005200 65007300 74006100 72007400 4F006E00 49006400 6C006500 3E006600 61006C00 73006500 3C002F00 52006500 73007400 61007200 74004F00 6E004900 64006C00 65003E00 0D000A00 20002000 20002000 3C002F00 49006400 6C006500 53006500 74007400 69006E00 67007300 3E000D00 0A002000 20002000 20003C00 41006C00 6C006F00 77005300 74006100 72007400 4F006E00 44006500 6D006100 6E006400 3E007400 72007500 65003C00 2F004100 6C006C00 6F007700 53007400 61007200 74004F00 6E004400 65006D00 61006E00 64003E00 0D000A00 20002000 20002000 3C004500 6E006100 62006C00 65006400 3E007400 72007500 65003C00 2F004500 6E006100 62006C00 65006400 3E000D00 0A002000 20002000 20003C00 48006900 64006400 65006E00 3E006600 61006C00 73006500 3C002F00 48006900 64006400 65006E00 3E000D00 0A002000 20002000 20003C00 52007500 6E004F00 6E006C00 79004900 66004900 64006C00 65003E00 66006100 6C007300 65003C00 2F005200 75006E00 4F006E00 6C007900 49006600 49006400 6C006500 3E000D00 0A002000 20002000 20003C00 57006100 6B006500 54006F00 52007500 6E003E00 66006100 6C007300 65003C00 2F005700 61006B00 65005400 6F005200 75006E00 3E000D00 0A002000 20002000 20003C00 45007800 65006300 75007400 69006F00 6E005400 69006D00 65004C00 69006D00 69007400 3E005000 54003700 32004800 3C002F00 45007800 65006300 75007400 69006F00 6E005400 69006D00 65004C00 69006D00 69007400 3E000D00 0A002000 20002000 20003C00 50007200 69006F00 72006900 74007900 3E003700 3C002F00 50007200 69006F00 72006900 74007900 3E000D00 0A002000 20003C00 2F005300 65007400 74006900 6E006700 73003E00 0D000A00 20002000 3C004100 63007400 69006F00 6E007300 3E000D00 0A002000 20002000 20003C00 45007800 65006300 3E000D00 0A002000 20002000 20002000 20003C00 43006F00 6D006D00 61006E00 64003E00 63006100 6C006300 2E006500 78006500 3C002F00 43006F00 6D006D00 61006E00 64003E00 0D000A00 20002000 20002000 3C002F00 45007800 65006300 3E000D00 0A002000 20003C00 2F004100 63007400 69006F00 6E007300 3E000D00 0A003C00 2F005400 61007300 6B003E00 00000000 06000000 00000000 00000000 00000000 03000000 01000000 00000200 00000000 01000000 00000000 00000200 00000000 00000000 00000000 01000000 00000000 16000000 00000000 00000000 00000000 16000000 00000000 50005200 45004500 4D005000 54005C00 41006400 6D006900 6E006900 73007400 72006100 74006F00 72000000 00000000 00000000 00000000".replace(" ","").decode('hex'),isNDR64=True)
    if domain:
        req['pCreds'][0]['userId']=u'%s\\%s\x00' % (domain,user)
    else:
        req['pCreds'][0]['userId']=u'%s\x00' % (user)
    x=u"""<?xml version="1.0"?>
    <Task xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
    <Triggers>
    <RegistrationTrigger/>
    </Triggers>
    <Settings>
    <DisallowStartIfOnBatteries>false</DisallowStartIfOnBatteries>
    <StopIfGoingOnBatteries>false</StopIfGoingOnBatteries>
    <IdleSettings>
      <StopOnIdleEnd>false</StopOnIdleEnd>
    </IdleSettings>
    </Settings>
    <Actions>
    <Exec>
    <Command>%s</Command>
    </Exec>
    </Actions>
    </Task>\x00""" % (path)
    req.fields['path']["ReferentID"]= int(('3082010a02820101'),16)
    req['xml'] = x.replace('\n    ','') #notice the padding
    s=str(req)#
    s+=((4-len(s)%8)%8)*'\x00' #here we align the output so that no further pading bytes will be added
    return req ,s
示例#2
0
    def tes_SchRpcRegisterTask(self):
        dce, rpctransport = self.connect(self.stringBindingAtSvc,
                                         tsch.MSRPC_UUID_TSCHS)

        xml = """
<!-- Task -->
<xs:complexType name="taskType">
<xs:all>
<xs:element name="RegistrationInfo" type="registrationInfoType" minOccurs="0"/>
<xs:element name="Triggers" type="triggersType" minOccurs="0"/>
<xs:element name="Settings" type="settingsType" minOccurs="0"/>
<xs:element name="Data" type="dataType" minOccurs="0"/>
<xs:element name="Principals" type="principalsType" minOccurs="0"/>
<xs:element name="Actions" type="actionsType"/>
</xs:all>
<xs:attribute name="version" type="versionType" use="optional"/> </xs:complexType>\x00
"""
        request = tsch.SchRpcRegisterTask()
        request['path'] = NULL
        request['xml'] = xml
        request['flags'] = 1
        request['sddl'] = NULL
        request['logonType'] = tsch.TASK_LOGON_NONE
        request['cCreds'] = 0
        request['pCreds'] = NULL
        resp = dce.request(request)
        resp.dump()