diff options
author | Samuel Cabrero <scabrero@zentyal.com> | 2014-07-04 12:45:59 +0200 |
---|---|---|
committer | Andrew Bartlett <abartlet@samba.org> | 2014-07-07 05:22:33 +0200 |
commit | d747372d28273542298f86530e715e8faaf907f2 (patch) | |
tree | 15d7e4fbf16e25ad085b9d0d08cb11c62a7d1670 /source3/libnet/libnet_dssync.c | |
parent | 331fb7fc64c0a4f64c28001a1644a2a6a923be75 (diff) | |
download | samba-d747372d28273542298f86530e715e8faaf907f2.tar.gz |
idl:drsuapi: Manage all possible lengths of drsuapi_DsBindInfo
Signed-off-by: Samuel Cabrero <scabrero@zentyal.com>
Reviewed-by: Kamen Mazdrashki <kamenim@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
Reviewed-by: Kamen Mazdrashki <kamenim@samba.org>
Diffstat (limited to 'source3/libnet/libnet_dssync.c')
-rw-r--r-- | source3/libnet/libnet_dssync.c | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/source3/libnet/libnet_dssync.c b/source3/libnet/libnet_dssync.c index a8431066efa..94f06285a89 100644 --- a/source3/libnet/libnet_dssync.c +++ b/source3/libnet/libnet_dssync.c @@ -195,9 +195,19 @@ static NTSTATUS libnet_dssync_bind(TALLOC_CTX *mem_ctx, ctx->remote_info28.repl_epoch = 0; break; } - case 28: + case 28: { ctx->remote_info28 = bind_info.info.info28; break; + } + case 32: { + struct drsuapi_DsBindInfo32 *info32; + info32 = &bind_info.info.info32; + ctx->remote_info28.site_guid = info32->site_guid; + ctx->remote_info28.supported_extensions = info32->supported_extensions; + ctx->remote_info28.pid = info32->pid; + ctx->remote_info28.repl_epoch = info32->repl_epoch; + break; + } case 48: { struct drsuapi_DsBindInfo48 *info48; info48 = &bind_info.info.info48; @@ -207,6 +217,15 @@ static NTSTATUS libnet_dssync_bind(TALLOC_CTX *mem_ctx, ctx->remote_info28.repl_epoch = info48->repl_epoch; break; } + case 52: { + struct drsuapi_DsBindInfo52 *info52; + info52 = &bind_info.info.info52; + ctx->remote_info28.site_guid = info52->site_guid; + ctx->remote_info28.supported_extensions = info52->supported_extensions; + ctx->remote_info28.pid = info52->pid; + ctx->remote_info28.repl_epoch = info52->repl_epoch; + break; + } default: DEBUG(1, ("Warning: invalid info length in bind info: %d\n", bind_info.length)); |