}
pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL)
+ if (pull == NULL) {
+ talloc_free(mem_ctx);
return False;
+ }
pull->flags |= LIBNDR_FLAG_REF_ALLOC;
status = ndr_pull_unixinfo_SidToUid(pull, NDR_IN, &r);
return False;
}
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_IN_DEBUG(unixinfo_SidToUid, &r);
+
ZERO_STRUCT(r.out);
- r.out.uid = talloc_size(mem_ctx, sizeof(*r.out.uid));
+ r.out.uid = talloc_zero(mem_ctx, uint64_t);
if (r.out.uid == NULL) {
talloc_free(mem_ctx);
return False;
}
- r.out.result = _unixinfo_SidToUid(p, r.in.sid, r.out.uid);
+ r.out.result = _unixinfo_SidToUid(p, &r);
+
+ if (p->rng_fault_state) {
+ talloc_free(mem_ctx);
+ /* Return True here, srv_pipe_hnd.c will take care */
+ return True;
+ }
+
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_OUT_DEBUG(unixinfo_SidToUid, &r);
push = ndr_push_init_ctx(mem_ctx);
if (push == NULL) {
}
blob = ndr_push_blob(push);
- if (!prs_init_data_blob(&p->out_data.rdata, &blob, p->mem_ctx)) {
+ if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
talloc_free(mem_ctx);
return False;
}
}
pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL)
+ if (pull == NULL) {
+ talloc_free(mem_ctx);
return False;
+ }
pull->flags |= LIBNDR_FLAG_REF_ALLOC;
status = ndr_pull_unixinfo_UidToSid(pull, NDR_IN, &r);
return False;
}
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_IN_DEBUG(unixinfo_UidToSid, &r);
+
ZERO_STRUCT(r.out);
- r.out.sid = talloc_size(mem_ctx, sizeof(*r.out.sid));
+ r.out.sid = talloc_zero(mem_ctx, struct dom_sid);
if (r.out.sid == NULL) {
talloc_free(mem_ctx);
return False;
}
- r.out.result = _unixinfo_UidToSid(p, r.in.uid, r.out.sid);
+ r.out.result = _unixinfo_UidToSid(p, &r);
+
+ if (p->rng_fault_state) {
+ talloc_free(mem_ctx);
+ /* Return True here, srv_pipe_hnd.c will take care */
+ return True;
+ }
+
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_OUT_DEBUG(unixinfo_UidToSid, &r);
push = ndr_push_init_ctx(mem_ctx);
if (push == NULL) {
}
blob = ndr_push_blob(push);
- if (!prs_init_data_blob(&p->out_data.rdata, &blob, p->mem_ctx)) {
+ if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
talloc_free(mem_ctx);
return False;
}
}
pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL)
+ if (pull == NULL) {
+ talloc_free(mem_ctx);
return False;
+ }
pull->flags |= LIBNDR_FLAG_REF_ALLOC;
status = ndr_pull_unixinfo_SidToGid(pull, NDR_IN, &r);
return False;
}
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_IN_DEBUG(unixinfo_SidToGid, &r);
+
ZERO_STRUCT(r.out);
- r.out.gid = talloc_size(mem_ctx, sizeof(*r.out.gid));
+ r.out.gid = talloc_zero(mem_ctx, uint64_t);
if (r.out.gid == NULL) {
talloc_free(mem_ctx);
return False;
}
- r.out.result = _unixinfo_SidToGid(p, r.in.sid, r.out.gid);
+ r.out.result = _unixinfo_SidToGid(p, &r);
+
+ if (p->rng_fault_state) {
+ talloc_free(mem_ctx);
+ /* Return True here, srv_pipe_hnd.c will take care */
+ return True;
+ }
+
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_OUT_DEBUG(unixinfo_SidToGid, &r);
push = ndr_push_init_ctx(mem_ctx);
if (push == NULL) {
}
blob = ndr_push_blob(push);
- if (!prs_init_data_blob(&p->out_data.rdata, &blob, p->mem_ctx)) {
+ if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
talloc_free(mem_ctx);
return False;
}
}
pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL)
+ if (pull == NULL) {
+ talloc_free(mem_ctx);
return False;
+ }
pull->flags |= LIBNDR_FLAG_REF_ALLOC;
status = ndr_pull_unixinfo_GidToSid(pull, NDR_IN, &r);
return False;
}
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_IN_DEBUG(unixinfo_GidToSid, &r);
+
ZERO_STRUCT(r.out);
- r.out.sid = talloc_size(mem_ctx, sizeof(*r.out.sid));
+ r.out.sid = talloc_zero(mem_ctx, struct dom_sid);
if (r.out.sid == NULL) {
talloc_free(mem_ctx);
return False;
}
- r.out.result = _unixinfo_GidToSid(p, r.in.gid, r.out.sid);
+ r.out.result = _unixinfo_GidToSid(p, &r);
+
+ if (p->rng_fault_state) {
+ talloc_free(mem_ctx);
+ /* Return True here, srv_pipe_hnd.c will take care */
+ return True;
+ }
+
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_OUT_DEBUG(unixinfo_GidToSid, &r);
push = ndr_push_init_ctx(mem_ctx);
if (push == NULL) {
}
blob = ndr_push_blob(push);
- if (!prs_init_data_blob(&p->out_data.rdata, &blob, p->mem_ctx)) {
+ if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
talloc_free(mem_ctx);
return False;
}
}
pull = ndr_pull_init_blob(&blob, mem_ctx);
- if (pull == NULL)
+ if (pull == NULL) {
+ talloc_free(mem_ctx);
return False;
+ }
pull->flags |= LIBNDR_FLAG_REF_ALLOC;
status = ndr_pull_unixinfo_GetPWUid(pull, NDR_IN, &r);
return False;
}
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_IN_DEBUG(unixinfo_GetPWUid, &r);
+
ZERO_STRUCT(r.out);
r.out.count = r.in.count;
- r.out.infos = talloc_array_size(mem_ctx, sizeof(*r.out.infos), *r.in.count);
+ r.out.infos = talloc_zero_array(mem_ctx, struct unixinfo_GetPWUidInfo, *r.in.count);
if (r.out.infos == NULL) {
talloc_free(mem_ctx);
return False;
}
- r.out.result = _unixinfo_GetPWUid(p, r.in.count, r.in.uids, r.out.infos);
+ r.out.result = _unixinfo_GetPWUid(p, &r);
+
+ if (p->rng_fault_state) {
+ talloc_free(mem_ctx);
+ /* Return True here, srv_pipe_hnd.c will take care */
+ return True;
+ }
+
+ if (DEBUGLEVEL >= 10)
+ NDR_PRINT_OUT_DEBUG(unixinfo_GetPWUid, &r);
push = ndr_push_init_ctx(mem_ctx);
if (push == NULL) {
}
blob = ndr_push_blob(push);
- if (!prs_init_data_blob(&p->out_data.rdata, &blob, p->mem_ctx)) {
+ if (!prs_copy_data_in(&p->out_data.rdata, (const char *)blob.data, (uint32)blob.length)) {
talloc_free(mem_ctx);
return False;
}