/* Unix SMB/CIFS implementation. routines for marshalling/unmarshalling lsa pipe 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" /* parser auto-generated by pidl */ static NTSTATUS ndr_push_lsa_QosInfo(struct ndr_push *ndr, int ndr_flags, struct lsa_QosInfo *r) { struct ndr_push_save _save1, _save2, _save3; ndr_push_save(ndr, &_save1); if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_push_align_uint32(ndr)); ndr_push_save(ndr, &_save2); NDR_CHECK(ndr_push_uint32(ndr, 0)); NDR_CHECK(ndr_push_uint16(ndr, r->impersonation_level)); NDR_CHECK(ndr_push_uint8(ndr, r->context_mode)); NDR_CHECK(ndr_push_uint8(ndr, r->effective_only)); buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; ndr_push_save(ndr, &_save3); ndr_push_restore(ndr, &_save2); NDR_CHECK(ndr_push_uint32(ndr, _save3.offset - _save1.offset)); ndr_push_restore(ndr, &_save3); done: return NT_STATUS_OK; } static NTSTATUS ndr_pull_lsa_QosInfo(struct ndr_pull *ndr, int ndr_flags, struct lsa_QosInfo *r) { uint32 _size; struct ndr_pull_save _save; ndr_pull_save(ndr, &_save); if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_pull_uint32(ndr, &_size)); NDR_CHECK(ndr_pull_limit_size(ndr, _size, 4)); NDR_CHECK(ndr_pull_uint16(ndr, &r->impersonation_level)); NDR_CHECK(ndr_pull_uint8(ndr, &r->context_mode)); NDR_CHECK(ndr_pull_uint8(ndr, &r->effective_only)); buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; ndr_pull_restore(ndr, &_save); NDR_CHECK(ndr_pull_advance(ndr, _size)); done: return NT_STATUS_OK; } static NTSTATUS ndr_push_lsa_ObjectAttribute(struct ndr_push *ndr, int ndr_flags, struct lsa_ObjectAttribute *r) { struct ndr_push_save _save1, _save2, _save3; ndr_push_save(ndr, &_save1); if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_push_align_uint32(ndr)); ndr_push_save(ndr, &_save2); NDR_CHECK(ndr_push_uint32(ndr, 0)); NDR_CHECK(ndr_push_ptr(ndr, r->root_dir)); NDR_CHECK(ndr_push_ptr(ndr, r->object_name)); NDR_CHECK(ndr_push_uint32(ndr, r->attributes)); NDR_CHECK(ndr_push_ptr(ndr, r->sec_desc)); NDR_CHECK(ndr_push_ptr(ndr, r->sec_qos)); buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; if (r->root_dir) { NDR_CHECK(ndr_push_uint8(ndr, *r->root_dir)); } if (r->object_name) { NDR_CHECK(ndr_push_unistr(ndr, r->object_name)); } if (r->sec_desc) { NDR_CHECK(ndr_push_security_descriptor(ndr, r->sec_desc)); } if (r->sec_qos) { NDR_CHECK(ndr_push_lsa_QosInfo(ndr, ndr_flags, r->sec_qos)); } ndr_push_save(ndr, &_save3); ndr_push_restore(ndr, &_save2); NDR_CHECK(ndr_push_uint32(ndr, _save3.offset - _save1.offset)); ndr_push_restore(ndr, &_save3); done: return NT_STATUS_OK; } static NTSTATUS ndr_pull_lsa_ObjectAttribute(struct ndr_pull *ndr, int ndr_flags, struct lsa_ObjectAttribute *r) { uint32 _ptr_root_dir; uint32 _ptr_object_name; uint32 _ptr_sec_desc; uint32 _ptr_sec_qos; uint32 _size; struct ndr_pull_save _save; ndr_pull_save(ndr, &_save); if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_pull_uint32(ndr, &_size)); NDR_CHECK(ndr_pull_limit_size(ndr, _size, 4)); NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_root_dir)); if (_ptr_root_dir) { NDR_ALLOC(ndr, r->root_dir); } else { r->root_dir = NULL; } NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_object_name)); if (_ptr_object_name) { NDR_ALLOC(ndr, r->object_name); } else { r->object_name = NULL; } NDR_CHECK(ndr_pull_uint32(ndr, &r->attributes)); NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sec_desc)); if (_ptr_sec_desc) { NDR_ALLOC(ndr, r->sec_desc); } else { r->sec_desc = NULL; } NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sec_qos)); if (_ptr_sec_qos) { NDR_ALLOC(ndr, r->sec_qos); } else { r->sec_qos = NULL; } buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; if (r->root_dir) { NDR_CHECK(ndr_pull_uint8(ndr, r->root_dir)); } if (r->object_name) { NDR_CHECK(ndr_pull_unistr(ndr, &r->object_name)); } if (r->sec_desc) { NDR_CHECK(ndr_pull_security_descriptor(ndr, r->sec_desc)); } if (r->sec_qos) { NDR_CHECK(ndr_pull_lsa_QosInfo(ndr, ndr_flags, r->sec_qos)); } ndr_pull_restore(ndr, &_save); NDR_CHECK(ndr_pull_advance(ndr, _size)); done: return NT_STATUS_OK; } NTSTATUS ndr_push_lsa_OpenPolicy(struct ndr_push *ndr, struct lsa_OpenPolicy *r) { NDR_CHECK(ndr_push_ptr(ndr, r->in.system_name)); if (r->in.system_name) { NDR_CHECK(ndr_push_uint16(ndr, *r->in.system_name)); } NDR_CHECK(ndr_push_lsa_ObjectAttribute(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.attr)); NDR_CHECK(ndr_push_uint32(ndr, r->in.desired_access)); return NT_STATUS_OK; } NTSTATUS ndr_push_lsa_OpenPolicy2(struct ndr_push *ndr, struct lsa_OpenPolicy2 *r) { NDR_CHECK(ndr_push_ptr(ndr, r->in.system_name)); if (r->in.system_name) { NDR_CHECK(ndr_push_unistr(ndr, r->in.system_name)); } NDR_CHECK(ndr_push_lsa_ObjectAttribute(ndr, NDR_SCALARS|NDR_BUFFERS, r->in.attr)); NDR_CHECK(ndr_push_uint32(ndr, r->in.desired_access)); return NT_STATUS_OK; } static NTSTATUS ndr_push_lsa_SidPtr(struct ndr_push *ndr, int ndr_flags, struct lsa_SidPtr *r) { if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_push_ptr(ndr, r->sid)); buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; if (r->sid) { NDR_CHECK(ndr_push_dom_sid2(ndr, r->sid)); } done: return NT_STATUS_OK; } static NTSTATUS ndr_pull_lsa_SidPtr(struct ndr_pull *ndr, int ndr_flags, struct lsa_SidPtr *r) { uint32 _ptr_sid; if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sid)); if (_ptr_sid) { NDR_ALLOC(ndr, r->sid); } else { r->sid = NULL; } buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; if (r->sid) { NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sid)); } done: return NT_STATUS_OK; } static NTSTATUS ndr_push_lsa_SidArray(struct ndr_push *ndr, int ndr_flags, struct lsa_SidArray *r) { if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_push_uint32(ndr, r->num_sids)); NDR_CHECK(ndr_push_ptr(ndr, r->sids)); buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; if (r->sids) { NDR_CHECK(ndr_push_array(ndr, ndr_flags, r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_push_flags_fn_t)ndr_push_lsa_SidPtr)); } done: return NT_STATUS_OK; } static NTSTATUS ndr_pull_lsa_SidArray(struct ndr_pull *ndr, int ndr_flags, struct lsa_SidArray *r) { uint32 _ptr_sids; if (!(ndr_flags & NDR_SCALARS)) goto buffers; NDR_CHECK(ndr_pull_uint32(ndr, &r->num_sids)); NDR_CHECK(ndr_pull_uint32(ndr, &_ptr_sids)); if (_ptr_sids) { NDR_ALLOC(ndr, r->sids); } else { r->sids = NULL; } buffers: if (!(ndr_flags & NDR_BUFFERS)) goto done; if (r->sids) { NDR_CHECK(ndr_pull_array(ndr, ndr_flags, (void **)&r->sids, sizeof(r->sids[0]), r->num_sids, (ndr_pull_flags_fn_t)ndr_pull_lsa_SidPtr)); } done: return NT_STATUS_OK; } NTSTATUS ndr_push_lsa_EnumSids(struct ndr_push *ndr, struct lsa_EnumSids *r) { NDR_CHECK(ndr_push_policy_handle(ndr, r->in.handle)); NDR_CHECK(ndr_push_uint32(ndr, r->in.resume_handle)); NDR_CHECK(ndr_push_uint32(ndr, r->in.num_entries)); return NT_STATUS_OK; } /* parse a openpolicy */ NTSTATUS ndr_pull_lsa_OpenPolicy(struct ndr_pull *ndr, struct lsa_OpenPolicy *r) { NDR_ALLOC(ndr, r->out.handle); NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle)); NDR_CHECK(ndr_pull_status(ndr, &r->out.result)); return NT_STATUS_OK; } /* parse a openpolicy2 */ NTSTATUS ndr_pull_lsa_OpenPolicy2(struct ndr_pull *ndr, struct lsa_OpenPolicy2 *r) { NDR_ALLOC(ndr, r->out.handle); NDR_CHECK(ndr_pull_policy_handle(ndr, r->out.handle)); NDR_CHECK(ndr_pull_status(ndr, &r->out.result)); return NT_STATUS_OK; } #if 0 /* pull a lsa_SidArray */ static NTSTATUS ndr_pull_lsa_SidArray(struct ndr_pull *ndr, struct lsa_SidArray *r) { uint32 ptr; NDR_CHECK(ndr_pull_uint32(ndr, &r->num_sids)); NDR_CHECK(ndr_pull_uint32(ndr, &ptr)); if (ptr) { uint32 asize, i; NDR_CHECK(ndr_pull_uint32(ndr, &asize)); NDR_ALLOC_N(ndr, r->sids, asize); for (i=0;isids[i]); } else { r->sids[i] = NULL; } } for (i=0;isids[i]) { NDR_CHECK(ndr_pull_dom_sid2(ndr, r->sids[i])); } } } return NT_STATUS_OK; } #endif /* pull a EnumSids */ NTSTATUS ndr_pull_lsa_EnumSids(struct ndr_pull *ndr, struct lsa_EnumSids *r) { NDR_CHECK(ndr_pull_uint32(ndr, &r->out.resume_handle)); NDR_ALLOC(ndr, r->out.sids); NDR_CHECK(ndr_pull_lsa_SidArray(ndr, NDR_SCALARS|NDR_BUFFERS, r->out.sids)); NDR_CHECK(ndr_pull_status(ndr, &r->out.result)); return NT_STATUS_OK; }