s3-spoolss: add winreg_get_driver_package_internal()
authorGünther Deschner <gd@samba.org>
Wed, 2 Nov 2016 13:37:02 +0000 (14:37 +0100)
committerGünther Deschner <gd@samba.org>
Tue, 9 May 2017 14:43:13 +0000 (16:43 +0200)
Guenther

Signed-off-by: Guenther Deschner <gd@samba.org>
Reviewed-by: Andreas Schneider <asn@samba.org>
source3/rpc_server/spoolss/srv_spoolss_util.c
source3/rpc_server/spoolss/srv_spoolss_util.h

index 753ddbdd2812fb6483fa53281efd126eff728b41..3cbb03d3eae5b36fa72c4b55529003e7aa552639 100644 (file)
@@ -612,6 +612,40 @@ WERROR winreg_add_driver_package_internal(TALLOC_CTX *mem_ctx,
        return result;
 }
 
+WERROR winreg_get_driver_package_internal(TALLOC_CTX *mem_ctx,
+                                         const struct auth_session_info *session_info,
+                                         struct messaging_context *msg_ctx,
+                                         const char *package_id,
+                                         const char *architecture,
+                                         const char **driver_store_path,
+                                         const char **cab_path)
+{
+       WERROR result;
+       struct dcerpc_binding_handle *b;
+       TALLOC_CTX *tmp_ctx;
+
+       tmp_ctx = talloc_stackframe();
+       if (tmp_ctx == NULL) {
+               return WERR_NOT_ENOUGH_MEMORY;
+       }
+
+       result = winreg_printer_binding_handle(tmp_ctx, session_info, msg_ctx, &b);
+       if (!W_ERROR_IS_OK(result)) {
+               talloc_free(tmp_ctx);
+               return result;
+       }
+
+       result = winreg_get_driver_package(mem_ctx,
+                                          b,
+                                          package_id,
+                                          architecture,
+                                          driver_store_path,
+                                          cab_path);
+
+       talloc_free(tmp_ctx);
+       return result;
+}
+
 WERROR winreg_get_printer_secdesc_internal(TALLOC_CTX *mem_ctx,
                                           const struct auth_session_info *session_info,
                                           struct messaging_context *msg_ctx,
index d9cddcdaafce4eb953891f041095b6d1bfc5994d..0c850ca282bb3cce328f529a2618e398c4208686 100644 (file)
@@ -175,4 +175,11 @@ WERROR winreg_add_driver_package_internal(TALLOC_CTX *mem_ctx,
                                          const char *architecture,
                                          const char *driver_store_path,
                                          const char *cab_path);
+WERROR winreg_get_driver_package_internal(TALLOC_CTX *mem_ctx,
+                                         const struct auth_session_info *session_info,
+                                         struct messaging_context *msg_ctx,
+                                         const char *package_id,
+                                         const char *architecture,
+                                         const char **driver_store_path,
+                                         const char **cab_path);
 #endif /* _SRV_SPOOLSS_UITL_H */