summaryrefslogtreecommitdiff
path: root/source4/rpc_server/dcesrv_auth.c
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@samba.org>2004-06-04 09:46:46 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 12:56:25 -0500
commit5165fec02e0e489ac63c3cb71bed31dea9fde644 (patch)
treef253af775d6151ef9e3eb5d01973f2f177febd19 /source4/rpc_server/dcesrv_auth.c
parentb0d4ed741f9fcb31ef124c1375db13cd6874131e (diff)
downloadsamba-5165fec02e0e489ac63c3cb71bed31dea9fde644.tar.gz
samba-5165fec02e0e489ac63c3cb71bed31dea9fde644.tar.bz2
samba-5165fec02e0e489ac63c3cb71bed31dea9fde644.zip
r1004: continue tridge's work on dcerpc server auth/crypto code
I made it much more generic, and we should be able to add a module interface to this code, so that other DCERPC_AUTH types can be added via modules... metze (This used to be commit d09abeb686c43c62322205689273d1b417113004)
Diffstat (limited to 'source4/rpc_server/dcesrv_auth.c')
-rw-r--r--source4/rpc_server/dcesrv_auth.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/source4/rpc_server/dcesrv_auth.c b/source4/rpc_server/dcesrv_auth.c
index 7aa296c245..df1a820039 100644
--- a/source4/rpc_server/dcesrv_auth.c
+++ b/source4/rpc_server/dcesrv_auth.c
@@ -51,11 +51,16 @@ BOOL dcesrv_auth_bind(struct dcesrv_call_state *call)
return False;
}
- status = dcesrv_crypto_startup(dce_conn, &dce_conn->auth_state);
+ status = dcesrv_crypto_select_type(dce_conn, &dce_conn->auth_state);
if (!NT_STATUS_IS_OK(status)) {
return False;
}
-
+
+ status = dcesrv_crypto_start(&dce_conn->auth_state);
+ if (!NT_STATUS_IS_OK(status)) {
+ return False;
+ }
+
return True;
}
@@ -67,7 +72,7 @@ BOOL dcesrv_auth_bind_ack(struct dcesrv_call_state *call, struct dcerpc_packet *
struct dcesrv_connection *dce_conn = call->conn;
NTSTATUS status;
- if (!call->conn->auth_state.crypto_state) {
+ if (!call->conn->auth_state.crypto_ctx.ops) {
return True;
}
@@ -98,7 +103,7 @@ BOOL dcesrv_auth_auth3(struct dcesrv_call_state *call)
NTSTATUS status;
if (!dce_conn->auth_state.auth_info ||
- !dce_conn->auth_state.crypto_state ||
+ !dce_conn->auth_state.crypto_ctx.ops ||
pkt->u.auth.auth_info.length == 0) {
return False;
}
@@ -138,7 +143,7 @@ BOOL dcesrv_auth_request(struct dcesrv_call_state *call)
NTSTATUS status;
if (!dce_conn->auth_state.auth_info ||
- !dce_conn->auth_state.crypto_state) {
+ !dce_conn->auth_state.crypto_ctx.ops) {
return True;
}
@@ -213,7 +218,7 @@ BOOL dcesrv_auth_response(struct dcesrv_call_state *call,
struct ndr_push *ndr;
/* non-signed packets are simple */
- if (!dce_conn->auth_state.auth_info || !dce_conn->auth_state.crypto_state) {
+ if (!dce_conn->auth_state.auth_info || !dce_conn->auth_state.crypto_ctx.ops) {
status = dcerpc_push_auth(blob, call->mem_ctx, pkt, NULL);
return NT_STATUS_IS_OK(status);
}