return sid
+def call_fn(fn, pipe, args):
+ """Wrap up a RPC call and throw an exception is an error was returned."""
+
+ result = fn(pipe, args);
+ if result & 0xc0000000:
+ raise dcerpc.NTSTATUS(result, dcerpc.nt_errstr(result));
+
+ return result;
+
+
class SamrHandle:
def __init__(self, pipe, handle):
r = dcerpc.samr_Close()
r.data_in.handle = self.handle
- dcerpc.dcerpc_samr_Close(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Close, self.pipe, r)
self.handle = None
r.data_in.handle = self.handle
r.data_in.sec_info = sec_info
- result = dcerpc.dcerpc_samr_QuerySecurity(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_QuerySecurity, self.pipe, r)
return r.data_out.sdbuf
r.data_in.sec_info = sec_info
r.data_in.sdbuf = sdbuf
- result = dcerpc.dcerpc_samr_SetSecurity(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_SetSecurity, self.pipe, r)
class ConnectHandle(SamrHandle):
while 1:
- result = dcerpc.dcerpc_samr_EnumDomains(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_EnumDomains, self.pipe, r)
for i in range(r.data_out.sam.count):
domains.append(dcerpc.samr_SamEntry_array_getitem(
r.data_in.domain = dcerpc.samr_String()
r.data_in.domain.string = domain_name
- result = dcerpc.dcerpc_samr_LookupDomain(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_LookupDomain, self.pipe, r)
return sid_to_string(r.data_out.sid);
r.data_in.access_mask = access_mask
r.data_in.sid = string_to_sid(domain_sid)
- result = dcerpc.dcerpc_samr_OpenDomain(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_OpenDomain, self.pipe, r)
return DomainHandle(self.pipe, r.data_out.domain_handle)
r = dcerpc.samr_Shutdown()
r.data_in.connect_handle = self.handle
- result = dcerpc.dcerpc_samr_Shutdown(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Shutdown, self.pipe, r)
class DomainHandle(SamrHandle):
r.data_in.domain_handle = self.handle
r.data_in.level = level
- result = dcerpc.dcerpc_samr_QueryDomainInfo(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_QueryDomainInfo, self.pipe, r)
return getattr(r.data_out.info, 'info%d' % level)
r.data_in.domain_handle = self.handle
r.data_in.level = level
- result = dcerpc.dcerpc_samr_QueryDomainInfo2(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_QueryDomainInfo2, self.pipe, r)
return getattr(r.data_out.info, 'info%d' % level)
r.data_in.resume_handle = 0
r.data_in.max_size = 1000
- result = dcerpc.dcerpc_samr_EnumDomainGroups(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_EnumDomainGroups, self.pipe, r)
groups = []
# no meaning so use 0xffffffff like W2K
r.data_in.acct_flags = 0xffffffffL
- result = dcerpc.dcerpc_samr_EnumDomainAliases(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_EnumDomainAliases, self.pipe, r)
aliases = []
r.data_in.acct_flags = user_account_flags
r.data_in.max_size = 1000
- result = dcerpc.dcerpc_samr_EnumDomainUsers(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_EnumDomainUsers, self.pipe, r)
users = []
r.data_in.account_name.string = account_name
r.data_in.access_mask = access_mask
- result = dcerpc.dcerpc_samr_CreateUser(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_CreateUser, self.pipe, r)
return (r.data_out.user_handle,
dcerpc.uint32_array_getitem(r.data_out.rid, 0))
r.data_in.access_mask = access_mask
r.data_in.rid = rid
- result = dcerpc.dcerpc_samr_OpenUser(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_OpenUser, self.pipe, r)
return UserHandle(pipe, r.data_out.user_handle)
r.data_in.access_mask = access_mask
r.data_in.rid = rid
- result = dcerpc.dcerpc_samr_OpenGroup(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_OpenGroup, self.pipe, r)
return GroupHandle(pipe, r.data_out.group_handle)
r.data_in.access_mask = access_mask
r.data_in.rid = rid
- result = dcerpc.dcerpc_samr_OpenAlias(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_OpenAlias, self.pipe, r)
return AliasHandle(pipe, r.data_out.group_handle)
r = dcerpc.samr_RidToSid()
r.data_in.domain_handle = self.handle
- result = dcerpc.dcerpc_samr_RidToSid(self.pipe, r)
+ call_fn(dcerpc.dcerpc_samr_RidToSid, self.pipe, r)
return sid_to_string(r.data_out.sid)
dcerpc.uint16_array_setitem(r.data_in.system_name, 0, ord('\\'))
r.data_in.access_mask = access_mask
- result = dcerpc.dcerpc_samr_Connect(pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Connect, pipe, r)
return ConnectHandle(pipe, r.data_out.connect_handle)
r.data_in.system_name = system_name
r.data_in.access_mask = access_mask
- result = dcerpc.dcerpc_samr_Connect2(pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Connect2, pipe, r)
return ConnectHandle(pipe, r.data_out.connect_handle)
r.data_in.unknown = 0
r.data_in.access_mask = access_mask
- result = dcerpc.dcerpc_samr_Connect3(pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Connect3, pipe, r)
return ConnectHandle(pipe, r.data_out.connect_handle)
r.data_in.unknown = 0
r.data_in.access_mask = access_mask
- result = dcerpc.dcerpc_samr_Connect4(pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Connect4, pipe, r)
return ConnectHandle(pipe, r.data_out.connect_handle)
r.data_in.info.unknown1 = 0
r.data_in.info.unknown2 = 0
- result = dcerpc.dcerpc_samr_Connect5(pipe, r)
+ call_fn(dcerpc.dcerpc_samr_Connect5, pipe, r)
return ConnectHandle(pipe, r.data_out.connect_handle)