summaryrefslogtreecommitdiff
path: root/source4/libcli/rpc/rpc_sec.c
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2003-11-03 06:22:45 +0000
committerAndrew Tridgell <tridge@samba.org>2003-11-03 06:22:45 +0000
commitc5cf47443985c34ad32c44c322901e0fc3a065d7 (patch)
treef7d6abd03304c4f2359a4753aae23e41982c0e17 /source4/libcli/rpc/rpc_sec.c
parent7fd381376f88ae99a4bf022d89f21ae497b48c1a (diff)
downloadsamba-c5cf47443985c34ad32c44c322901e0fc3a065d7.tar.gz
samba-c5cf47443985c34ad32c44c322901e0fc3a065d7.tar.bz2
samba-c5cf47443985c34ad32c44c322901e0fc3a065d7.zip
a major revamp of the low level dcerpc code in samba4, We can now do a
successful LSA OpenPolicy using smbtorture (This used to be commit e925c315f55905060fcca1b188ae1f7e40baf514)
Diffstat (limited to 'source4/libcli/rpc/rpc_sec.c')
-rw-r--r--source4/libcli/rpc/rpc_sec.c179
1 files changed, 0 insertions, 179 deletions
diff --git a/source4/libcli/rpc/rpc_sec.c b/source4/libcli/rpc/rpc_sec.c
deleted file mode 100644
index 49b50c758c..0000000000
--- a/source4/libcli/rpc/rpc_sec.c
+++ /dev/null
@@ -1,179 +0,0 @@
-/*
- Unix SMB/CIFS implementation.
-
- routines for marshalling/unmarshalling security descriptors
- and related structures
-
- Copyright (C) Andrew Tridgell 2003
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-*/
-
-
-#include "includes.h"
-
-/*
- parse a security_ace
-*/
-NTSTATUS ndr_parse_security_ace(struct ndr_parse *ndr, struct security_ace *ace)
-{
- uint16 size;
- struct ndr_parse_save save;
-
- ndr_parse_save(ndr, &save);
-
- NDR_CHECK(ndr_parse_u8(ndr, &ace->type));
- NDR_CHECK(ndr_parse_u8(ndr, &ace->flags));
- NDR_CHECK(ndr_parse_u16(ndr, &size));
- NDR_CHECK(ndr_parse_limit_size(ndr, size, 4));
-
- NDR_CHECK(ndr_parse_u32(ndr, &ace->access_mask));
-
- if (sec_ace_object(ace->type)) {
- NDR_ALLOC(ndr, ace->obj);
- NDR_CHECK(ndr_parse_u32(ndr, &ace->obj->flags));
- if (ace->obj->flags & SEC_ACE_OBJECT_PRESENT) {
- NDR_CHECK(ndr_parse_guid(ndr, &ace->obj->object_guid));
- }
- if (ace->obj->flags & SEC_ACE_OBJECT_INHERITED_PRESENT) {
- NDR_CHECK(ndr_parse_guid(ndr, &ace->obj->inherit_guid));
- }
- }
-
-
- NDR_CHECK(ndr_parse_dom_sid(ndr, &ace->trustee));
-
- ndr_parse_restore(ndr, &save);
- NDR_CHECK(ndr_parse_advance(ndr, size));
-
- return NT_STATUS_OK;
-}
-
-/*
- parse a security_acl
-*/
-NTSTATUS ndr_parse_security_acl(struct ndr_parse *ndr, struct security_acl *acl)
-{
- int i;
- uint16 size;
- struct ndr_parse_save save;
-
- ndr_parse_save(ndr, &save);
-
- NDR_CHECK(ndr_parse_u16(ndr, &acl->revision));
- NDR_CHECK(ndr_parse_u16(ndr, &size));
- NDR_CHECK(ndr_parse_limit_size(ndr, size, 4));
- NDR_CHECK(ndr_parse_u32(ndr, &acl->num_aces));
-
- NDR_ALLOC_N(ndr, acl->aces, acl->num_aces);
-
- for (i=0;i<acl->num_aces;i++) {
- NDR_CHECK(ndr_parse_security_ace(ndr, &acl->aces[i]));
- }
-
- ndr_parse_restore(ndr, &save);
- NDR_CHECK(ndr_parse_advance(ndr, size));
-
- return NT_STATUS_OK;
-}
-
-/*
- parse a security_acl offset and structure
-*/
-NTSTATUS ndr_parse_security_acl_ofs(struct ndr_parse *ndr, struct security_acl **acl)
-{
- uint32 ofs;
- struct ndr_parse_save save;
-
- NDR_CHECK(ndr_parse_u32(ndr, &ofs));
- if (ofs == 0) {
- /* it is valid for an acl ptr to be NULL */
- *acl = NULL;
- return NT_STATUS_OK;
- }
-
- ndr_parse_save(ndr, &save);
- NDR_CHECK(ndr_parse_set_offset(ndr, ofs));
- NDR_ALLOC(ndr, *acl);
- NDR_CHECK(ndr_parse_security_acl(ndr, *acl));
- ndr_parse_restore(ndr, &save);
-
- return NT_STATUS_OK;
-}
-
-
-/*
- parse a dom_sid
-*/
-NTSTATUS ndr_parse_dom_sid(struct ndr_parse *ndr, struct dom_sid *sid)
-{
- int i;
-
- NDR_CHECK(ndr_parse_u8(ndr, &sid->sid_rev_num));
- NDR_CHECK(ndr_parse_u8(ndr, &sid->num_auths));
- for (i=0;i<6;i++) {
- NDR_CHECK(ndr_parse_u8(ndr, &sid->id_auth[i]));
- }
-
- NDR_ALLOC_N(ndr, sid->sub_auths, sid->num_auths);
-
- for (i=0;i<sid->num_auths;i++) {
- NDR_CHECK(ndr_parse_u32(ndr, &sid->sub_auths[i]));
- }
-
- return NT_STATUS_OK;
-}
-
-/*
- parse a dom_sid offset and structure
-*/
-NTSTATUS ndr_parse_dom_sid_ofs(struct ndr_parse *ndr, struct dom_sid **sid)
-{
- uint32 ofs;
- struct ndr_parse_save save;
-
- NDR_CHECK(ndr_parse_u32(ndr, &ofs));
- if (ofs == 0) {
- /* it is valid for a dom_sid ptr to be NULL */
- *sid = NULL;
- return NT_STATUS_OK;
- }
-
- ndr_parse_save(ndr, &save);
- NDR_CHECK(ndr_parse_set_offset(ndr, ofs));
- NDR_ALLOC(ndr, *sid);
- NDR_CHECK(ndr_parse_dom_sid(ndr, *sid));
- ndr_parse_restore(ndr, &save);
-
- return NT_STATUS_OK;
-}
-
-/*
- parse a security descriptor
-*/
-NTSTATUS ndr_parse_security_descriptor(struct ndr_parse *ndr,
- struct security_descriptor **sd)
-{
- NDR_ALLOC(ndr, *sd);
-
- NDR_CHECK(ndr_parse_u8(ndr, &(*sd)->revision));
- NDR_CHECK(ndr_parse_u16(ndr, &(*sd)->type));
- NDR_CHECK(ndr_parse_dom_sid_ofs(ndr, &(*sd)->owner_sid));
- NDR_CHECK(ndr_parse_dom_sid_ofs(ndr, &(*sd)->group_sid));
- NDR_CHECK(ndr_parse_security_acl_ofs(ndr, &(*sd)->sacl));
- NDR_CHECK(ndr_parse_security_acl_ofs(ndr, &(*sd)->dacl));
-
- return NT_STATUS_OK;
-}