s3:rpcclient: make use of dcerpc_parse_binding() to create the binding
authorStefan Metzmacher <metze@samba.org>
Thu, 30 Jan 2014 21:05:51 +0000 (22:05 +0100)
committerGünther Deschner <gd@samba.org>
Thu, 13 Feb 2014 10:54:14 +0000 (11:54 +0100)
This makes sure the binding is talloc'ed.

Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Guenther Deschner <gd@samba.org>
source3/rpcclient/cmd_epmapper.c

index 9c6d7474db406f61506c7c692ac97b27e8ebad07..ff9e874527b3f42e0bec174ab305d64fd0028b51 100644 (file)
@@ -28,7 +28,7 @@ static NTSTATUS cmd_epmapper_map(struct rpc_pipe_client *p,
                                 int argc, const char **argv)
 {
        struct dcerpc_binding_handle *b = p->binding_handle;
-       struct dcerpc_binding map_binding;
+       struct dcerpc_binding *map_binding;
        struct epm_twr_t map_tower;
        struct epm_twr_p_t towers[500];
        struct policy_handle entry_handle;
@@ -41,13 +41,18 @@ static NTSTATUS cmd_epmapper_map(struct rpc_pipe_client *p,
 
        abstract_syntax = ndr_table_lsarpc.syntax_id;
 
-       ZERO_STRUCT(map_binding);
-       map_binding.transport = NCACN_NP;
-        map_binding.object = abstract_syntax;
-        map_binding.host = "127.0.0.1"; /* needed? */
-        map_binding.endpoint = "0"; /* correct? needed? */
+       /* 127.0.0.1[0] => correct? needed? */
+       status = dcerpc_parse_binding(tmp_ctx, "ncacn_np:127.0.0.1[0]",
+                                     &map_binding);
+       if (!NT_STATUS_IS_OK(status)) {
+               d_fprintf(stderr, "dcerpc_parse_binding returned %s\n",
+                         nt_errstr(status));
+               goto done;
+       }
+
+       map_binding->object = abstract_syntax;
 
-       status = dcerpc_binding_build_tower(tmp_ctx, &map_binding,
+       status = dcerpc_binding_build_tower(tmp_ctx, map_binding,
                                            &map_tower.tower);
        if (!NT_STATUS_IS_OK(status)) {
                d_fprintf(stderr, "dcerpc_binding_build_tower returned %s\n",