s4:dsdb/repl: make use of use tevent_req based dcerpc_binding_handle stubs
authorStefan Metzmacher <metze@samba.org>
Mon, 8 Mar 2010 15:23:17 +0000 (16:23 +0100)
committerStefan Metzmacher <metze@samba.org>
Fri, 12 Mar 2010 14:25:41 +0000 (15:25 +0100)
metze

source4/dsdb/repl/drepl_notify.c
source4/dsdb/repl/drepl_out_helpers.c
source4/dsdb/repl/drepl_service.h

index 5047da33077c0210947537dafce6d45561bca47a..7ae4af724fd4c361ab57b82b5cae71ecc9012aef 100644 (file)
@@ -38,6 +38,7 @@
 
 
 struct dreplsrv_op_notify_state {
+       struct tevent_context *ev;
        struct dreplsrv_notify_operation *op;
        void *ndr_struct_ptr;
 };
@@ -60,6 +61,7 @@ static struct tevent_req *dreplsrv_op_notify_send(TALLOC_CTX *mem_ctx,
        if (req == NULL) {
                return NULL;
        }
+       state->ev = ev;
        state->op = op;
 
        subreq = dreplsrv_out_drsuapi_send(state,
@@ -90,7 +92,7 @@ static void dreplsrv_op_notify_connect_done(struct tevent_req *subreq)
        dreplsrv_op_notify_replica_sync_trigger(req);
 }
 
-static void dreplsrv_op_notify_replica_sync_done(struct rpc_request *rreq);
+static void dreplsrv_op_notify_replica_sync_done(struct tevent_req *subreq);
 
 static void dreplsrv_op_notify_replica_sync_trigger(struct tevent_req *req)
 {
@@ -99,8 +101,8 @@ static void dreplsrv_op_notify_replica_sync_trigger(struct tevent_req *req)
                struct dreplsrv_op_notify_state);
        struct dreplsrv_partition *partition = state->op->source_dsa->partition;
        struct dreplsrv_drsuapi_connection *drsuapi = state->op->source_dsa->conn->drsuapi;
-       struct rpc_request *rreq;
        struct drsuapi_DsReplicaSync *r;
+       struct tevent_req *subreq;
 
        r = talloc_zero(state, struct drsuapi_DsReplicaSync);
        if (tevent_req_nomem(r, req)) {
@@ -125,17 +127,21 @@ static void dreplsrv_op_notify_replica_sync_trigger(struct tevent_req *req)
 
        state->ndr_struct_ptr = r;
 
-       rreq = dcerpc_drsuapi_DsReplicaSync_send(drsuapi->pipe, r, r);
-       if (tevent_req_nomem(rreq, req)) {
+       subreq = dcerpc_drsuapi_DsReplicaSync_r_send(state,
+                                                    state->ev,
+                                                    drsuapi->drsuapi_handle,
+                                                    r);
+       if (tevent_req_nomem(subreq, req)) {
                return;
        }
-       composite_continue_rpc(NULL, rreq, dreplsrv_op_notify_replica_sync_done, req);
+       tevent_req_set_callback(subreq, dreplsrv_op_notify_replica_sync_done, req);
 }
 
-static void dreplsrv_op_notify_replica_sync_done(struct rpc_request *rreq)
+static void dreplsrv_op_notify_replica_sync_done(struct tevent_req *subreq)
 {
-       struct tevent_req *req = talloc_get_type(rreq->async.private_data,
-                                                struct tevent_req);
+       struct tevent_req *req =
+               tevent_req_callback_data(subreq,
+               struct tevent_req);
        struct dreplsrv_op_notify_state *state =
                tevent_req_data(req,
                struct dreplsrv_op_notify_state);
@@ -145,7 +151,8 @@ static void dreplsrv_op_notify_replica_sync_done(struct rpc_request *rreq)
 
        state->ndr_struct_ptr = NULL;
 
-       status = dcerpc_drsuapi_DsReplicaSync_recv(rreq);
+       status = dcerpc_drsuapi_DsReplicaSync_r_recv(subreq, r);
+       TALLOC_FREE(subreq);
        if (tevent_req_nterror(req, status)) {
                return;
        }
index a8a3f80fa687cd1711d4c04e8335aac35b379f87..a12481b8972515ef335ec5aa61d4b900136eb86a 100644 (file)
@@ -37,6 +37,8 @@
 #include "../lib/util/tevent_ntstatus.h"
 
 struct dreplsrv_out_drsuapi_state {
+       struct tevent_context *ev;
+
        struct dreplsrv_out_connection *conn;
 
        struct dreplsrv_drsuapi_connection *drsuapi;
@@ -61,6 +63,7 @@ struct tevent_req *dreplsrv_out_drsuapi_send(TALLOC_CTX *mem_ctx,
                return NULL;
        }
 
+       state->ev       = ev;
        state->conn     = conn;
        state->drsuapi  = conn->drsuapi;
 
@@ -90,7 +93,7 @@ struct tevent_req *dreplsrv_out_drsuapi_send(TALLOC_CTX *mem_ctx,
        return req;
 }
 
-static void dreplsrv_out_drsuapi_bind_done(struct rpc_request *rreq);
+static void dreplsrv_out_drsuapi_bind_done(struct tevent_req *subreq);
 
 static void dreplsrv_out_drsuapi_connect_done(struct composite_context *creq)
 {
@@ -99,7 +102,7 @@ static void dreplsrv_out_drsuapi_connect_done(struct composite_context *creq)
        struct dreplsrv_out_drsuapi_state *state = tevent_req_data(req,
                                                   struct dreplsrv_out_drsuapi_state);
        NTSTATUS status;
-       struct rpc_request *rreq;
+       struct tevent_req *subreq;
 
        status = dcerpc_pipe_connect_b_recv(creq,
                                            state->drsuapi,
@@ -108,6 +111,8 @@ static void dreplsrv_out_drsuapi_connect_done(struct composite_context *creq)
                return;
        }
 
+       state->drsuapi->drsuapi_handle = state->drsuapi->pipe->binding_handle;
+
        status = gensec_session_key(state->drsuapi->pipe->conn->security_state.generic_state,
                                    &state->drsuapi->gensec_skey);
        if (tevent_req_nterror(req, status)) {
@@ -121,24 +126,26 @@ static void dreplsrv_out_drsuapi_connect_done(struct composite_context *creq)
        state->bind_r.in.bind_info = &state->bind_info_ctr;
        state->bind_r.out.bind_handle = &state->drsuapi->bind_handle;
 
-       rreq = dcerpc_drsuapi_DsBind_send(state->drsuapi->pipe,
-                                         state,
-                                         &state->bind_r);
-       if (tevent_req_nomem(rreq, req)) {
+       subreq = dcerpc_drsuapi_DsBind_r_send(state,
+                                             state->ev,
+                                             state->drsuapi->drsuapi_handle,
+                                             &state->bind_r);
+       if (tevent_req_nomem(subreq, req)) {
                return;
        }
-       composite_continue_rpc(NULL, rreq, dreplsrv_out_drsuapi_bind_done, req);
+       tevent_req_set_callback(subreq, dreplsrv_out_drsuapi_bind_done, req);
 }
 
-static void dreplsrv_out_drsuapi_bind_done(struct rpc_request *rreq)
+static void dreplsrv_out_drsuapi_bind_done(struct tevent_req *subreq)
 {
-       struct tevent_req *req = talloc_get_type(rreq->async.private_data,
-                                                struct tevent_req);
+       struct tevent_req *req = tevent_req_callback_data(subreq,
+                                struct tevent_req);
        struct dreplsrv_out_drsuapi_state *state = tevent_req_data(req,
                                                   struct dreplsrv_out_drsuapi_state);
        NTSTATUS status;
 
-       status = dcerpc_drsuapi_DsBind_recv(rreq);
+       status = dcerpc_drsuapi_DsBind_r_recv(subreq, state);
+       TALLOC_FREE(subreq);
        if (tevent_req_nterror(req, status)) {
                return;
        }
@@ -202,6 +209,7 @@ NTSTATUS dreplsrv_out_drsuapi_recv(struct tevent_req *req)
 }
 
 struct dreplsrv_op_pull_source_state {
+       struct tevent_context *ev;
        struct dreplsrv_out_operation *op;
        void *ndr_struct_ptr;
 };
@@ -221,7 +229,7 @@ struct tevent_req *dreplsrv_op_pull_source_send(TALLOC_CTX *mem_ctx,
        if (req == NULL) {
                return NULL;
        }
-
+       state->ev = ev;
        state->op = op;
 
        subreq = dreplsrv_out_drsuapi_send(state, ev, op->source_dsa->conn);
@@ -250,7 +258,7 @@ static void dreplsrv_op_pull_source_connect_done(struct tevent_req *subreq)
        dreplsrv_op_pull_source_get_changes_trigger(req);
 }
 
-static void dreplsrv_op_pull_source_get_changes_done(struct rpc_request *rreq);
+static void dreplsrv_op_pull_source_get_changes_done(struct tevent_req *subreq);
 
 static void dreplsrv_op_pull_source_get_changes_trigger(struct tevent_req *req)
 {
@@ -260,9 +268,9 @@ static void dreplsrv_op_pull_source_get_changes_trigger(struct tevent_req *req)
        struct dreplsrv_service *service = state->op->service;
        struct dreplsrv_partition *partition = state->op->source_dsa->partition;
        struct dreplsrv_drsuapi_connection *drsuapi = state->op->source_dsa->conn->drsuapi;
-       struct rpc_request *rreq;
        struct drsuapi_DsGetNCChanges *r;
        struct drsuapi_DsReplicaCursorCtrEx *uptodateness_vector;
+       struct tevent_req *subreq;
 
        r = talloc(state, struct drsuapi_DsGetNCChanges);
        if (tevent_req_nomem(r, req)) {
@@ -324,11 +332,14 @@ static void dreplsrv_op_pull_source_get_changes_trigger(struct tevent_req *req)
 #endif
 
        state->ndr_struct_ptr = r;
-       rreq = dcerpc_drsuapi_DsGetNCChanges_send(drsuapi->pipe, r, r);
-       if (tevent_req_nomem(rreq, req)) {
+       subreq = dcerpc_drsuapi_DsGetNCChanges_r_send(state,
+                                                     state->ev,
+                                                     drsuapi->drsuapi_handle,
+                                                     r);
+       if (tevent_req_nomem(subreq, req)) {
                return;
        }
-       composite_continue_rpc(NULL, rreq, dreplsrv_op_pull_source_get_changes_done, req);
+       tevent_req_set_callback(subreq, dreplsrv_op_pull_source_get_changes_done, req);
 }
 
 static void dreplsrv_op_pull_source_apply_changes_trigger(struct tevent_req *req,
@@ -337,10 +348,10 @@ static void dreplsrv_op_pull_source_apply_changes_trigger(struct tevent_req *req
                                                          struct drsuapi_DsGetNCChangesCtr1 *ctr1,
                                                          struct drsuapi_DsGetNCChangesCtr6 *ctr6);
 
-static void dreplsrv_op_pull_source_get_changes_done(struct rpc_request *rreq)
+static void dreplsrv_op_pull_source_get_changes_done(struct tevent_req *subreq)
 {
-       struct tevent_req *req = talloc_get_type(rreq->async.private_data,
-                                                struct tevent_req);
+       struct tevent_req *req = tevent_req_callback_data(subreq,
+                                struct tevent_req);
        struct dreplsrv_op_pull_source_state *state = tevent_req_data(req,
                                                      struct dreplsrv_op_pull_source_state);
        NTSTATUS status;
@@ -352,7 +363,8 @@ static void dreplsrv_op_pull_source_get_changes_done(struct rpc_request *rreq)
 
        state->ndr_struct_ptr = NULL;
 
-       status = dcerpc_drsuapi_DsGetNCChanges_recv(rreq);
+       status = dcerpc_drsuapi_DsGetNCChanges_r_recv(subreq, r);
+       TALLOC_FREE(subreq);
        if (tevent_req_nterror(req, status)) {
                return;
        }
@@ -514,7 +526,7 @@ static void dreplsrv_op_pull_source_apply_changes_trigger(struct tevent_req *req
        dreplsrv_update_refs_trigger(req);
 }
 
-static void dreplsrv_update_refs_done(struct rpc_request *rreq);
+static void dreplsrv_update_refs_done(struct tevent_req *subreq);
 
 /*
   send a UpdateRefs request to refresh our repsTo record on the server
@@ -526,10 +538,10 @@ static void dreplsrv_update_refs_trigger(struct tevent_req *req)
        struct dreplsrv_service *service = state->op->service;
        struct dreplsrv_partition *partition = state->op->source_dsa->partition;
        struct dreplsrv_drsuapi_connection *drsuapi = state->op->source_dsa->conn->drsuapi;
-       struct rpc_request *rreq;
        struct drsuapi_DsReplicaUpdateRefs *r;
        char *ntds_guid_str;
        char *ntds_dns_name;
+       struct tevent_req *subreq;
 
        r = talloc(state, struct drsuapi_DsReplicaUpdateRefs);
        if (tevent_req_nomem(r, req)) {
@@ -559,19 +571,22 @@ static void dreplsrv_update_refs_trigger(struct tevent_req *req)
        }
 
        state->ndr_struct_ptr = r;
-       rreq = dcerpc_drsuapi_DsReplicaUpdateRefs_send(drsuapi->pipe, r, r);
-       if (tevent_req_nomem(rreq, req)) {
+       subreq = dcerpc_drsuapi_DsReplicaUpdateRefs_r_send(state,
+                                                          state->ev,
+                                                          drsuapi->drsuapi_handle,
+                                                          r);
+       if (tevent_req_nomem(subreq, req)) {
                return;
        }
-       composite_continue_rpc(NULL, rreq, dreplsrv_update_refs_done, req);
+       tevent_req_set_callback(subreq, dreplsrv_update_refs_done, req);
 }
 
 /*
   receive a UpdateRefs reply
  */
-static void dreplsrv_update_refs_done(struct rpc_request *rreq)
+static void dreplsrv_update_refs_done(struct tevent_req *subreq)
 {
-       struct tevent_req *req = talloc_get_type(rreq->async.private_data,
+       struct tevent_req *req = tevent_req_callback_data(subreq,
                                 struct tevent_req);
        struct dreplsrv_op_pull_source_state *state = tevent_req_data(req,
                                                      struct dreplsrv_op_pull_source_state);
@@ -581,7 +596,8 @@ static void dreplsrv_update_refs_done(struct rpc_request *rreq)
 
        state->ndr_struct_ptr = NULL;
 
-       status = dcerpc_drsuapi_DsReplicaUpdateRefs_recv(rreq);
+       status = dcerpc_drsuapi_DsReplicaUpdateRefs_r_recv(subreq, r);
+       TALLOC_FREE(subreq);
        if (!NT_STATUS_IS_OK(status)) {
                DEBUG(0,("UpdateRefs failed with %s\n", 
                         nt_errstr(status)));
index b9ee5aed5da578e2f3aaa9909bc0a32e7e615c47..7813f92cbe8fc8cf427b4a35c26eb658ceaae39c 100644 (file)
@@ -33,6 +33,7 @@ struct dreplsrv_drsuapi_connection {
         * for a valid connection
         */
        struct dcerpc_pipe *pipe;
+       struct dcerpc_binding_handle *drsuapi_handle;
 
        DATA_BLOB gensec_skey;
        struct drsuapi_DsBindInfo28 remote_info28;