a3a04f
From 9fb528332f48de59d70d48686e3af4df70206635 Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Tue, 29 Aug 2017 17:06:21 +0200
a3a04f
Subject: [PATCH 1/7] CVE-2017-12150: s3:popt_common: don't turn a guessed
a3a04f
 username into a specified one
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 source3/include/auth_info.h |  1 +
a3a04f
 source3/lib/popt_common.c   |  6 +-----
a3a04f
 source3/lib/util_cmdline.c  | 29 +++++++++++++++++++++++++++++
a3a04f
 3 files changed, 31 insertions(+), 5 deletions(-)
a3a04f
a3a04f
diff --git a/source3/include/auth_info.h b/source3/include/auth_info.h
a3a04f
index c6f71ad..8212c27 100644
a3a04f
--- a/source3/include/auth_info.h
a3a04f
+++ b/source3/include/auth_info.h
a3a04f
@@ -29,6 +29,7 @@ void set_cmdline_auth_info_from_file(struct user_auth_info *auth_info,
a3a04f
 const char *get_cmdline_auth_info_username(const struct user_auth_info *auth_info);
a3a04f
 void set_cmdline_auth_info_username(struct user_auth_info *auth_info,
a3a04f
 				    const char *username);
a3a04f
+void reset_cmdline_auth_info_username(struct user_auth_info *auth_info);
a3a04f
 const char *get_cmdline_auth_info_domain(const struct user_auth_info *auth_info);
a3a04f
 void set_cmdline_auth_info_domain(struct user_auth_info *auth_info,
a3a04f
 				  const char *domain);
a3a04f
diff --git a/source3/lib/popt_common.c b/source3/lib/popt_common.c
a3a04f
index 9928c70..36b5e92 100644
a3a04f
--- a/source3/lib/popt_common.c
a3a04f
+++ b/source3/lib/popt_common.c
a3a04f
@@ -238,7 +238,6 @@ void popt_common_credentials_set_delay_post(void)
a3a04f
 void popt_common_credentials_post(void)
a3a04f
 {
a3a04f
 	struct user_auth_info *auth_info = cmdline_auth_info;
a3a04f
-	const char *username = NULL;
a3a04f
 
a3a04f
 	if (get_cmdline_auth_info_use_machine_account(auth_info) &&
a3a04f
 	    !set_cmdline_auth_info_machine_account_creds(auth_info))
a3a04f
@@ -259,10 +258,7 @@ void popt_common_credentials_post(void)
a3a04f
 	 * correctly parsed yet. If we have a username we need to set it again
a3a04f
 	 * to run the string parser for the username correctly.
a3a04f
 	 */
a3a04f
-	username = get_cmdline_auth_info_username(auth_info);
a3a04f
-	if (username != NULL && username[0] != '\0') {
a3a04f
-		set_cmdline_auth_info_username(auth_info, username);
a3a04f
-	}
a3a04f
+	reset_cmdline_auth_info_username(auth_info);
a3a04f
 }
a3a04f
 
a3a04f
 static void popt_common_credentials_callback(poptContext con,
a3a04f
diff --git a/source3/lib/util_cmdline.c b/source3/lib/util_cmdline.c
a3a04f
index ad51a4f..80142e2 100644
a3a04f
--- a/source3/lib/util_cmdline.c
a3a04f
+++ b/source3/lib/util_cmdline.c
a3a04f
@@ -37,6 +37,7 @@
a3a04f
 struct user_auth_info {
a3a04f
 	struct cli_credentials *creds;
a3a04f
 	struct loadparm_context *lp_ctx;
a3a04f
+	bool got_username;
a3a04f
 	bool got_pass;
a3a04f
 	int signing_state;
a3a04f
 	bool smb_encrypt;
a3a04f
@@ -93,6 +94,7 @@ void set_cmdline_auth_info_from_file(struct user_auth_info *auth_info,
a3a04f
 	if (!ok) {
a3a04f
 		exit(EIO);
a3a04f
 	}
a3a04f
+	auth_info->got_username = true;
a3a04f
 }
a3a04f
 
a3a04f
 const char *get_cmdline_auth_info_username(const struct user_auth_info *auth_info)
a3a04f
@@ -123,11 +125,38 @@ void set_cmdline_auth_info_username(struct user_auth_info *auth_info,
a3a04f
 		exit(ENOMEM);
a3a04f
 	}
a3a04f
 
a3a04f
+	auth_info->got_username = true;
a3a04f
 	if (strchr_m(username, '%') != NULL) {
a3a04f
 		auth_info->got_pass = true;
a3a04f
 	}
a3a04f
 }
a3a04f
 
a3a04f
+void reset_cmdline_auth_info_username(struct user_auth_info *auth_info)
a3a04f
+{
a3a04f
+	const char *username = NULL;
a3a04f
+	const char *new_val = NULL;
a3a04f
+
a3a04f
+	if (!auth_info->got_username) {
a3a04f
+		return;
a3a04f
+	}
a3a04f
+
a3a04f
+	username = cli_credentials_get_username(auth_info->creds);
a3a04f
+	if (username == NULL) {
a3a04f
+		return;
a3a04f
+	}
a3a04f
+	if (username[0] == '\0') {
a3a04f
+		return;
a3a04f
+	}
a3a04f
+
a3a04f
+	cli_credentials_parse_string(auth_info->creds,
a3a04f
+				     username,
a3a04f
+				     CRED_SPECIFIED);
a3a04f
+	new_val = cli_credentials_get_username(auth_info->creds);
a3a04f
+	if (new_val == NULL) {
a3a04f
+		exit(ENOMEM);
a3a04f
+	}
a3a04f
+}
a3a04f
+
a3a04f
 const char *get_cmdline_auth_info_domain(const struct user_auth_info *auth_info)
a3a04f
 {
a3a04f
 	const char *domain = NULL;
a3a04f
-- 
a3a04f
1.9.1
a3a04f
a3a04f
a3a04f
From 97a7ddff5d327bf5bcc27c8a88b000b3a187a827 Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Thu, 3 Nov 2016 17:16:43 +0100
a3a04f
Subject: [PATCH 2/7] CVE-2017-12150: s3:lib:
a3a04f
 get_cmdline_auth_info_signing_state smb_encrypt SMB_SIGNING_REQUIRED
a3a04f
a3a04f
This is an addition to the fixes for CVE-2015-5296.
a3a04f
a3a04f
It applies to smb2mount -e, smbcacls -e and smbcquotas -e.
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 source3/lib/util_cmdline.c | 3 +++
a3a04f
 1 file changed, 3 insertions(+)
a3a04f
a3a04f
diff --git a/source3/lib/util_cmdline.c b/source3/lib/util_cmdline.c
a3a04f
index 80142e2..90ee67c 100644
a3a04f
--- a/source3/lib/util_cmdline.c
a3a04f
+++ b/source3/lib/util_cmdline.c
a3a04f
@@ -265,6 +265,9 @@ void set_cmdline_auth_info_signing_state_raw(struct user_auth_info *auth_info,
a3a04f
 
a3a04f
 int get_cmdline_auth_info_signing_state(const struct user_auth_info *auth_info)
a3a04f
 {
a3a04f
+	if (auth_info->smb_encrypt) {
a3a04f
+		return SMB_SIGNING_REQUIRED;
a3a04f
+	}
a3a04f
 	return auth_info->signing_state;
a3a04f
 }
a3a04f
 
a3a04f
-- 
a3a04f
1.9.1
a3a04f
a3a04f
a3a04f
From b760a464ee3d94edeff6eb10a0b08359d6e98099 Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Fri, 9 Dec 2016 09:26:32 +0100
a3a04f
Subject: [PATCH 3/7] CVE-2017-12150: s3:pylibsmb: make use of
a3a04f
 SMB_SIGNING_DEFAULT for 'samba.samba3.libsmb_samba_internal'
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 source3/libsmb/pylibsmb.c | 2 +-
a3a04f
 1 file changed, 1 insertion(+), 1 deletion(-)
a3a04f
a3a04f
diff --git a/source3/libsmb/pylibsmb.c b/source3/libsmb/pylibsmb.c
a3a04f
index 59c0998..350c6d4 100644
a3a04f
--- a/source3/libsmb/pylibsmb.c
a3a04f
+++ b/source3/libsmb/pylibsmb.c
a3a04f
@@ -444,7 +444,7 @@ static int py_cli_state_init(struct py_cli_state *self, PyObject *args,
a3a04f
 
a3a04f
 	req = cli_full_connection_creds_send(
a3a04f
 		NULL, self->ev, "myname", host, NULL, 0, share, "?????",
a3a04f
-		cli_creds, 0, 0);
a3a04f
+		cli_creds, 0, SMB_SIGNING_DEFAULT);
a3a04f
 	if (!py_tevent_req_wait_exc(self->ev, req)) {
a3a04f
 		return -1;
a3a04f
 	}
a3a04f
-- 
a3a04f
1.9.1
a3a04f
a3a04f
a3a04f
From f42ffde214c3be1d6ba3afd8fe88a3e04470c4bd Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Mon, 12 Dec 2016 05:49:46 +0100
a3a04f
Subject: [PATCH 4/7] CVE-2017-12150: libgpo: make use of SMB_SIGNING_REQUIRED
a3a04f
 in gpo_connect_server()
a3a04f
a3a04f
It's important that we use a signed connection to get the GPOs!
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 libgpo/gpo_fetch.c | 2 +-
a3a04f
 1 file changed, 1 insertion(+), 1 deletion(-)
a3a04f
a3a04f
diff --git a/libgpo/gpo_fetch.c b/libgpo/gpo_fetch.c
a3a04f
index 836bc23..3740d4e 100644
a3a04f
--- a/libgpo/gpo_fetch.c
a3a04f
+++ b/libgpo/gpo_fetch.c
a3a04f
@@ -133,7 +133,7 @@ static NTSTATUS gpo_connect_server(ADS_STRUCT *ads,
a3a04f
 			ads->auth.password,
a3a04f
 			CLI_FULL_CONNECTION_USE_KERBEROS |
a3a04f
 			CLI_FULL_CONNECTION_FALLBACK_AFTER_KERBEROS,
a3a04f
-			Undefined);
a3a04f
+			SMB_SIGNING_REQUIRED);
a3a04f
 	if (!NT_STATUS_IS_OK(result)) {
a3a04f
 		DEBUG(10,("check_refresh_gpo: "
a3a04f
 				"failed to connect: %s\n",
a3a04f
-- 
a3a04f
1.9.1
a3a04f
a3a04f
a3a04f
From d8c6aceb94ab72991eb538ab5dc388686a177052 Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Tue, 29 Aug 2017 15:24:14 +0200
a3a04f
Subject: [PATCH 5/7] CVE-2017-12150: auth/credentials:
a3a04f
 cli_credentials_authentication_requested() should check for
a3a04f
 NTLM_CCACHE/SIGN/SEAL
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 auth/credentials/credentials.c | 16 ++++++++++++++++
a3a04f
 1 file changed, 16 insertions(+)
a3a04f
a3a04f
diff --git a/auth/credentials/credentials.c b/auth/credentials/credentials.c
a3a04f
index 06648c7..5e3b5e8 100644
a3a04f
--- a/auth/credentials/credentials.c
a3a04f
+++ b/auth/credentials/credentials.c
a3a04f
@@ -25,6 +25,7 @@
a3a04f
 #include "librpc/gen_ndr/samr.h" /* for struct samrPassword */
a3a04f
 #include "auth/credentials/credentials.h"
a3a04f
 #include "auth/credentials/credentials_internal.h"
a3a04f
+#include "auth/gensec/gensec.h"
a3a04f
 #include "libcli/auth/libcli_auth.h"
a3a04f
 #include "tevent.h"
a3a04f
 #include "param/param.h"
a3a04f
@@ -300,6 +301,8 @@ _PUBLIC_ bool cli_credentials_set_principal_callback(struct cli_credentials *cre
a3a04f
 
a3a04f
 _PUBLIC_ bool cli_credentials_authentication_requested(struct cli_credentials *cred) 
a3a04f
 {
a3a04f
+	uint32_t gensec_features = 0;
a3a04f
+
a3a04f
 	if (cred->bind_dn) {
a3a04f
 		return true;
a3a04f
 	}
a3a04f
@@ -327,6 +330,19 @@ _PUBLIC_ bool cli_credentials_authentication_requested(struct cli_credentials *c
a3a04f
 		return true;
a3a04f
 	}
a3a04f
 
a3a04f
+	gensec_features = cli_credentials_get_gensec_features(cred);
a3a04f
+	if (gensec_features & GENSEC_FEATURE_NTLM_CCACHE) {
a3a04f
+		return true;
a3a04f
+	}
a3a04f
+
a3a04f
+	if (gensec_features & GENSEC_FEATURE_SIGN) {
a3a04f
+		return true;
a3a04f
+	}
a3a04f
+
a3a04f
+	if (gensec_features & GENSEC_FEATURE_SEAL) {
a3a04f
+		return true;
a3a04f
+	}
a3a04f
+
a3a04f
 	return false;
a3a04f
 }
a3a04f
 
a3a04f
-- 
a3a04f
1.9.1
a3a04f
a3a04f
a3a04f
From 28f4a8dbd2b82bb8fb9f6224e1641d935766e62a Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Tue, 29 Aug 2017 15:35:49 +0200
a3a04f
Subject: [PATCH 6/7] CVE-2017-12150: libcli/smb: add
a3a04f
 smbXcli_conn_signing_mandatory()
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 libcli/smb/smbXcli_base.c | 5 +++++
a3a04f
 libcli/smb/smbXcli_base.h | 1 +
a3a04f
 2 files changed, 6 insertions(+)
a3a04f
a3a04f
diff --git a/libcli/smb/smbXcli_base.c b/libcli/smb/smbXcli_base.c
a3a04f
index b21d796..239e5eb 100644
a3a04f
--- a/libcli/smb/smbXcli_base.c
a3a04f
+++ b/libcli/smb/smbXcli_base.c
a3a04f
@@ -468,6 +468,11 @@ bool smbXcli_conn_use_unicode(struct smbXcli_conn *conn)
a3a04f
 	return false;
a3a04f
 }
a3a04f
 
a3a04f
+bool smbXcli_conn_signing_mandatory(struct smbXcli_conn *conn)
a3a04f
+{
a3a04f
+	return conn->mandatory_signing;
a3a04f
+}
a3a04f
+
a3a04f
 void smbXcli_conn_set_sockopt(struct smbXcli_conn *conn, const char *options)
a3a04f
 {
a3a04f
 	set_socket_options(conn->sock_fd, options);
a3a04f
diff --git a/libcli/smb/smbXcli_base.h b/libcli/smb/smbXcli_base.h
a3a04f
index e48fc35..2594f07 100644
a3a04f
--- a/libcli/smb/smbXcli_base.h
a3a04f
+++ b/libcli/smb/smbXcli_base.h
a3a04f
@@ -47,6 +47,7 @@ bool smbXcli_conn_dfs_supported(struct smbXcli_conn *conn);
a3a04f
 
a3a04f
 enum protocol_types smbXcli_conn_protocol(struct smbXcli_conn *conn);
a3a04f
 bool smbXcli_conn_use_unicode(struct smbXcli_conn *conn);
a3a04f
+bool smbXcli_conn_signing_mandatory(struct smbXcli_conn *conn);
a3a04f
 
a3a04f
 void smbXcli_conn_set_sockopt(struct smbXcli_conn *conn, const char *options);
a3a04f
 const struct sockaddr_storage *smbXcli_conn_local_sockaddr(struct smbXcli_conn *conn);
a3a04f
-- 
a3a04f
1.9.1
a3a04f
a3a04f
a3a04f
From 28506663282a1457708c38c58437e9eb9c0002bf Mon Sep 17 00:00:00 2001
a3a04f
From: Stefan Metzmacher <metze@samba.org>
a3a04f
Date: Mon, 12 Dec 2016 06:07:56 +0100
a3a04f
Subject: [PATCH 7/7] CVE-2017-12150: s3:libsmb: only fallback to anonymous if
a3a04f
 authentication was not requested
a3a04f
a3a04f
With forced encryption or required signing we should also don't fallback.
a3a04f
a3a04f
BUG: https://bugzilla.samba.org/show_bug.cgi?id=12997
a3a04f
a3a04f
Signed-off-by: Stefan Metzmacher <metze@samba.org>
a3a04f
---
a3a04f
 source3/libsmb/clidfs.c | 16 ++++------------
a3a04f
 1 file changed, 4 insertions(+), 12 deletions(-)
a3a04f
a3a04f
diff --git a/source3/libsmb/clidfs.c b/source3/libsmb/clidfs.c
a3a04f
index 75012b2..fdcd665 100644
a3a04f
--- a/source3/libsmb/clidfs.c
a3a04f
+++ b/source3/libsmb/clidfs.c
a3a04f
@@ -26,6 +26,7 @@
a3a04f
 #include "trans2.h"
a3a04f
 #include "libsmb/nmblib.h"
a3a04f
 #include "../libcli/smb/smbXcli_base.h"
a3a04f
+#include "auth/credentials/credentials.h"
a3a04f
 
a3a04f
 /********************************************************************
a3a04f
  Important point.
a3a04f
@@ -145,9 +146,6 @@ static NTSTATUS do_connect(TALLOC_CTX *ctx,
a3a04f
 	char *servicename;
a3a04f
 	char *sharename;
a3a04f
 	char *newserver, *newshare;
a3a04f
-	const char *username;
a3a04f
-	const char *password;
a3a04f
-	const char *domain;
a3a04f
 	NTSTATUS status;
a3a04f
 	int flags = 0;
a3a04f
 	int signing_state = get_cmdline_auth_info_signing_state(auth_info);
a3a04f
@@ -225,21 +223,15 @@ static NTSTATUS do_connect(TALLOC_CTX *ctx,
a3a04f
 		smb2cli_conn_set_max_credits(c->conn, DEFAULT_SMB2_MAX_CREDITS);
a3a04f
 	}
a3a04f
 
a3a04f
-	username = get_cmdline_auth_info_username(auth_info);
a3a04f
-	password = get_cmdline_auth_info_password(auth_info);
a3a04f
-	domain = get_cmdline_auth_info_domain(auth_info);
a3a04f
-	if ((domain == NULL) || (domain[0] == '\0')) {
a3a04f
-		domain = lp_workgroup();
a3a04f
-	}
a3a04f
-
a3a04f
 	creds = get_cmdline_auth_info_creds(auth_info);
a3a04f
 
a3a04f
 	status = cli_session_setup_creds(c, creds);
a3a04f
 	if (!NT_STATUS_IS_OK(status)) {
a3a04f
 		/* If a password was not supplied then
a3a04f
 		 * try again with a null username. */
a3a04f
-		if (password[0] || !username[0] ||
a3a04f
-			get_cmdline_auth_info_use_kerberos(auth_info) ||
a3a04f
+		if (force_encrypt || smbXcli_conn_signing_mandatory(c->conn) ||
a3a04f
+			cli_credentials_authentication_requested(creds) ||
a3a04f
+			cli_credentials_is_anonymous(creds) ||
a3a04f
 			!NT_STATUS_IS_OK(status = cli_session_setup_anon(c)))
a3a04f
 		{
a3a04f
 			d_printf("session setup failed: %s\n",
a3a04f
-- 
a3a04f
1.9.1
a3a04f