struct dcesrv_call_reply *rep;
NTSTATUS status;
- /* setup a bind_ack */
+ /* setup a bind_nak */
dcesrv_init_hdr(&pkt);
pkt.auth_length = 0;
pkt.call_id = call->pkt.call_id;
dcerpc_set_frag_length(&rep->data, rep->data.length);
DLIST_ADD_END(call->replies, rep, struct dcesrv_call_reply *);
+ DLIST_ADD_END(call->conn->call_list, call, struct dcesrv_call_state *);
return NT_STATUS_OK;
}
/* handle any authentication that is being requested */
if (!dcesrv_auth_bind(call)) {
+ /* TODO: work out the right reject code */
return dcesrv_bind_nak(call, 0);
}
void *r;
NTSTATUS status;
DATA_BLOB stub;
+ uint32 total_length;
opnum = call->pkt.u.request.opnum;
stub = ndr_push_blob(push);
+ total_length = stub.length;
+
do {
uint32 length;
struct dcesrv_call_reply *rep;
pkt.call_id = call->pkt.call_id;
pkt.ptype = DCERPC_PKT_RESPONSE;
pkt.pfc_flags = 0;
- if (!call->replies) {
+ if (stub.length == total_length) {
pkt.pfc_flags |= DCERPC_PFC_FLAG_FIRST;
}
if (length == stub.length) {