Compare commits
No commits in common. 'git-annex' and 'master' have entirely different histories.
39 changed files with 12108 additions and 5 deletions
@ -0,0 +1 @@ |
||||
*.tar.xz filter=lfs diff=lfs merge=lfs -text |
@ -0,0 +1 @@ |
||||
samba.spec.mod |
@ -0,0 +1,3 @@ |
||||
the .tito/packages directory contains metadata files |
||||
named after their packages. Each file has the latest tagged |
||||
version and the project's relative directory. |
@ -0,0 +1 @@ |
||||
4.9.1-106.dc ./ |
@ -0,0 +1 @@ |
||||
../../tito_libs/releasers.conf |
@ -0,0 +1,6 @@ |
||||
[buildconfig] |
||||
builder = fws.builder.GitLfsBuilder |
||||
tagger = tito.tagger.ReleaseTagger |
||||
changelog_do_not_remove_cherrypick = 0 |
||||
changelog_format = %s (%ae) |
||||
lib_dir = ../tito_libs |
@ -0,0 +1,20 @@ |
||||
MIT Kerberos 5 Support |
||||
======================= |
||||
|
||||
Fedora is using MIT Kerberos implementation as its Kerberos infrastructure of |
||||
choice. The Samba build in Fedora is using MIT Kerberos implementation in order |
||||
to allow system-wide interoperability between both desktop and server |
||||
applications running on the same machine. |
||||
|
||||
At the moment the Samba Active Directory Domain Controller implementation is |
||||
not available with MIT Kereberos. FreeIPA and Samba Team members are currently |
||||
working on Samba MIT Kerberos support as this is a requirement for a GNU/Linux |
||||
distribution integration of Samba AD DC features. |
||||
|
||||
We have just finished migrating the file server and all client utilities to MIT |
||||
Kerberos. The result of this work is available in samba-* packages in Fedora. |
||||
We'll provide Samba AD DC functionality as soon as its support of MIT Kerberos |
||||
KDC will be ready. |
||||
|
||||
In case of further questions do not hesitate to send your inquiries to |
||||
samba-owner@fedoraproject.org |
@ -0,0 +1,29 @@ |
||||
Downgrading Samba |
||||
================= |
||||
|
||||
Short version: data-preserving downgrades between Samba versions are not supported |
||||
|
||||
Long version: |
||||
With Samba development there are cases when on-disk database format evolves. |
||||
In general, Samba Team attempts to maintain forward compatibility and |
||||
automatically upgrade databases during runtime when requires. |
||||
However, when downgrade is required Samba will not perform downgrade to |
||||
existing databases. It may be impossible if new features that caused database |
||||
upgrade are in use. Thus, one needs to consider a downgrade procedure before |
||||
actually downgrading Samba setup. |
||||
|
||||
Please always perform back up prior both upgrading and downgrading across major |
||||
version changes. Restoring database files is easiest and simplest way to get to |
||||
previously working setup. |
||||
|
||||
Easiest way to downgrade is to remove all created databases and start from scratch. |
||||
This means losing all authentication and domain relationship data, as well as |
||||
user databases (in case of tdb storage), printers, registry settings, and winbindd |
||||
caches. |
||||
|
||||
Remove databases in following locations: |
||||
/var/lib/samba/*.tdb |
||||
/var/lib/samba/private/*.tdb |
||||
|
||||
In particular, registry settings are known to prevent running downgraded versions |
||||
(Samba 4 to Samba 3) as registry format has changed between Samba 3 and Samba 4. |
@ -1 +0,0 @@ |
||||
1527491374.026095633s 1 e2299539-99e7-4f60-9098-872d514dc801 |
@ -1,2 +0,0 @@ |
||||
1521556542.293351514s 1 00000000-0000-0000-0000-000000000001 |
||||
1521556542.295925385s 1 e2299539-99e7-4f60-9098-872d514dc801 |
@ -1 +0,0 @@ |
||||
1521556542.292001502s 1 https://download.samba.org/pub/samba/stable/samba-4.6.2.tar.gz |
Binary file not shown.
@ -0,0 +1,38 @@ |
||||
# |
||||
# pam_winbind configuration file |
||||
# |
||||
# /etc/security/pam_winbind.conf |
||||
# |
||||
|
||||
[global] |
||||
|
||||
# turn on debugging |
||||
;debug = no |
||||
|
||||
# turn on extended PAM state debugging |
||||
;debug_state = no |
||||
|
||||
# request a cached login if possible |
||||
# (needs "winbind offline logon = yes" in smb.conf) |
||||
;cached_login = no |
||||
|
||||
# authenticate using kerberos |
||||
;krb5_auth = no |
||||
|
||||
# when using kerberos, request a "FILE" krb5 credential cache type |
||||
# (leave empty to just do krb5 authentication but not have a ticket |
||||
# afterwards) |
||||
;krb5_ccache_type = |
||||
|
||||
# make successful authentication dependend on membership of one SID |
||||
# (can also take a name) |
||||
;require_membership_of = |
||||
|
||||
# password expiry warning period in days |
||||
;warn_pwd_expire = 14 |
||||
|
||||
# omit pam conversations |
||||
;silent = no |
||||
|
||||
# create homedirectory on the fly |
||||
;mkhomedir = no |
@ -0,0 +1,38 @@ |
||||
From cbea69c909bfe4aed541d1b4ffc2f859642f4000 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Thu, 17 Jan 2019 13:58:14 +0100
|
||||
Subject: [PATCH] s3:lib: Fix the debug message for adding cache entries.
|
||||
|
||||
To get correct values, we need to cast 'timeout' to 'long int' first in
|
||||
order to do calculation in that integer space! Calculations are don in
|
||||
the space of the lvalue!
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Volker Lendecke <vl@samba.org>
|
||||
---
|
||||
source3/lib/gencache.c | 8 ++++----
|
||||
1 file changed, 4 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/source3/lib/gencache.c b/source3/lib/gencache.c
|
||||
index ab12fc1c531..9f4e1cfcaa3 100644
|
||||
--- a/source3/lib/gencache.c
|
||||
+++ b/source3/lib/gencache.c
|
||||
@@ -294,11 +294,11 @@ bool gencache_set_data_blob(const char *keystr, DATA_BLOB blob,
|
||||
dbufs[0] = (TDB_DATA) { .dptr = (uint8_t *)hdr, .dsize = hdr_len };
|
||||
dbufs[1] = (TDB_DATA) { .dptr = blob.data, .dsize = blob.length };
|
||||
|
||||
- DEBUG(10, ("Adding cache entry with key=[%s] and timeout="
|
||||
- "[%s] (%d seconds %s)\n", keystr,
|
||||
+ DBG_DEBUG("Adding cache entry with key=[%s] and timeout="
|
||||
+ "[%s] (%ld seconds %s)\n", keystr,
|
||||
timestring(talloc_tos(), timeout),
|
||||
- (int)(timeout - time(NULL)),
|
||||
- timeout > time(NULL) ? "ahead" : "in the past"));
|
||||
+ ((long int)timeout) - time(NULL),
|
||||
+ timeout > time(NULL) ? "ahead" : "in the past");
|
||||
|
||||
ret = tdb_storev(cache_notrans->tdb, string_term_tdb_data(keystr),
|
||||
dbufs, 2, 0);
|
||||
--
|
||||
2.20.1
|
||||
|
@ -0,0 +1,151 @@ |
||||
From a803d2524b8c06e2c360db0c686a212ac49f7321 Mon Sep 17 00:00:00 2001
|
||||
From: Jeremy Allison <jra@samba.org>
|
||||
Date: Thu, 21 Mar 2019 14:51:30 -0700
|
||||
Subject: [PATCH] CVE-2019-3880 s3: rpc: winreg: Remove implementations of
|
||||
SaveKey/RestoreKey.
|
||||
|
||||
The were not using VFS backend calls and could only work
|
||||
locally, and were unsafe against symlink races and other
|
||||
security issues.
|
||||
|
||||
If the incoming handle is valid, return WERR_BAD_PATHNAME.
|
||||
|
||||
[MS-RRP] states "The format of the file name is implementation-specific"
|
||||
so ensure we don't allow this.
|
||||
|
||||
As reported by Michael Hanselmann.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13851
|
||||
|
||||
Signed-off-by: Jeremy Allison <jra@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
---
|
||||
source3/rpc_server/winreg/srv_winreg_nt.c | 92 ++-----------------------------
|
||||
1 file changed, 4 insertions(+), 88 deletions(-)
|
||||
|
||||
diff --git a/source3/rpc_server/winreg/srv_winreg_nt.c b/source3/rpc_server/winreg/srv_winreg_nt.c
|
||||
index d9ee8d0602d..816c6bb2a12 100644
|
||||
--- a/source3/rpc_server/winreg/srv_winreg_nt.c
|
||||
+++ b/source3/rpc_server/winreg/srv_winreg_nt.c
|
||||
@@ -640,46 +640,6 @@ WERROR _winreg_AbortSystemShutdown(struct pipes_struct *p,
|
||||
}
|
||||
|
||||
/*******************************************************************
|
||||
- ********************************************************************/
|
||||
-
|
||||
-static int validate_reg_filename(TALLOC_CTX *ctx, char **pp_fname )
|
||||
-{
|
||||
- char *p = NULL;
|
||||
- int num_services = lp_numservices();
|
||||
- int snum = -1;
|
||||
- const char *share_path = NULL;
|
||||
- char *fname = *pp_fname;
|
||||
-
|
||||
- /* convert to a unix path, stripping the C:\ along the way */
|
||||
-
|
||||
- if (!(p = valid_share_pathname(ctx, fname))) {
|
||||
- return -1;
|
||||
- }
|
||||
-
|
||||
- /* has to exist within a valid file share */
|
||||
-
|
||||
- for (snum=0; snum<num_services; snum++) {
|
||||
- if (!lp_snum_ok(snum) || lp_printable(snum)) {
|
||||
- continue;
|
||||
- }
|
||||
-
|
||||
- share_path = lp_path(talloc_tos(), snum);
|
||||
-
|
||||
- /* make sure we have a path (e.g. [homes] ) */
|
||||
- if (strlen(share_path) == 0) {
|
||||
- continue;
|
||||
- }
|
||||
-
|
||||
- if (strncmp(share_path, p, strlen(share_path)) == 0) {
|
||||
- break;
|
||||
- }
|
||||
- }
|
||||
-
|
||||
- *pp_fname = p;
|
||||
- return (snum < num_services) ? snum : -1;
|
||||
-}
|
||||
-
|
||||
-/*******************************************************************
|
||||
_winreg_RestoreKey
|
||||
********************************************************************/
|
||||
|
||||
@@ -687,36 +647,11 @@ WERROR _winreg_RestoreKey(struct pipes_struct *p,
|
||||
struct winreg_RestoreKey *r)
|
||||
{
|
||||
struct registry_key *regkey = find_regkey_by_hnd( p, r->in.handle );
|
||||
- char *fname = NULL;
|
||||
- int snum = -1;
|
||||
|
||||
- if ( !regkey )
|
||||
+ if ( !regkey ) {
|
||||
return WERR_INVALID_HANDLE;
|
||||
-
|
||||
- if ( !r->in.filename || !r->in.filename->name )
|
||||
- return WERR_INVALID_PARAMETER;
|
||||
-
|
||||
- fname = talloc_strdup(p->mem_ctx, r->in.filename->name);
|
||||
- if (!fname) {
|
||||
- return WERR_NOT_ENOUGH_MEMORY;
|
||||
}
|
||||
-
|
||||
- DEBUG(8,("_winreg_RestoreKey: verifying restore of key [%s] from "
|
||||
- "\"%s\"\n", regkey->key->name, fname));
|
||||
-
|
||||
- if ((snum = validate_reg_filename(p->mem_ctx, &fname)) == -1)
|
||||
- return WERR_BAD_PATHNAME;
|
||||
-
|
||||
- /* user must posses SeRestorePrivilege for this this proceed */
|
||||
-
|
||||
- if ( !security_token_has_privilege(p->session_info->security_token, SEC_PRIV_RESTORE)) {
|
||||
- return WERR_ACCESS_DENIED;
|
||||
- }
|
||||
-
|
||||
- DEBUG(2,("_winreg_RestoreKey: Restoring [%s] from %s in share %s\n",
|
||||
- regkey->key->name, fname, lp_servicename(talloc_tos(), snum) ));
|
||||
-
|
||||
- return reg_restorekey(regkey, fname);
|
||||
+ return WERR_BAD_PATHNAME;
|
||||
}
|
||||
|
||||
/*******************************************************************
|
||||
@@ -727,30 +662,11 @@ WERROR _winreg_SaveKey(struct pipes_struct *p,
|
||||
struct winreg_SaveKey *r)
|
||||
{
|
||||
struct registry_key *regkey = find_regkey_by_hnd( p, r->in.handle );
|
||||
- char *fname = NULL;
|
||||
- int snum = -1;
|
||||
|
||||
- if ( !regkey )
|
||||
+ if ( !regkey ) {
|
||||
return WERR_INVALID_HANDLE;
|
||||
-
|
||||
- if ( !r->in.filename || !r->in.filename->name )
|
||||
- return WERR_INVALID_PARAMETER;
|
||||
-
|
||||
- fname = talloc_strdup(p->mem_ctx, r->in.filename->name);
|
||||
- if (!fname) {
|
||||
- return WERR_NOT_ENOUGH_MEMORY;
|
||||
}
|
||||
-
|
||||
- DEBUG(8,("_winreg_SaveKey: verifying backup of key [%s] to \"%s\"\n",
|
||||
- regkey->key->name, fname));
|
||||
-
|
||||
- if ((snum = validate_reg_filename(p->mem_ctx, &fname)) == -1 )
|
||||
- return WERR_BAD_PATHNAME;
|
||||
-
|
||||
- DEBUG(2,("_winreg_SaveKey: Saving [%s] to %s in share %s\n",
|
||||
- regkey->key->name, fname, lp_servicename(talloc_tos(), snum) ));
|
||||
-
|
||||
- return reg_savekey(regkey, fname);
|
||||
+ return WERR_BAD_PATHNAME;
|
||||
}
|
||||
|
||||
/*******************************************************************
|
||||
--
|
||||
2.11.0
|
||||
|
@ -0,0 +1,280 @@ |
||||
From 5192b35d5e8644f000277c2f075b2ae90c514cbd Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Tue, 4 Sep 2018 15:48:03 +0200
|
||||
Subject: [PATCH] s3:libsmbclient: Add function to set protocol levels
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit 0dae4e2f5c65167fdb2405e232436921a0bb17e6)
|
||||
---
|
||||
source3/include/libsmbclient.h | 19 ++-
|
||||
source3/libsmb/ABI/smbclient-0.5.0.sigs | 185 ++++++++++++++++++++++++
|
||||
source3/libsmb/libsmb_setget.c | 18 +++
|
||||
source3/libsmb/wscript | 2 +-
|
||||
4 files changed, 222 insertions(+), 2 deletions(-)
|
||||
create mode 100644 source3/libsmb/ABI/smbclient-0.5.0.sigs
|
||||
|
||||
diff --git a/source3/include/libsmbclient.h b/source3/include/libsmbclient.h
|
||||
index ca5c7f87f71..5e4a1715402 100644
|
||||
--- a/source3/include/libsmbclient.h
|
||||
+++ b/source3/include/libsmbclient.h
|
||||
@@ -831,7 +831,24 @@ smbc_getOptionUseNTHash(SMBCCTX *c);
|
||||
void
|
||||
smbc_setOptionUseNTHash(SMBCCTX *c, smbc_bool b);
|
||||
|
||||
-
|
||||
+/**
|
||||
+ * @brief Set the 'client min protocol' and the 'client max protocol'.
|
||||
+ *
|
||||
+ * IMPORTANT: This overrrides the values 'client min protocol' and 'client max
|
||||
+ * protocol' set in the smb.conf file!
|
||||
+ *
|
||||
+ * @param[in] c The smbc context to use.
|
||||
+ *
|
||||
+ * @param[in] min_proto The minimal protocol to use or NULL for leaving it
|
||||
+ * untouched.
|
||||
+ *
|
||||
+ * @param[in] max_proto The maximum protocol to use or NULL for leaving it
|
||||
+ * untouched.
|
||||
+ *
|
||||
+ * @returns true for success, false otherwise
|
||||
+ */
|
||||
+smbc_bool
|
||||
+smbc_setOptionProtocols(SMBCCTX *c, const char *min_proto, const char *max_proto);
|
||||
|
||||
/*************************************
|
||||
* Getters and setters for FUNCTIONS *
|
||||
diff --git a/source3/libsmb/ABI/smbclient-0.5.0.sigs b/source3/libsmb/ABI/smbclient-0.5.0.sigs
|
||||
new file mode 100644
|
||||
index 00000000000..b4245979c24
|
||||
--- /dev/null
|
||||
+++ b/source3/libsmb/ABI/smbclient-0.5.0.sigs
|
||||
@@ -0,0 +1,185 @@
|
||||
+smbc_chmod: int (const char *, mode_t)
|
||||
+smbc_close: int (int)
|
||||
+smbc_closedir: int (int)
|
||||
+smbc_creat: int (const char *, mode_t)
|
||||
+smbc_fgetxattr: int (int, const char *, const void *, size_t)
|
||||
+smbc_flistxattr: int (int, char *, size_t)
|
||||
+smbc_free_context: int (SMBCCTX *, int)
|
||||
+smbc_fremovexattr: int (int, const char *)
|
||||
+smbc_fsetxattr: int (int, const char *, const void *, size_t, int)
|
||||
+smbc_fstat: int (int, struct stat *)
|
||||
+smbc_fstatvfs: int (int, struct statvfs *)
|
||||
+smbc_ftruncate: int (int, off_t)
|
||||
+smbc_getDebug: int (SMBCCTX *)
|
||||
+smbc_getFunctionAddCachedServer: smbc_add_cached_srv_fn (SMBCCTX *)
|
||||
+smbc_getFunctionAuthData: smbc_get_auth_data_fn (SMBCCTX *)
|
||||
+smbc_getFunctionAuthDataWithContext: smbc_get_auth_data_with_context_fn (SMBCCTX *)
|
||||
+smbc_getFunctionCheckServer: smbc_check_server_fn (SMBCCTX *)
|
||||
+smbc_getFunctionChmod: smbc_chmod_fn (SMBCCTX *)
|
||||
+smbc_getFunctionClose: smbc_close_fn (SMBCCTX *)
|
||||
+smbc_getFunctionClosedir: smbc_closedir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionCreat: smbc_creat_fn (SMBCCTX *)
|
||||
+smbc_getFunctionFstat: smbc_fstat_fn (SMBCCTX *)
|
||||
+smbc_getFunctionFstatVFS: smbc_fstatvfs_fn (SMBCCTX *)
|
||||
+smbc_getFunctionFstatdir: smbc_fstatdir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionFtruncate: smbc_ftruncate_fn (SMBCCTX *)
|
||||
+smbc_getFunctionGetCachedServer: smbc_get_cached_srv_fn (SMBCCTX *)
|
||||
+smbc_getFunctionGetdents: smbc_getdents_fn (SMBCCTX *)
|
||||
+smbc_getFunctionGetxattr: smbc_getxattr_fn (SMBCCTX *)
|
||||
+smbc_getFunctionListPrintJobs: smbc_list_print_jobs_fn (SMBCCTX *)
|
||||
+smbc_getFunctionListxattr: smbc_listxattr_fn (SMBCCTX *)
|
||||
+smbc_getFunctionLseek: smbc_lseek_fn (SMBCCTX *)
|
||||
+smbc_getFunctionLseekdir: smbc_lseekdir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionMkdir: smbc_mkdir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionNotify: smbc_notify_fn (SMBCCTX *)
|
||||
+smbc_getFunctionOpen: smbc_open_fn (SMBCCTX *)
|
||||
+smbc_getFunctionOpenPrintJob: smbc_open_print_job_fn (SMBCCTX *)
|
||||
+smbc_getFunctionOpendir: smbc_opendir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionPrintFile: smbc_print_file_fn (SMBCCTX *)
|
||||
+smbc_getFunctionPurgeCachedServers: smbc_purge_cached_fn (SMBCCTX *)
|
||||
+smbc_getFunctionRead: smbc_read_fn (SMBCCTX *)
|
||||
+smbc_getFunctionReaddir: smbc_readdir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionReaddirPlus: smbc_readdirplus_fn (SMBCCTX *)
|
||||
+smbc_getFunctionRemoveCachedServer: smbc_remove_cached_srv_fn (SMBCCTX *)
|
||||
+smbc_getFunctionRemoveUnusedServer: smbc_remove_unused_server_fn (SMBCCTX *)
|
||||
+smbc_getFunctionRemovexattr: smbc_removexattr_fn (SMBCCTX *)
|
||||
+smbc_getFunctionRename: smbc_rename_fn (SMBCCTX *)
|
||||
+smbc_getFunctionRmdir: smbc_rmdir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionSetxattr: smbc_setxattr_fn (SMBCCTX *)
|
||||
+smbc_getFunctionSplice: smbc_splice_fn (SMBCCTX *)
|
||||
+smbc_getFunctionStat: smbc_stat_fn (SMBCCTX *)
|
||||
+smbc_getFunctionStatVFS: smbc_statvfs_fn (SMBCCTX *)
|
||||
+smbc_getFunctionTelldir: smbc_telldir_fn (SMBCCTX *)
|
||||
+smbc_getFunctionUnlink: smbc_unlink_fn (SMBCCTX *)
|
||||
+smbc_getFunctionUnlinkPrintJob: smbc_unlink_print_job_fn (SMBCCTX *)
|
||||
+smbc_getFunctionUtimes: smbc_utimes_fn (SMBCCTX *)
|
||||
+smbc_getFunctionWrite: smbc_write_fn (SMBCCTX *)
|
||||
+smbc_getNetbiosName: const char *(SMBCCTX *)
|
||||
+smbc_getOptionBrowseMaxLmbCount: int (SMBCCTX *)
|
||||
+smbc_getOptionCaseSensitive: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionDebugToStderr: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionFallbackAfterKerberos: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionFullTimeNames: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionNoAutoAnonymousLogin: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionOneSharePerServer: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionOpenShareMode: smbc_share_mode (SMBCCTX *)
|
||||
+smbc_getOptionSmbEncryptionLevel: smbc_smb_encrypt_level (SMBCCTX *)
|
||||
+smbc_getOptionUrlEncodeReaddirEntries: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionUseCCache: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionUseKerberos: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionUseNTHash: smbc_bool (SMBCCTX *)
|
||||
+smbc_getOptionUserData: void *(SMBCCTX *)
|
||||
+smbc_getPort: uint16_t (SMBCCTX *)
|
||||
+smbc_getServerCacheData: struct smbc_server_cache *(SMBCCTX *)
|
||||
+smbc_getTimeout: int (SMBCCTX *)
|
||||
+smbc_getUser: const char *(SMBCCTX *)
|
||||
+smbc_getWorkgroup: const char *(SMBCCTX *)
|
||||
+smbc_getdents: int (unsigned int, struct smbc_dirent *, int)
|
||||
+smbc_getxattr: int (const char *, const char *, const void *, size_t)
|
||||
+smbc_init: int (smbc_get_auth_data_fn, int)
|
||||
+smbc_init_context: SMBCCTX *(SMBCCTX *)
|
||||
+smbc_lgetxattr: int (const char *, const char *, const void *, size_t)
|
||||
+smbc_list_print_jobs: int (const char *, smbc_list_print_job_fn)
|
||||
+smbc_listxattr: int (const char *, char *, size_t)
|
||||
+smbc_llistxattr: int (const char *, char *, size_t)
|
||||
+smbc_lremovexattr: int (const char *, const char *)
|
||||
+smbc_lseek: off_t (int, off_t, int)
|
||||
+smbc_lseekdir: int (int, off_t)
|
||||
+smbc_lsetxattr: int (const char *, const char *, const void *, size_t, int)
|
||||
+smbc_mkdir: int (const char *, mode_t)
|
||||
+smbc_new_context: SMBCCTX *(void)
|
||||
+smbc_notify: int (int, smbc_bool, uint32_t, unsigned int, smbc_notify_callback_fn, void *)
|
||||
+smbc_open: int (const char *, int, mode_t)
|
||||
+smbc_open_print_job: int (const char *)
|
||||
+smbc_opendir: int (const char *)
|
||||
+smbc_option_get: void *(SMBCCTX *, char *)
|
||||
+smbc_option_set: void (SMBCCTX *, char *, ...)
|
||||
+smbc_print_file: int (const char *, const char *)
|
||||
+smbc_read: ssize_t (int, void *, size_t)
|
||||
+smbc_readdir: struct smbc_dirent *(unsigned int)
|
||||
+smbc_readdirplus: const struct libsmb_file_info *(unsigned int)
|
||||
+smbc_removexattr: int (const char *, const char *)
|
||||
+smbc_rename: int (const char *, const char *)
|
||||
+smbc_rmdir: int (const char *)
|
||||
+smbc_setConfiguration: int (SMBCCTX *, const char *)
|
||||
+smbc_setDebug: void (SMBCCTX *, int)
|
||||
+smbc_setFunctionAddCachedServer: void (SMBCCTX *, smbc_add_cached_srv_fn)
|
||||
+smbc_setFunctionAuthData: void (SMBCCTX *, smbc_get_auth_data_fn)
|
||||
+smbc_setFunctionAuthDataWithContext: void (SMBCCTX *, smbc_get_auth_data_with_context_fn)
|
||||
+smbc_setFunctionCheckServer: void (SMBCCTX *, smbc_check_server_fn)
|
||||
+smbc_setFunctionChmod: void (SMBCCTX *, smbc_chmod_fn)
|
||||
+smbc_setFunctionClose: void (SMBCCTX *, smbc_close_fn)
|
||||
+smbc_setFunctionClosedir: void (SMBCCTX *, smbc_closedir_fn)
|
||||
+smbc_setFunctionCreat: void (SMBCCTX *, smbc_creat_fn)
|
||||
+smbc_setFunctionFstat: void (SMBCCTX *, smbc_fstat_fn)
|
||||
+smbc_setFunctionFstatVFS: void (SMBCCTX *, smbc_fstatvfs_fn)
|
||||
+smbc_setFunctionFstatdir: void (SMBCCTX *, smbc_fstatdir_fn)
|
||||
+smbc_setFunctionFtruncate: void (SMBCCTX *, smbc_ftruncate_fn)
|
||||
+smbc_setFunctionGetCachedServer: void (SMBCCTX *, smbc_get_cached_srv_fn)
|
||||
+smbc_setFunctionGetdents: void (SMBCCTX *, smbc_getdents_fn)
|
||||
+smbc_setFunctionGetxattr: void (SMBCCTX *, smbc_getxattr_fn)
|
||||
+smbc_setFunctionListPrintJobs: void (SMBCCTX *, smbc_list_print_jobs_fn)
|
||||
+smbc_setFunctionListxattr: void (SMBCCTX *, smbc_listxattr_fn)
|
||||
+smbc_setFunctionLseek: void (SMBCCTX *, smbc_lseek_fn)
|
||||
+smbc_setFunctionLseekdir: void (SMBCCTX *, smbc_lseekdir_fn)
|
||||
+smbc_setFunctionMkdir: void (SMBCCTX *, smbc_mkdir_fn)
|
||||
+smbc_setFunctionNotify: void (SMBCCTX *, smbc_notify_fn)
|
||||
+smbc_setFunctionOpen: void (SMBCCTX *, smbc_open_fn)
|
||||
+smbc_setFunctionOpenPrintJob: void (SMBCCTX *, smbc_open_print_job_fn)
|
||||
+smbc_setFunctionOpendir: void (SMBCCTX *, smbc_opendir_fn)
|
||||
+smbc_setFunctionPrintFile: void (SMBCCTX *, smbc_print_file_fn)
|
||||
+smbc_setFunctionPurgeCachedServers: void (SMBCCTX *, smbc_purge_cached_fn)
|
||||
+smbc_setFunctionRead: void (SMBCCTX *, smbc_read_fn)
|
||||
+smbc_setFunctionReaddir: void (SMBCCTX *, smbc_readdir_fn)
|
||||
+smbc_setFunctionReaddirPlus: void (SMBCCTX *, smbc_readdirplus_fn)
|
||||
+smbc_setFunctionRemoveCachedServer: void (SMBCCTX *, smbc_remove_cached_srv_fn)
|
||||
+smbc_setFunctionRemoveUnusedServer: void (SMBCCTX *, smbc_remove_unused_server_fn)
|
||||
+smbc_setFunctionRemovexattr: void (SMBCCTX *, smbc_removexattr_fn)
|
||||
+smbc_setFunctionRename: void (SMBCCTX *, smbc_rename_fn)
|
||||
+smbc_setFunctionRmdir: void (SMBCCTX *, smbc_rmdir_fn)
|
||||
+smbc_setFunctionSetxattr: void (SMBCCTX *, smbc_setxattr_fn)
|
||||
+smbc_setFunctionSplice: void (SMBCCTX *, smbc_splice_fn)
|
||||
+smbc_setFunctionStat: void (SMBCCTX *, smbc_stat_fn)
|
||||
+smbc_setFunctionStatVFS: void (SMBCCTX *, smbc_statvfs_fn)
|
||||
+smbc_setFunctionTelldir: void (SMBCCTX *, smbc_telldir_fn)
|
||||
+smbc_setFunctionUnlink: void (SMBCCTX *, smbc_unlink_fn)
|
||||
+smbc_setFunctionUnlinkPrintJob: void (SMBCCTX *, smbc_unlink_print_job_fn)
|
||||
+smbc_setFunctionUtimes: void (SMBCCTX *, smbc_utimes_fn)
|
||||
+smbc_setFunctionWrite: void (SMBCCTX *, smbc_write_fn)
|
||||
+smbc_setLogCallback: void (SMBCCTX *, void *, smbc_debug_callback_fn)
|
||||
+smbc_setNetbiosName: void (SMBCCTX *, const char *)
|
||||
+smbc_setOptionBrowseMaxLmbCount: void (SMBCCTX *, int)
|
||||
+smbc_setOptionCaseSensitive: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionDebugToStderr: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionFallbackAfterKerberos: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionFullTimeNames: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionNoAutoAnonymousLogin: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionOneSharePerServer: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionOpenShareMode: void (SMBCCTX *, smbc_share_mode)
|
||||
+smbc_setOptionProtocols: smbc_bool (SMBCCTX *, const char *, const char *)
|
||||
+smbc_setOptionSmbEncryptionLevel: void (SMBCCTX *, smbc_smb_encrypt_level)
|
||||
+smbc_setOptionUrlEncodeReaddirEntries: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionUseCCache: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionUseKerberos: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionUseNTHash: void (SMBCCTX *, smbc_bool)
|
||||
+smbc_setOptionUserData: void (SMBCCTX *, void *)
|
||||
+smbc_setPort: void (SMBCCTX *, uint16_t)
|
||||
+smbc_setServerCacheData: void (SMBCCTX *, struct smbc_server_cache *)
|
||||
+smbc_setTimeout: void (SMBCCTX *, int)
|
||||
+smbc_setUser: void (SMBCCTX *, const char *)
|
||||
+smbc_setWorkgroup: void (SMBCCTX *, const char *)
|
||||
+smbc_set_context: SMBCCTX *(SMBCCTX *)
|
||||
+smbc_set_credentials: void (const char *, const char *, const char *, smbc_bool, const char *)
|
||||
+smbc_set_credentials_with_fallback: void (SMBCCTX *, const char *, const char *, const char *)
|
||||
+smbc_setxattr: int (const char *, const char *, const void *, size_t, int)
|
||||
+smbc_stat: int (const char *, struct stat *)
|
||||
+smbc_statvfs: int (char *, struct statvfs *)
|
||||
+smbc_telldir: off_t (int)
|
||||
+smbc_unlink: int (const char *)
|
||||
+smbc_unlink_print_job: int (const char *, int)
|
||||
+smbc_urldecode: int (char *, char *, size_t)
|
||||
+smbc_urlencode: int (char *, char *, int)
|
||||
+smbc_utime: int (const char *, struct utimbuf *)
|
||||
+smbc_utimes: int (const char *, struct timeval *)
|
||||
+smbc_version: const char *(void)
|
||||
+smbc_write: ssize_t (int, const void *, size_t)
|
||||
diff --git a/source3/libsmb/libsmb_setget.c b/source3/libsmb/libsmb_setget.c
|
||||
index 60b822a395c..b1c4ff3b557 100644
|
||||
--- a/source3/libsmb/libsmb_setget.c
|
||||
+++ b/source3/libsmb/libsmb_setget.c
|
||||
@@ -526,6 +526,24 @@ smbc_setOptionUseNTHash(SMBCCTX *c, smbc_bool b)
|
||||
}
|
||||
}
|
||||
|
||||
+smbc_bool
|
||||
+smbc_setOptionProtocols(SMBCCTX *c,
|
||||
+ const char *min_proto,
|
||||
+ const char *max_proto)
|
||||
+{
|
||||
+ bool ok = true;
|
||||
+
|
||||
+ if (min_proto != NULL) {
|
||||
+ ok = lp_set_cmdline("client min protocol", min_proto);
|
||||
+ }
|
||||
+
|
||||
+ if (max_proto != NULL) {
|
||||
+ ok &= lp_set_cmdline("client min protocol", max_proto);
|
||||
+ }
|
||||
+
|
||||
+ return ok;
|
||||
+}
|
||||
+
|
||||
/** Get the function for obtaining authentication data */
|
||||
smbc_get_auth_data_fn
|
||||
smbc_getFunctionAuthData(SMBCCTX *c)
|
||||
diff --git a/source3/libsmb/wscript b/source3/libsmb/wscript
|
||||
index 5482aea7d9c..298afc3c0e3 100644
|
||||
--- a/source3/libsmb/wscript
|
||||
+++ b/source3/libsmb/wscript
|
||||
@@ -27,5 +27,5 @@ def build(bld):
|
||||
public_headers='../include/libsmbclient.h',
|
||||
abi_directory='ABI',
|
||||
abi_match='smbc_*',
|
||||
- vnum='0.4.0',
|
||||
+ vnum='0.5.0',
|
||||
pc_files='smbclient.pc')
|
||||
--
|
||||
2.19.2
|
||||
|
@ -0,0 +1,252 @@ |
||||
From 14d3e54fa87dc204223eba2c7e18b6e1bf0e4564 Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Thu, 3 Jan 2019 12:07:01 -0500
|
||||
Subject: [PATCH 1/5] s3:libsmb: Check disable_netbios in socket connect
|
||||
|
||||
If the disable_netbios option is set then return NT_STATUS_NOT_SUPPORTED
|
||||
for a port 139 connection in the low level socket connection code.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13727
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Noel Power <nopower@suse.com>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit 78f51a1d3c53248159c1e7643364b62e52457bb9)
|
||||
---
|
||||
source3/libsmb/smbsock_connect.c | 5 +++++
|
||||
1 file changed, 5 insertions(+)
|
||||
|
||||
diff --git a/source3/libsmb/smbsock_connect.c b/source3/libsmb/smbsock_connect.c
|
||||
index 9f915e1bb42..bb3cb07646c 100644
|
||||
--- a/source3/libsmb/smbsock_connect.c
|
||||
+++ b/source3/libsmb/smbsock_connect.c
|
||||
@@ -376,6 +376,11 @@ struct tevent_req *smbsock_connect_send(TALLOC_CTX *mem_ctx,
|
||||
tevent_req_set_cleanup_fn(req, smbsock_connect_cleanup);
|
||||
|
||||
if (port == NBT_SMB_PORT) {
|
||||
+ if (lp_disable_netbios()) {
|
||||
+ tevent_req_nterror(req, NT_STATUS_NOT_SUPPORTED);
|
||||
+ return tevent_req_post(req, ev);
|
||||
+ }
|
||||
+
|
||||
state->req_139 = nb_connect_send(state, state->ev, state->addr,
|
||||
state->called_name,
|
||||
state->called_type,
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From 94491362b882e49757f8ecd8e133149457e2f2e5 Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Mon, 17 Dec 2018 14:40:33 -0500
|
||||
Subject: [PATCH 2/5] s3:libsmb: Print debug message about Netbios
|
||||
|
||||
With a preceding patch, cli_connect_nb() will return
|
||||
NT_STATUS_NOT_SUPPORTED when 'disable netbios' is set in smb.conf.
|
||||
|
||||
Print an informative error message to indicate Netbios is disabled
|
||||
if this occurs.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13727
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Noel Power <nopower@suse.com>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit 499f051c9d527a14f9712365f8403a1ee0662c5b)
|
||||
---
|
||||
source3/libsmb/clidfs.c | 10 +++++++---
|
||||
source3/libsmb/libsmb_server.c | 4 ++++
|
||||
2 files changed, 11 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/source3/libsmb/clidfs.c b/source3/libsmb/clidfs.c
|
||||
index 0dfb8b33606..4342a3b1d1b 100644
|
||||
--- a/source3/libsmb/clidfs.c
|
||||
+++ b/source3/libsmb/clidfs.c
|
||||
@@ -196,9 +196,13 @@ static NTSTATUS do_connect(TALLOC_CTX *ctx,
|
||||
flags, &c);
|
||||
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
- d_printf("Connection to %s failed (Error %s)\n",
|
||||
- server,
|
||||
- nt_errstr(status));
|
||||
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_SUPPORTED)) {
|
||||
+ DBG_ERR("NetBIOS support disabled, unable to connect");
|
||||
+ }
|
||||
+
|
||||
+ DBG_WARNING("Connection to %s failed (Error %s)\n",
|
||||
+ server,
|
||||
+ nt_errstr(status));
|
||||
return status;
|
||||
}
|
||||
|
||||
diff --git a/source3/libsmb/libsmb_server.c b/source3/libsmb/libsmb_server.c
|
||||
index 67dfcf72327..0067df48cac 100644
|
||||
--- a/source3/libsmb/libsmb_server.c
|
||||
+++ b/source3/libsmb/libsmb_server.c
|
||||
@@ -489,6 +489,10 @@ SMBC_server_internal(TALLOC_CTX *ctx,
|
||||
}
|
||||
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_SUPPORTED)) {
|
||||
+ DBG_ERR("NetBIOS support disabled, unable to connect");
|
||||
+ }
|
||||
+
|
||||
errno = map_errno_from_nt_status(status);
|
||||
return NULL;
|
||||
}
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From a0e7b2e45efe680971ded1b66ea919f3fa4a9ad4 Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Mon, 17 Dec 2018 14:57:59 -0500
|
||||
Subject: [PATCH 3/5] s3:smbpasswd: Print debug message about Netbios
|
||||
|
||||
With a preceding patch, cli_connect_nb() will return
|
||||
NT_STATUS_NOT_SUPPORTED when 'disable netbios' is set in smb.conf.
|
||||
|
||||
Print an informative error message to indicate Netbios is disabled
|
||||
if this occurs.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13727
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Noel Power <nopower@suse.com>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit ecbb2f78cec6d9e6f5180c8ba274a1da2152f098)
|
||||
---
|
||||
source3/libsmb/passchange.c | 16 ++++++++++++----
|
||||
1 file changed, 12 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/source3/libsmb/passchange.c b/source3/libsmb/passchange.c
|
||||
index 48ffba8036f..f60e3079975 100644
|
||||
--- a/source3/libsmb/passchange.c
|
||||
+++ b/source3/libsmb/passchange.c
|
||||
@@ -46,10 +46,18 @@ NTSTATUS remote_password_change(const char *remote_machine,
|
||||
result = cli_connect_nb(remote_machine, NULL, 0, 0x20, NULL,
|
||||
SMB_SIGNING_IPC_DEFAULT, 0, &cli);
|
||||
if (!NT_STATUS_IS_OK(result)) {
|
||||
- if (asprintf(err_str, "Unable to connect to SMB server on "
|
||||
- "machine %s. Error was : %s.\n",
|
||||
- remote_machine, nt_errstr(result))==-1) {
|
||||
- *err_str = NULL;
|
||||
+ if (NT_STATUS_EQUAL(result, NT_STATUS_NOT_SUPPORTED)) {
|
||||
+ if (asprintf(err_str, "Unable to connect to SMB server on "
|
||||
+ "machine %s. NetBIOS support disabled\n",
|
||||
+ remote_machine) == -1) {
|
||||
+ *err_str = NULL;
|
||||
+ }
|
||||
+ } else {
|
||||
+ if (asprintf(err_str, "Unable to connect to SMB server on "
|
||||
+ "machine %s. Error was : %s.\n",
|
||||
+ remote_machine, nt_errstr(result))==-1) {
|
||||
+ *err_str = NULL;
|
||||
+ }
|
||||
}
|
||||
return result;
|
||||
}
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From 5f5420b85b0467c0cb3237c82bd4c151bbb0133b Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Mon, 17 Dec 2018 15:17:24 -0500
|
||||
Subject: [PATCH 4/5] s3:utils:net: Print debug message about Netbios
|
||||
|
||||
With a preceding patch, cli_connect_nb() will return
|
||||
NT_STATUS_NOT_SUPPORTED when 'disable netbios' is set in smb.conf.
|
||||
|
||||
Print an informative error message to indicate Netbios is disabled
|
||||
if this occurs.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13727
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Noel Power <nopower@suse.com>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit 08867de2efde05e4730b41a335d13f775e44e397)
|
||||
---
|
||||
source3/utils/net_rpc.c | 3 +++
|
||||
source3/utils/net_time.c | 9 +++++++--
|
||||
2 files changed, 10 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/source3/utils/net_rpc.c b/source3/utils/net_rpc.c
|
||||
index 67fff2f4d1b..91ad90f9594 100644
|
||||
--- a/source3/utils/net_rpc.c
|
||||
+++ b/source3/utils/net_rpc.c
|
||||
@@ -7431,6 +7431,9 @@ bool net_rpc_check(struct net_context *c, unsigned flags)
|
||||
lp_netbios_name(), SMB_SIGNING_IPC_DEFAULT,
|
||||
0, &cli);
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_SUPPORTED)) {
|
||||
+ DBG_ERR("NetBIOS support disabled, unable to connect\n");
|
||||
+ }
|
||||
return false;
|
||||
}
|
||||
status = smbXcli_negprot(cli->conn, cli->timeout, PROTOCOL_CORE,
|
||||
diff --git a/source3/utils/net_time.c b/source3/utils/net_time.c
|
||||
index 0091fc86333..5e6cf2ea15d 100644
|
||||
--- a/source3/utils/net_time.c
|
||||
+++ b/source3/utils/net_time.c
|
||||
@@ -37,8 +37,13 @@ static time_t cli_servertime(const char *host,
|
||||
status = cli_connect_nb(host, dest_ss, 0, 0x20, lp_netbios_name(),
|
||||
SMB_SIGNING_DEFAULT, 0, &cli);
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
- fprintf(stderr, _("Can't contact server %s. Error %s\n"),
|
||||
- host, nt_errstr(status));
|
||||
+ if (NT_STATUS_EQUAL(status, NT_STATUS_NOT_SUPPORTED)) {
|
||||
+ fprintf(stderr, "Can't contact server %s. NetBIOS support disabled,"
|
||||
+ " Error %s\n", host, nt_errstr(status));
|
||||
+ } else {
|
||||
+ fprintf(stderr, "Can't contact server %s. Error %s\n",
|
||||
+ host, nt_errstr(status));
|
||||
+ }
|
||||
goto done;
|
||||
}
|
||||
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From c948bd0660c1ddba0205ccdbd156baefa1c27971 Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Mon, 14 Jan 2019 10:36:47 -0500
|
||||
Subject: [PATCH 5/5] s3:libsmb: Honor disable_netbios option in
|
||||
smbsock_connect_send
|
||||
|
||||
If disable_netbios is set, return before the tevent timer is triggered
|
||||
to prevent outgoing netbios connections.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13727
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit c324f84a2fa25e29d2f7879fbcd35ce0e76a78f8)
|
||||
---
|
||||
source3/libsmb/smbsock_connect.c | 7 +++++++
|
||||
1 file changed, 7 insertions(+)
|
||||
|
||||
diff --git a/source3/libsmb/smbsock_connect.c b/source3/libsmb/smbsock_connect.c
|
||||
index bb3cb07646c..be52b9a4f79 100644
|
||||
--- a/source3/libsmb/smbsock_connect.c
|
||||
+++ b/source3/libsmb/smbsock_connect.c
|
||||
@@ -415,6 +415,13 @@ struct tevent_req *smbsock_connect_send(TALLOC_CTX *mem_ctx,
|
||||
tevent_req_set_callback(state->req_445, smbsock_connect_connected,
|
||||
req);
|
||||
|
||||
+ /*
|
||||
+ * Check for disable_netbios
|
||||
+ */
|
||||
+ if (lp_disable_netbios()) {
|
||||
+ return req;
|
||||
+ }
|
||||
+
|
||||
/*
|
||||
* After 5 msecs, fire the 139 (NBT) request
|
||||
*/
|
||||
--
|
||||
2.20.1
|
||||
|
@ -0,0 +1,37 @@ |
||||
From fac7c0a0357fc0c9fc472a0ee022a8db7571f054 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Fri, 22 Mar 2019 14:39:11 +0100
|
||||
Subject: [PATCH] docs: Update smbclient manpage for --max-protocol
|
||||
|
||||
We default to SMB3 now.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13857
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Alexander Bokovoy <ab@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
(cherry picked from commit 63084375e3c536f22f65e7b7796d114fa8c804c9)
|
||||
---
|
||||
docs-xml/manpages/smbclient.1.xml | 6 +++---
|
||||
1 file changed, 3 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/docs-xml/manpages/smbclient.1.xml b/docs-xml/manpages/smbclient.1.xml
|
||||
index e71a21a95e3..e25f7d3517b 100644
|
||||
--- a/docs-xml/manpages/smbclient.1.xml
|
||||
+++ b/docs-xml/manpages/smbclient.1.xml
|
||||
@@ -261,9 +261,9 @@
|
||||
<listitem><para>This allows the user to select the
|
||||
highest SMB protocol level that smbclient will use to
|
||||
connect to the server. By default this is set to
|
||||
- NT1, which is the highest available SMB1 protocol.
|
||||
- To connect using SMB2 or SMB3 protocol, use the
|
||||
- strings SMB2 or SMB3 respectively. Note that to connect
|
||||
+ highest available SMB3 protocol version.
|
||||
+ To connect using SMB2 or SMB1 protocol, use the
|
||||
+ strings SMB2 or NT1 respectively. Note that to connect
|
||||
to a Windows 2012 server with encrypted transport selecting
|
||||
a max-protocol of SMB3 is required.
|
||||
</para></listitem>
|
||||
--
|
||||
2.21.0
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,40 @@ |
||||
From 99c354431703a4408f0208e3f2b06a9da81937f2 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Wed, 7 Nov 2018 14:32:29 +0100
|
||||
Subject: [PATCH] lib:util: Fix DEBUGCLASS pointer initializiation
|
||||
|
||||
This fixes a segfault in pyglue:
|
||||
|
||||
==10142== Process terminating with default action of signal 11 (SIGSEGV)
|
||||
==10142== Bad permissions for mapped region at address 0x6F00A20
|
||||
==10142== at 0x6F1074B: py_set_debug_level (pyglue.c:165)
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13679
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit 71ef09c1afdbf967b829cb66b33c3a5cb1c18ba0)
|
||||
---
|
||||
lib/util/debug.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/lib/util/debug.c b/lib/util/debug.c
|
||||
index d41e0f99c77..847ec1f0a0c 100644
|
||||
--- a/lib/util/debug.c
|
||||
+++ b/lib/util/debug.c
|
||||
@@ -557,10 +557,10 @@ static const char *default_classname_table[] = {
|
||||
* This is to allow reading of DEBUGLEVEL_CLASS before the debug
|
||||
* system has been initialized.
|
||||
*/
|
||||
-static const int debug_class_list_initial[ARRAY_SIZE(default_classname_table)];
|
||||
+static int debug_class_list_initial[ARRAY_SIZE(default_classname_table)];
|
||||
|
||||
static size_t debug_num_classes = 0;
|
||||
-int *DEBUGLEVEL_CLASS = discard_const_p(int, debug_class_list_initial);
|
||||
+int *DEBUGLEVEL_CLASS = debug_class_list_initial;
|
||||
|
||||
|
||||
/* -------------------------------------------------------------------------- **
|
||||
--
|
||||
2.19.1
|
||||
|
@ -0,0 +1,87 @@ |
||||
From fdc98f74d016bcfd9673f4bc011ba7ede59bdf48 Mon Sep 17 00:00:00 2001
|
||||
From: Jeremy Allison <jra@samba.org>
|
||||
Date: Fri, 18 Jan 2019 14:24:30 -0800
|
||||
Subject: [PATCH 2/2] smbd: uid: Don't crash if 'force group' is added to an
|
||||
existing share connection.
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
smbd could crash if "force group" is added to a
|
||||
share definition whilst an existing connection
|
||||
to that share exists. In that case, don't change
|
||||
the existing credentials for force group, only
|
||||
do so for new connections.
|
||||
|
||||
Remove knownfail from regression test.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13690
|
||||
|
||||
Signed-off-by: Jeremy Allison <jra@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
|
||||
Autobuild-User(master): Ralph Böhme <slow@samba.org>
|
||||
Autobuild-Date(master): Fri Jan 25 16:31:27 CET 2019 on sn-devel-144
|
||||
|
||||
(cherry picked from commit e37f9956c1f2416408bad048a4618f6366086b6a)
|
||||
---
|
||||
source3/smbd/uid.c | 35 +++++++++++++++++++++++++++++++++--
|
||||
2 files changed, 33 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/source3/smbd/uid.c b/source3/smbd/uid.c
|
||||
index 9d5321cf4cc..ced2d450f8e 100644
|
||||
--- a/source3/smbd/uid.c
|
||||
+++ b/source3/smbd/uid.c
|
||||
@@ -296,6 +296,7 @@ static bool change_to_user_internal(connection_struct *conn,
|
||||
int snum;
|
||||
gid_t gid;
|
||||
uid_t uid;
|
||||
+ const char *force_group_name;
|
||||
char group_c;
|
||||
int num_groups = 0;
|
||||
gid_t *group_list = NULL;
|
||||
@@ -335,9 +336,39 @@ static bool change_to_user_internal(connection_struct *conn,
|
||||
* See if we should force group for this service. If so this overrides
|
||||
* any group set in the force user code.
|
||||
*/
|
||||
- if((group_c = *lp_force_group(talloc_tos(), snum))) {
|
||||
+ force_group_name = lp_force_group(talloc_tos(), snum);
|
||||
+ group_c = *force_group_name;
|
||||
|
||||
- SMB_ASSERT(conn->force_group_gid != (gid_t)-1);
|
||||
+ if ((group_c != '\0') && (conn->force_group_gid == (gid_t)-1)) {
|
||||
+ /*
|
||||
+ * This can happen if "force group" is added to a
|
||||
+ * share definition whilst an existing connection
|
||||
+ * to that share exists. In that case, don't change
|
||||
+ * the existing credentials for force group, only
|
||||
+ * do so for new connections.
|
||||
+ *
|
||||
+ * BUG: https://bugzilla.samba.org/show_bug.cgi?id=13690
|
||||
+ */
|
||||
+ DBG_INFO("Not forcing group %s on existing connection to "
|
||||
+ "share %s for SMB user %s (unix user %s)\n",
|
||||
+ force_group_name,
|
||||
+ lp_const_servicename(snum),
|
||||
+ session_info->unix_info->sanitized_username,
|
||||
+ session_info->unix_info->unix_name);
|
||||
+ }
|
||||
+
|
||||
+ if((group_c != '\0') && (conn->force_group_gid != (gid_t)-1)) {
|
||||
+ /*
|
||||
+ * Only force group for connections where
|
||||
+ * conn->force_group_gid has already been set
|
||||
+ * to the correct value (i.e. the connection
|
||||
+ * happened after the 'force group' definition
|
||||
+ * was added to the share definition. Connections
|
||||
+ * that were made before force group was added
|
||||
+ * should stay with their existing credentials.
|
||||
+ *
|
||||
+ * BUG: https://bugzilla.samba.org/show_bug.cgi?id=13690
|
||||
+ */
|
||||
|
||||
if (group_c == '+') {
|
||||
int i;
|
||||
--
|
||||
2.20.1.495.gaa96b0ce6b-goog
|
||||
|
@ -0,0 +1,544 @@ |
||||
From 996850e7c3bae8fa2f3fcb3f2e3a811c1e6c162f Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Fri, 29 Mar 2019 11:34:53 +0100
|
||||
Subject: [PATCH 01/11] s3:libads: Print more information when LDAP fails
|
||||
|
||||
Currently we just get an error but don't know what exactly we tried to
|
||||
do in 'net ads join -d10'.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 40669e3739eb5cde135c371e2c8134d3f11a16a5)
|
||||
---
|
||||
source3/libads/ldap.c | 12 ++++++++++--
|
||||
1 file changed, 10 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/source3/libads/ldap.c b/source3/libads/ldap.c
|
||||
index 13846695bd4..110f74a2dbb 100644
|
||||
--- a/source3/libads/ldap.c
|
||||
+++ b/source3/libads/ldap.c
|
||||
@@ -1521,8 +1521,10 @@ static void ads_print_error(int ret, LDAP *ld)
|
||||
if (ret != 0) {
|
||||
char *ld_error = NULL;
|
||||
ldap_get_option(ld, LDAP_OPT_ERROR_STRING, &ld_error);
|
||||
- DEBUG(10,("AD LDAP failure %d (%s):\n%s\n", ret,
|
||||
- ldap_err2string(ret), ld_error));
|
||||
+ DBG_ERR("AD LDAP ERROR: %d (%s): %s\n",
|
||||
+ ret,
|
||||
+ ldap_err2string(ret),
|
||||
+ ld_error);
|
||||
SAFE_FREE(ld_error);
|
||||
}
|
||||
}
|
||||
@@ -1549,6 +1551,8 @@ ADS_STATUS ads_gen_mod(ADS_STRUCT *ads, const char *mod_dn, ADS_MODLIST mods)
|
||||
(char) 1};
|
||||
LDAPControl *controls[2];
|
||||
|
||||
+ DBG_INFO("AD LDAP: Modifying %s\n", mod_dn);
|
||||
+
|
||||
controls[0] = &PermitModify;
|
||||
controls[1] = NULL;
|
||||
|
||||
@@ -1580,6 +1584,8 @@ ADS_STATUS ads_gen_add(ADS_STRUCT *ads, const char *new_dn, ADS_MODLIST mods)
|
||||
char *utf8_dn = NULL;
|
||||
size_t converted_size;
|
||||
|
||||
+ DBG_INFO("AD LDAP: Adding %s\n", new_dn);
|
||||
+
|
||||
if (!push_utf8_talloc(talloc_tos(), &utf8_dn, new_dn, &converted_size)) {
|
||||
DEBUG(1, ("ads_gen_add: push_utf8_talloc failed!"));
|
||||
return ADS_ERROR_NT(NT_STATUS_NO_MEMORY);
|
||||
@@ -1612,6 +1618,8 @@ ADS_STATUS ads_del_dn(ADS_STRUCT *ads, char *del_dn)
|
||||
return ADS_ERROR_NT(NT_STATUS_NO_MEMORY);
|
||||
}
|
||||
|
||||
+ DBG_INFO("AD LDAP: Deleting %s\n", del_dn);
|
||||
+
|
||||
ret = ldap_delete_s(ads->ldap.ld, utf8_dn);
|
||||
ads_print_error(ret, ads->ldap.ld);
|
||||
TALLOC_FREE(utf8_dn);
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From 5fe5419bd6617fb33c7aafce20e1eeb3edd2f35f Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Wed, 27 Mar 2019 16:45:39 +0100
|
||||
Subject: [PATCH 02/11] s3:libsmb: Add some useful debug output to cliconnect
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 011a47f04dabe22095a30d284662d8ca50463ee8)
|
||||
---
|
||||
source3/libsmb/cliconnect.c | 13 +++++++++++++
|
||||
1 file changed, 13 insertions(+)
|
||||
|
||||
diff --git a/source3/libsmb/cliconnect.c b/source3/libsmb/cliconnect.c
|
||||
index 837299d9220..9a3d3c769f9 100644
|
||||
--- a/source3/libsmb/cliconnect.c
|
||||
+++ b/source3/libsmb/cliconnect.c
|
||||
@@ -345,6 +345,8 @@ NTSTATUS cli_session_creds_prepare_krb5(struct cli_state *cli,
|
||||
return NT_STATUS_OK;
|
||||
}
|
||||
|
||||
+ DBG_INFO("Doing kinit for %s to access %s\n",
|
||||
+ user_principal, target_hostname);
|
||||
|
||||
/*
|
||||
* TODO: This should be done within the gensec layer
|
||||
@@ -374,6 +376,11 @@ NTSTATUS cli_session_creds_prepare_krb5(struct cli_state *cli,
|
||||
*/
|
||||
}
|
||||
|
||||
+ DBG_DEBUG("Successfully authenticated as %s to access %s using "
|
||||
+ "Kerberos\n",
|
||||
+ user_principal,
|
||||
+ target_hostname);
|
||||
+
|
||||
TALLOC_FREE(frame);
|
||||
return NT_STATUS_OK;
|
||||
}
|
||||
@@ -1293,6 +1300,10 @@ static struct tevent_req *cli_session_setup_spnego_send(
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
||||
+ DBG_INFO("Connect to %s as %s using SPNEGO\n",
|
||||
+ target_hostname,
|
||||
+ cli_credentials_get_principal(creds, talloc_tos()));
|
||||
+
|
||||
subreq = cli_session_setup_gensec_send(state, ev, cli, creds,
|
||||
target_service, target_hostname);
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
@@ -1496,6 +1507,8 @@ struct tevent_req *cli_session_setup_creds_send(TALLOC_CTX *mem_ctx,
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
||||
+ DBG_INFO("Connect to %s as %s using NTLM\n", domain, username);
|
||||
+
|
||||
if ((sec_mode & NEGOTIATE_SECURITY_CHALLENGE_RESPONSE) == 0) {
|
||||
bool use_unicode = smbXcli_conn_use_unicode(cli->conn);
|
||||
uint8_t *bytes = NULL;
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From 0ad85d0c8d5f1c0a8a2fc9bed2e685e3421195bc Mon Sep 17 00:00:00 2001
|
||||
From: Guenther Deschner <gd@samba.org>
|
||||
Date: Mon, 1 Apr 2019 17:46:39 +0200
|
||||
Subject: [PATCH 03/11] s3:libnet: Fix debug message in libnet_DomainJoin()
|
||||
|
||||
A newline is missing but also use DBG_INFO macro and cleanup spelling.
|
||||
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 3a33c360071bb7cada58f1f71ccd8949fda70662)
|
||||
---
|
||||
source3/libnet/libnet_join.c | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/source3/libnet/libnet_join.c b/source3/libnet/libnet_join.c
|
||||
index 27fc5135442..ddc00f7ad7c 100644
|
||||
--- a/source3/libnet/libnet_join.c
|
||||
+++ b/source3/libnet/libnet_join.c
|
||||
@@ -2664,8 +2664,8 @@ static WERROR libnet_DomainJoin(TALLOC_CTX *mem_ctx,
|
||||
return WERR_NERR_DEFAULTJOINREQUIRED;
|
||||
}
|
||||
|
||||
- DEBUG(5, ("failed to precreate account in ou %s: %s",
|
||||
- r->in.account_ou, ads_errstr(ads_status)));
|
||||
+ DBG_INFO("Failed to pre-create account in OU %s: %s\n",
|
||||
+ r->in.account_ou, ads_errstr(ads_status));
|
||||
}
|
||||
rpc_join:
|
||||
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From d6802828cc9a0dbdd667966faea7cc331479179b Mon Sep 17 00:00:00 2001
|
||||
From: Guenther Deschner <gd@samba.org>
|
||||
Date: Wed, 27 Mar 2019 17:51:04 +0100
|
||||
Subject: [PATCH 04/11] auth:ntlmssp: Add back CRAP ndr debug output
|
||||
|
||||
This got lost somehow during refactoring. This is still viable
|
||||
information when trying to figure out what is going wrong when
|
||||
authenticating a user over NTLMSSP.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 9e92654899db3c951bee0203415a15737402e7b7)
|
||||
---
|
||||
auth/ntlmssp/ntlmssp_client.c | 32 ++++++++++++++++++++++++++++++++
|
||||
1 file changed, 32 insertions(+)
|
||||
|
||||
diff --git a/auth/ntlmssp/ntlmssp_client.c b/auth/ntlmssp/ntlmssp_client.c
|
||||
index ab406a2c5be..8e49dcee5ea 100644
|
||||
--- a/auth/ntlmssp/ntlmssp_client.c
|
||||
+++ b/auth/ntlmssp/ntlmssp_client.c
|
||||
@@ -342,6 +342,22 @@ NTSTATUS ntlmssp_client_challenge(struct gensec_security *gensec_security,
|
||||
}
|
||||
}
|
||||
|
||||
+ if (DEBUGLEVEL >= 10) {
|
||||
+ struct CHALLENGE_MESSAGE *challenge =
|
||||
+ talloc(ntlmssp_state, struct CHALLENGE_MESSAGE);
|
||||
+ if (challenge != NULL) {
|
||||
+ NTSTATUS status;
|
||||
+ challenge->NegotiateFlags = chal_flags;
|
||||
+ status = ntlmssp_pull_CHALLENGE_MESSAGE(
|
||||
+ &in, challenge, challenge);
|
||||
+ if (NT_STATUS_IS_OK(status)) {
|
||||
+ NDR_PRINT_DEBUG(CHALLENGE_MESSAGE,
|
||||
+ challenge);
|
||||
+ }
|
||||
+ TALLOC_FREE(challenge);
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
if (chal_flags & NTLMSSP_TARGET_TYPE_SERVER) {
|
||||
ntlmssp_state->server.is_standalone = true;
|
||||
} else {
|
||||
@@ -702,6 +718,22 @@ NTSTATUS ntlmssp_client_challenge(struct gensec_security *gensec_security,
|
||||
return nt_status;
|
||||
}
|
||||
|
||||
+ if (DEBUGLEVEL >= 10) {
|
||||
+ struct AUTHENTICATE_MESSAGE *authenticate =
|
||||
+ talloc(ntlmssp_state, struct AUTHENTICATE_MESSAGE);
|
||||
+ if (authenticate != NULL) {
|
||||
+ NTSTATUS status;
|
||||
+ authenticate->NegotiateFlags = ntlmssp_state->neg_flags;
|
||||
+ status = ntlmssp_pull_AUTHENTICATE_MESSAGE(
|
||||
+ out, authenticate, authenticate);
|
||||
+ if (NT_STATUS_IS_OK(status)) {
|
||||
+ NDR_PRINT_DEBUG(AUTHENTICATE_MESSAGE,
|
||||
+ authenticate);
|
||||
+ }
|
||||
+ TALLOC_FREE(authenticate);
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
/*
|
||||
* We always include the MIC, even without:
|
||||
* av_flags->Value.AvFlags |= NTLMSSP_AVFLAG_MIC_IN_AUTHENTICATE_MESSAGE;
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From 9a4a76ad58a96903129d1aef0c5ac05a9beeda4b Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 1 Apr 2019 15:59:10 +0200
|
||||
Subject: [PATCH 05/11] auth:creds: Prefer the principal over DOMAIN/username
|
||||
when using NTLM
|
||||
|
||||
If we want to authenticate using -Wadmin@otherdomain the DC should do
|
||||
take care of the authentication with the right DC for us.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Pair-Programmed-With: Guenther Deschner <gd@samba.org>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 5c7f0a6902cfdd698e5f4159d37537bb4c9c1cc3)
|
||||
---
|
||||
auth/credentials/credentials.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/auth/credentials/credentials.c b/auth/credentials/credentials.c
|
||||
index 4663185c979..7ef58d0752c 100644
|
||||
--- a/auth/credentials/credentials.c
|
||||
+++ b/auth/credentials/credentials.c
|
||||
@@ -1115,7 +1115,7 @@ _PUBLIC_ void cli_credentials_get_ntlm_username_domain(struct cli_credentials *c
|
||||
const char **username,
|
||||
const char **domain)
|
||||
{
|
||||
- if (cred->principal_obtained > cred->username_obtained) {
|
||||
+ if (cred->principal_obtained >= cred->username_obtained) {
|
||||
*domain = talloc_strdup(mem_ctx, "");
|
||||
*username = cli_credentials_get_principal(cred, mem_ctx);
|
||||
} else {
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From 40267b96b2d596bf92139bbc794337fa828e63d5 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 1 Apr 2019 16:39:45 +0200
|
||||
Subject: [PATCH 06/11] s3:libnet: Use more secure name for the JOIN krb5.conf
|
||||
|
||||
Currently we create krb5.conf..JOIN, use krb5.conf._JOIN_ instead.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit b7f0c64514a28cfb5d2cdee683c18943b97ea753)
|
||||
---
|
||||
source3/libnet/libnet_join.c | 8 +++++---
|
||||
1 file changed, 5 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/source3/libnet/libnet_join.c b/source3/libnet/libnet_join.c
|
||||
index ddc00f7ad7c..e052306523d 100644
|
||||
--- a/source3/libnet/libnet_join.c
|
||||
+++ b/source3/libnet/libnet_join.c
|
||||
@@ -2598,12 +2598,14 @@ static WERROR libnet_DomainJoin(TALLOC_CTX *mem_ctx,
|
||||
}
|
||||
|
||||
/* The domain parameter is only used as modifier
|
||||
- * to krb5.conf file name. .JOIN is is not a valid
|
||||
+ * to krb5.conf file name. _JOIN_ is is not a valid
|
||||
* NetBIOS name so it cannot clash with another domain
|
||||
* -- Uri.
|
||||
*/
|
||||
- create_local_private_krb5_conf_for_domain(
|
||||
- pre_connect_realm, ".JOIN", sitename, &ss);
|
||||
+ create_local_private_krb5_conf_for_domain(pre_connect_realm,
|
||||
+ "_JOIN_",
|
||||
+ sitename,
|
||||
+ &ss);
|
||||
}
|
||||
|
||||
status = libnet_join_lookup_dc_rpc(mem_ctx, r, &cli);
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From cdc7199588e89eec42f30d0ea00f406911739763 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 1 Apr 2019 16:47:26 +0200
|
||||
Subject: [PATCH 07/11] s3:libads: Make sure we can lookup KDCs which are not
|
||||
configured
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Pair-Programmed-With: Guenther Deschner <gd@samba.org>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit c016afc832543514ebf7ecda1fbe6b272ea533d6)
|
||||
---
|
||||
source3/libads/kerberos.c | 12 ++++++++++--
|
||||
1 file changed, 10 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/source3/libads/kerberos.c b/source3/libads/kerberos.c
|
||||
index e623f2456a8..360cdd741da 100644
|
||||
--- a/source3/libads/kerberos.c
|
||||
+++ b/source3/libads/kerberos.c
|
||||
@@ -673,11 +673,19 @@ bool create_local_private_krb5_conf_for_domain(const char *realm,
|
||||
}
|
||||
#endif
|
||||
|
||||
+ /*
|
||||
+ * We are setting 'dns_lookup_kdc' to true, because we want to lookup
|
||||
+ * KDCs which are not configured via DNS SRV records, eg. if we do:
|
||||
+ *
|
||||
+ * net ads join -Uadmin@otherdomain
|
||||
+ */
|
||||
file_contents =
|
||||
talloc_asprintf(fname,
|
||||
- "[libdefaults]\n\tdefault_realm = %s\n"
|
||||
+ "[libdefaults]\n"
|
||||
+ "\tdefault_realm = %s\n"
|
||||
"%s"
|
||||
- "\tdns_lookup_realm = false\n\n"
|
||||
+ "\tdns_lookup_realm = false\n"
|
||||
+ "\tdns_lookup_kdc = true\n\n"
|
||||
"[realms]\n\t%s = {\n"
|
||||
"%s\t}\n"
|
||||
"%s\n",
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From 85d85aa3f79ab0a4c3f3f3aad94d7ed545992a45 Mon Sep 17 00:00:00 2001
|
||||
From: Guenther Deschner <gd@samba.org>
|
||||
Date: Mon, 1 Apr 2019 17:40:03 +0200
|
||||
Subject: [PATCH 08/11] s3:ldap: Leave add machine code early for pre-existing
|
||||
accounts
|
||||
|
||||
This avoids numerous LDAP constraint violation errors when we try to
|
||||
re-precreate an already existing machine account.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Pair-Programmed-With: Andreas Schneider <asn@samba.org>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Boehme <slow@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 2044ca0e20bd3180720a82506b3af041d14b5c68)
|
||||
---
|
||||
source3/libads/ldap.c | 10 +++++++++-
|
||||
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/source3/libads/ldap.c b/source3/libads/ldap.c
|
||||
index 110f74a2dbb..e191ea792a8 100644
|
||||
--- a/source3/libads/ldap.c
|
||||
+++ b/source3/libads/ldap.c
|
||||
@@ -2120,6 +2120,15 @@ ADS_STATUS ads_create_machine_acct(ADS_STRUCT *ads,
|
||||
goto done;
|
||||
}
|
||||
|
||||
+ ret = ads_find_machine_acct(ads, &res, machine_escaped);
|
||||
+ ads_msgfree(ads, res);
|
||||
+ if (ADS_ERR_OK(ret)) {
|
||||
+ DBG_DEBUG("Host account for %s already exists.\n",
|
||||
+ machine_escaped);
|
||||
+ ret = ADS_ERROR_LDAP(LDAP_ALREADY_EXISTS);
|
||||
+ goto done;
|
||||
+ }
|
||||
+
|
||||
new_dn = talloc_asprintf(ctx, "cn=%s,%s", machine_escaped, org_unit);
|
||||
samAccountName = talloc_asprintf(ctx, "%s$", machine_name);
|
||||
|
||||
@@ -2155,7 +2164,6 @@ ADS_STATUS ads_create_machine_acct(ADS_STRUCT *ads,
|
||||
|
||||
done:
|
||||
SAFE_FREE(machine_escaped);
|
||||
- ads_msgfree(ads, res);
|
||||
talloc_destroy(ctx);
|
||||
|
||||
return ret;
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From ff8c3e197107621f9398515120a33239940a507b Mon Sep 17 00:00:00 2001
|
||||
From: =?UTF-8?q?G=C3=BCnther=20Deschner?= <gd@samba.org>
|
||||
Date: Tue, 2 Apr 2019 13:14:06 +0200
|
||||
Subject: [PATCH 09/11] s3-libnet_join: always pass down admin domain to ads
|
||||
layer
|
||||
|
||||
Otherwise we could loose the information that a non-default domain name
|
||||
has been used for admin creds.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Guenther
|
||||
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Reviewed-by: Andreas Schneider <asn@samba.org>
|
||||
(cherry picked from commit ea29aa27cbac4253ee1701fed99a3e0811f7475d)
|
||||
---
|
||||
source3/libnet/libnet_join.c | 12 ++++++++++++
|
||||
1 file changed, 12 insertions(+)
|
||||
|
||||
diff --git a/source3/libnet/libnet_join.c b/source3/libnet/libnet_join.c
|
||||
index e052306523d..fc7429e6a23 100644
|
||||
--- a/source3/libnet/libnet_join.c
|
||||
+++ b/source3/libnet/libnet_join.c
|
||||
@@ -205,7 +205,19 @@ static ADS_STATUS libnet_join_connect_ads(TALLOC_CTX *mem_ctx,
|
||||
password = r->in.machine_password;
|
||||
ccname = "MEMORY:libnet_join_machine_creds";
|
||||
} else {
|
||||
+ char *p = NULL;
|
||||
+
|
||||
username = r->in.admin_account;
|
||||
+
|
||||
+ p = strchr(r->in.admin_account, '@');
|
||||
+ if (p == NULL) {
|
||||
+ username = talloc_asprintf(mem_ctx, "%s@%s",
|
||||
+ r->in.admin_account,
|
||||
+ r->in.admin_domain);
|
||||
+ }
|
||||
+ if (username == NULL) {
|
||||
+ return ADS_ERROR(LDAP_NO_MEMORY);
|
||||
+ }
|
||||
password = r->in.admin_password;
|
||||
|
||||
/*
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From a3939fb583bb21abb34ec4179ffeb65e9a621279 Mon Sep 17 00:00:00 2001
|
||||
From: =?UTF-8?q?G=C3=BCnther=20Deschner?= <gd@samba.org>
|
||||
Date: Tue, 2 Apr 2019 13:16:11 +0200
|
||||
Subject: [PATCH 10/11] s3-libnet_join: setup libnet join error string when AD
|
||||
connect fails
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Guenther
|
||||
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Reviewed-by: Andreas Schneider <asn@samba.org>
|
||||
(cherry picked from commit 68121f46c74df9cef7a377040d01ba75cdcf5a26)
|
||||
---
|
||||
source3/libnet/libnet_join.c | 3 +++
|
||||
1 file changed, 3 insertions(+)
|
||||
|
||||
diff --git a/source3/libnet/libnet_join.c b/source3/libnet/libnet_join.c
|
||||
index fc7429e6a23..6d3fc1fe01f 100644
|
||||
--- a/source3/libnet/libnet_join.c
|
||||
+++ b/source3/libnet/libnet_join.c
|
||||
@@ -2655,6 +2655,9 @@ static WERROR libnet_DomainJoin(TALLOC_CTX *mem_ctx,
|
||||
|
||||
ads_status = libnet_join_connect_ads_user(mem_ctx, r);
|
||||
if (!ADS_ERR_OK(ads_status)) {
|
||||
+ libnet_join_set_error_string(mem_ctx, r,
|
||||
+ "failed to connect to AD: %s",
|
||||
+ ads_errstr(ads_status));
|
||||
return WERR_NERR_DEFAULTJOINREQUIRED;
|
||||
}
|
||||
|
||||
--
|
||||
2.21.0
|
||||
|
||||
|
||||
From d91788b9f257a3e87d9ad460bc4a3e8b8f1d49c3 Mon Sep 17 00:00:00 2001
|
||||
From: =?UTF-8?q?G=C3=BCnther=20Deschner?= <gd@samba.org>
|
||||
Date: Tue, 2 Apr 2019 13:16:55 +0200
|
||||
Subject: [PATCH 11/11] s3-libnet_join: allow fallback to NTLMSSP auth in
|
||||
libnet_join
|
||||
|
||||
When a non-DNS and non-default admin domain is provided during the join
|
||||
sometimes we might not be able to kinit with 'user@SHORTDOMAINNAME'
|
||||
(e.g. when the winbind krb5 locator is not installed). In that case lets
|
||||
fallback to NTLMSSP, like we do in winbind.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13861
|
||||
|
||||
Guenther
|
||||
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
Reviewed-by: Andreas Schneider <asn@samba.org>
|
||||
|
||||
Autobuild-User(master): Andreas Schneider <asn@cryptomilk.org>
|
||||
Autobuild-Date(master): Wed Apr 3 18:57:31 UTC 2019 on sn-devel-144
|
||||
|
||||
(cherry picked from commit 377d27359ccdb8f2680fda36ca388f44456590e5)
|
||||
---
|
||||
source3/libnet/libnet_join.c | 2 ++
|
||||
1 file changed, 2 insertions(+)
|
||||
|
||||
diff --git a/source3/libnet/libnet_join.c b/source3/libnet/libnet_join.c
|
||||
index 6d3fc1fe01f..b876d7ea89f 100644
|
||||
--- a/source3/libnet/libnet_join.c
|
||||
+++ b/source3/libnet/libnet_join.c
|
||||
@@ -145,6 +145,8 @@ static ADS_STATUS libnet_connect_ads(const char *dns_domain_name,
|
||||
return ADS_ERROR_LDAP(LDAP_NO_MEMORY);
|
||||
}
|
||||
|
||||
+ my_ads->auth.flags |= ADS_AUTH_ALLOW_NTLMSSP;
|
||||
+
|
||||
if (user_name) {
|
||||
SAFE_FREE(my_ads->auth.user_name);
|
||||
my_ads->auth.user_name = SMB_STRDUP(user_name);
|
||||
--
|
||||
2.21.0
|
||||
|
@ -0,0 +1,56 @@ |
||||
From 01b912069337c8dd2eab6be006813dc7fbc2f882 Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Mon, 17 Dec 2018 11:26:11 -0500
|
||||
Subject: [PATCH] s3: net: Do not set NET_FLAGS_ANONYMOUS with -k
|
||||
|
||||
This affects net rpc getsid and net rpc changetrustpw commands.
|
||||
This avoids an anonymous IPC connection being made when -k is used,
|
||||
this only affects net rpc getsid and net rpc changetrustpw commands.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13726
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Noel Power <npower@samba.org>
|
||||
---
|
||||
source3/utils/net_rpc.c | 10 ++++++++--
|
||||
1 file changed, 8 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/source3/utils/net_rpc.c b/source3/utils/net_rpc.c
|
||||
index b99a036fca1..67fff2f4d1b 100644
|
||||
--- a/source3/utils/net_rpc.c
|
||||
+++ b/source3/utils/net_rpc.c
|
||||
@@ -316,6 +316,12 @@ static NTSTATUS rpc_changetrustpw_internals(struct net_context *c,
|
||||
|
||||
int net_rpc_changetrustpw(struct net_context *c, int argc, const char **argv)
|
||||
{
|
||||
+ int conn_flags = NET_FLAGS_PDC;
|
||||
+
|
||||
+ if (!c->opt_user_specified && !c->opt_kerberos) {
|
||||
+ conn_flags |= NET_FLAGS_ANONYMOUS;
|
||||
+ }
|
||||
+
|
||||
if (c->display_usage) {
|
||||
d_printf( "%s\n"
|
||||
"net rpc changetrustpw\n"
|
||||
@@ -326,7 +332,7 @@ int net_rpc_changetrustpw(struct net_context *c, int argc, const char **argv)
|
||||
}
|
||||
|
||||
return run_rpc_command(c, NULL, &ndr_table_netlogon,
|
||||
- NET_FLAGS_ANONYMOUS | NET_FLAGS_PDC,
|
||||
+ conn_flags,
|
||||
rpc_changetrustpw_internals,
|
||||
argc, argv);
|
||||
}
|
||||
@@ -863,7 +869,7 @@ int net_rpc_getsid(struct net_context *c, int argc, const char **argv)
|
||||
{
|
||||
int conn_flags = NET_FLAGS_PDC;
|
||||
|
||||
- if (!c->opt_user_specified) {
|
||||
+ if (!c->opt_user_specified && !c->opt_kerberos) {
|
||||
conn_flags |= NET_FLAGS_ANONYMOUS;
|
||||
}
|
||||
|
||||
--
|
||||
2.20.1
|
||||
|
@ -0,0 +1,521 @@ |
||||
From 7c0a36d527800cd9d148c64b24371c76ac73db63 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Tue, 12 Mar 2019 10:15:05 +0100
|
||||
Subject: [PATCH 1/5] s3:script: Fix jobid check in test_smbspool.sh
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13832
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Bryan Mason <bmason@redhat.com>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
(cherry picked from commit fad5e4eaeb9202c1b63c42ea09254c17c473e33a)
|
||||
---
|
||||
source3/script/tests/test_smbspool.sh | 4 ++--
|
||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/source3/script/tests/test_smbspool.sh b/source3/script/tests/test_smbspool.sh
|
||||
index d95ed064634..f28c0909334 100755
|
||||
--- a/source3/script/tests/test_smbspool.sh
|
||||
+++ b/source3/script/tests/test_smbspool.sh
|
||||
@@ -99,8 +99,8 @@ test_vlp_verify()
|
||||
fi
|
||||
|
||||
jobid=$(echo "$out" | awk '/[0-9]+/ { print $1 };')
|
||||
- if [ $jobid -lt 1000 || $jobid -gt 2000 ]; then
|
||||
- echo "failed to get jobid"
|
||||
+ if [ -z "$jobid" ] || [ $jobid -lt 100 || [ $jobid -gt 2000 ]; then
|
||||
+ echo "Invalid jobid: $jobid"
|
||||
echo "$out"
|
||||
return 1
|
||||
fi
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From 3cce23b5b863abf2c2352f5a066dc005d9728b18 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Tue, 12 Mar 2019 09:40:58 +0100
|
||||
Subject: [PATCH 2/5] s3:client: Pass DEVICE_URI and AUTH_INFO_REQUIRED env to
|
||||
smbspool
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13832
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Bryan Mason <bmason@redhat.com>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
(cherry picked from commit 43160184d254a57f87bb2adeba47f48d8539533a)
|
||||
---
|
||||
source3/client/smbspool_krb5_wrapper.c | 24 +++++++++++++++++++++---
|
||||
1 file changed, 21 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/source3/client/smbspool_krb5_wrapper.c b/source3/client/smbspool_krb5_wrapper.c
|
||||
index dee3b4c54be..5c4da33238b 100644
|
||||
--- a/source3/client/smbspool_krb5_wrapper.c
|
||||
+++ b/source3/client/smbspool_krb5_wrapper.c
|
||||
@@ -84,24 +84,36 @@ int main(int argc, char *argv[])
|
||||
struct passwd *pwd;
|
||||
char gen_cc[PATH_MAX] = {0};
|
||||
struct stat sb;
|
||||
- char *env;
|
||||
+ char *env = NULL;
|
||||
+ char auth_info_required[256] = {0};
|
||||
+ char device_uri[4096] = {0};
|
||||
uid_t uid = (uid_t)-1;
|
||||
gid_t gid = (gid_t)-1;
|
||||
unsigned long tmp;
|
||||
int cmp;
|
||||
int rc;
|
||||
|
||||
+ env = getenv("DEVICE_URI");
|
||||
+ if (env != NULL && strlen(env) > 2) {
|
||||
+ snprintf(device_uri, sizeof(device_uri), "%s", env);
|
||||
+ }
|
||||
+
|
||||
/* Check if AuthInfoRequired is set to negotiate */
|
||||
env = getenv("AUTH_INFO_REQUIRED");
|
||||
|
||||
/* If not set, then just call smbspool. */
|
||||
- if (env == NULL) {
|
||||
+ if (env == NULL || env[0] == 0) {
|
||||
CUPS_SMB_DEBUG("AUTH_INFO_REQUIRED is not set - "
|
||||
"execute smbspool");
|
||||
goto smbspool;
|
||||
} else {
|
||||
CUPS_SMB_DEBUG("AUTH_INFO_REQUIRED=%s", env);
|
||||
|
||||
+ snprintf(auth_info_required,
|
||||
+ sizeof(auth_info_required),
|
||||
+ "%s",
|
||||
+ env);
|
||||
+
|
||||
cmp = strcmp(env, "username,password");
|
||||
if (cmp == 0) {
|
||||
CUPS_SMB_DEBUG("Authenticate using username/password - "
|
||||
@@ -223,12 +235,18 @@ create_env:
|
||||
#else
|
||||
{
|
||||
extern char **environ;
|
||||
- environ = calloc(1, sizeof(*environ));
|
||||
+ environ = calloc(3, sizeof(*environ));
|
||||
}
|
||||
#endif
|
||||
|
||||
CUPS_SMB_DEBUG("Setting KRB5CCNAME to '%s'", gen_cc);
|
||||
setenv("KRB5CCNAME", gen_cc, 1);
|
||||
+ if (device_uri[0] != '\0') {
|
||||
+ setenv("DEVICE_URI", device_uri, 1);
|
||||
+ }
|
||||
+ if (auth_info_required[0] != '\0') {
|
||||
+ setenv("AUTH_INFO_REQUIRED", auth_info_required, 1);
|
||||
+ }
|
||||
|
||||
smbspool:
|
||||
snprintf(smbspool_cmd,
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From 0c03a0baf57ef4503e98b9e2ddd5695e6c8dd3fd Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Fri, 4 Jan 2019 09:21:24 +0100
|
||||
Subject: [PATCH 3/5] s3:client: Evaluate the AUTH_INFO_REQUIRED variable set
|
||||
by cups
|
||||
|
||||
This should not switch to username,password if cups has been configured
|
||||
to use negotiate (Kerberos authentication).
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13832
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Bryan Mason <bmason@redhat.com>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
(cherry picked from commit 5274b09fbaa5e45cc58f3301818d4e9f6a402845)
|
||||
---
|
||||
source3/client/smbspool.c | 32 ++++++++++++++++++++------------
|
||||
1 file changed, 20 insertions(+), 12 deletions(-)
|
||||
|
||||
diff --git a/source3/client/smbspool.c b/source3/client/smbspool.c
|
||||
index 389e4ea553f..3dbf6be014b 100644
|
||||
--- a/source3/client/smbspool.c
|
||||
+++ b/source3/client/smbspool.c
|
||||
@@ -60,7 +60,7 @@
|
||||
* Local functions...
|
||||
*/
|
||||
|
||||
-static int get_exit_code(struct cli_state * cli, NTSTATUS nt_status, bool use_kerberos);
|
||||
+static int get_exit_code(struct cli_state * cli, NTSTATUS nt_status);
|
||||
static void list_devices(void);
|
||||
static struct cli_state *smb_complete_connection(const char *, const char *,
|
||||
int, const char *, const char *, const char *, const char *, int, bool *need_auth);
|
||||
@@ -72,6 +72,8 @@ static char *uri_unescape_alloc(const char *);
|
||||
static bool smb_encrypt;
|
||||
#endif
|
||||
|
||||
+static const char *auth_info_required;
|
||||
+
|
||||
/*
|
||||
* 'main()' - Main entry for SMB backend.
|
||||
*/
|
||||
@@ -185,6 +187,11 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
}
|
||||
}
|
||||
|
||||
+ auth_info_required = getenv("AUTH_INFO_REQUIRED");
|
||||
+ if (auth_info_required == NULL) {
|
||||
+ auth_info_required = "none";
|
||||
+ }
|
||||
+
|
||||
cmp = strncmp(dev_uri, "smb://", 6);
|
||||
if (cmp != 0) {
|
||||
fprintf(stderr,
|
||||
@@ -233,6 +240,10 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
server = uri + 6;
|
||||
}
|
||||
|
||||
+ if (password != empty_str) {
|
||||
+ auth_info_required = "username,password";
|
||||
+ }
|
||||
+
|
||||
tmp = server;
|
||||
|
||||
if ((sep = strchr_m(tmp, '/')) == NULL) {
|
||||
@@ -352,8 +363,7 @@ done:
|
||||
|
||||
static int
|
||||
get_exit_code(struct cli_state * cli,
|
||||
- NTSTATUS nt_status,
|
||||
- bool use_kerberos)
|
||||
+ NTSTATUS nt_status)
|
||||
{
|
||||
int i;
|
||||
|
||||
@@ -380,10 +390,7 @@ get_exit_code(struct cli_state * cli,
|
||||
}
|
||||
|
||||
if (cli) {
|
||||
- if (use_kerberos)
|
||||
- fputs("ATTR: auth-info-required=negotiate\n", stderr);
|
||||
- else
|
||||
- fputs("ATTR: auth-info-required=username,password\n", stderr);
|
||||
+ fprintf(stderr, "ATTR: auth-info-required=%s\n", auth_info_required);
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -452,6 +459,7 @@ smb_complete_connection(const char *myname,
|
||||
}
|
||||
|
||||
if (flags & CLI_FULL_CONNECTION_USE_KERBEROS) {
|
||||
+ auth_info_required = "negotiate";
|
||||
use_kerberos = true;
|
||||
}
|
||||
|
||||
@@ -474,7 +482,7 @@ smb_complete_connection(const char *myname,
|
||||
if (!NT_STATUS_IS_OK(nt_status)) {
|
||||
fprintf(stderr, "ERROR: Session setup failed: %s\n", nt_errstr(nt_status));
|
||||
|
||||
- if (get_exit_code(cli, nt_status, use_kerberos) == 2) {
|
||||
+ if (get_exit_code(cli, nt_status) == 2) {
|
||||
*need_auth = true;
|
||||
}
|
||||
|
||||
@@ -488,7 +496,7 @@ smb_complete_connection(const char *myname,
|
||||
fprintf(stderr, "ERROR: Tree connect failed (%s)\n",
|
||||
nt_errstr(nt_status));
|
||||
|
||||
- if (get_exit_code(cli, nt_status, use_kerberos) == 2) {
|
||||
+ if (get_exit_code(cli, nt_status) == 2) {
|
||||
*need_auth = true;
|
||||
}
|
||||
|
||||
@@ -677,7 +685,7 @@ smb_print(struct cli_state * cli, /* I - SMB connection */
|
||||
if (!NT_STATUS_IS_OK(nt_status)) {
|
||||
fprintf(stderr, "ERROR: %s opening remote spool %s\n",
|
||||
nt_errstr(nt_status), title);
|
||||
- return get_exit_code(cli, nt_status, false);
|
||||
+ return get_exit_code(cli, nt_status);
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -695,7 +703,7 @@ smb_print(struct cli_state * cli, /* I - SMB connection */
|
||||
status = cli_writeall(cli, fnum, 0, (uint8_t *)buffer,
|
||||
tbytes, nbytes, NULL);
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
- int ret = get_exit_code(cli, status, false);
|
||||
+ int ret = get_exit_code(cli, status);
|
||||
fprintf(stderr, "ERROR: Error writing spool: %s\n",
|
||||
nt_errstr(status));
|
||||
fprintf(stderr, "DEBUG: Returning status %d...\n",
|
||||
@@ -711,7 +719,7 @@ smb_print(struct cli_state * cli, /* I - SMB connection */
|
||||
if (!NT_STATUS_IS_OK(nt_status)) {
|
||||
fprintf(stderr, "ERROR: %s closing remote spool %s\n",
|
||||
nt_errstr(nt_status), title);
|
||||
- return get_exit_code(cli, nt_status, false);
|
||||
+ return get_exit_code(cli, nt_status);
|
||||
} else {
|
||||
return (0);
|
||||
}
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From 59c5b1c6bad46ac523504120833080836cdc19a1 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Tue, 12 Mar 2019 10:09:14 +0100
|
||||
Subject: [PATCH 4/5] s3:client: Make sure we work on a copy of the title
|
||||
|
||||
We can't be sure we can write to the input buffer.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13832
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Bryan Mason <bmason@redhat.com>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
(cherry picked from commit 129ae27946318a075e99c9e6d1bacf8963f72282)
|
||||
---
|
||||
source3/client/smbspool.c | 14 ++++++++++----
|
||||
1 file changed, 10 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/source3/client/smbspool.c b/source3/client/smbspool.c
|
||||
index 3dbf6be014b..94c7ea368a2 100644
|
||||
--- a/source3/client/smbspool.c
|
||||
+++ b/source3/client/smbspool.c
|
||||
@@ -66,7 +66,7 @@ static struct cli_state *smb_complete_connection(const char *, const char *,
|
||||
int, const char *, const char *, const char *, const char *, int, bool *need_auth);
|
||||
static struct cli_state *smb_connect(const char *, const char *, int, const
|
||||
char *, const char *, const char *, const char *, bool *need_auth);
|
||||
-static int smb_print(struct cli_state *, char *, FILE *);
|
||||
+static int smb_print(struct cli_state *, const char *, FILE *);
|
||||
static char *uri_unescape_alloc(const char *);
|
||||
#if 0
|
||||
static bool smb_encrypt;
|
||||
@@ -655,7 +655,7 @@ kerberos_auth:
|
||||
|
||||
static int /* O - 0 = success, non-0 = failure */
|
||||
smb_print(struct cli_state * cli, /* I - SMB connection */
|
||||
- char *title, /* I - Title/job name */
|
||||
+ const char *print_title, /* I - Title/job name */
|
||||
FILE * fp)
|
||||
{ /* I - File to print */
|
||||
uint16_t fnum; /* File number */
|
||||
@@ -663,12 +663,18 @@ smb_print(struct cli_state * cli, /* I - SMB connection */
|
||||
tbytes; /* Total bytes read */
|
||||
char buffer[8192], /* Buffer for copy */
|
||||
*ptr; /* Pointer into title */
|
||||
+ char title[1024] = {0};
|
||||
+ int len;
|
||||
NTSTATUS nt_status;
|
||||
|
||||
|
||||
/*
|
||||
- * Sanitize the title...
|
||||
- */
|
||||
+ * Sanitize the title...
|
||||
+ */
|
||||
+ len = snprintf(title, sizeof(title), "%s", print_title);
|
||||
+ if (len != strlen(print_title)) {
|
||||
+ return 2;
|
||||
+ }
|
||||
|
||||
for (ptr = title; *ptr; ptr++) {
|
||||
if (!isalnum((int) *ptr) && !isspace((int) *ptr)) {
|
||||
--
|
||||
2.20.1
|
||||
|
||||
|
||||
From 912e8b22b3b35c17bce35d10d543cc1505a15c46 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Tue, 12 Mar 2019 11:40:30 +0100
|
||||
Subject: [PATCH 5/5] s3:client: Fix smbspool device uri handling
|
||||
|
||||
If we are executed as a CUPS backend, argv[0] is set to the device uri.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13832
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Bryan Mason <bmason@redhat.com>
|
||||
Signed-off-by: Guenther Deschner <gd@samba.org>
|
||||
|
||||
(cherry picked from commit 69d7a496d3bf52eaa10e81132bb61430863fdd8a)
|
||||
---
|
||||
source3/client/smbspool.c | 120 ++++++++++++++++++++++++++++++--------
|
||||
1 file changed, 96 insertions(+), 24 deletions(-)
|
||||
|
||||
diff --git a/source3/client/smbspool.c b/source3/client/smbspool.c
|
||||
index 94c7ea368a2..97d00bdd011 100644
|
||||
--- a/source3/client/smbspool.c
|
||||
+++ b/source3/client/smbspool.c
|
||||
@@ -99,10 +99,12 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
char empty_str[] = "";
|
||||
int tries = 0;
|
||||
bool need_auth = true;
|
||||
- const char *dev_uri;
|
||||
+ const char *dev_uri = NULL;
|
||||
+ const char *env = NULL;
|
||||
const char *config_file = NULL;
|
||||
TALLOC_CTX *frame = talloc_stackframe();
|
||||
- bool device_uri_cmdline = false;
|
||||
+ const char *print_user = NULL;
|
||||
+ const char *print_title = NULL;
|
||||
const char *print_file = NULL;
|
||||
const char *print_copies = NULL;
|
||||
int cmp;
|
||||
@@ -139,21 +141,81 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
}
|
||||
|
||||
/*
|
||||
- * If we have 6 arguments find out if we have the device_uri from the
|
||||
- * command line or the print data
|
||||
+ * Find out if we have the device_uri in the command line.
|
||||
+ *
|
||||
+ * If we are started as a CUPS backend argv[0] is normally the
|
||||
+ * device_uri!
|
||||
*/
|
||||
- if (argc == 7) {
|
||||
- cmp = strncmp(argv[1], "smb://", 6);
|
||||
- if (cmp == 0) {
|
||||
- device_uri_cmdline = true;
|
||||
+ if (argc == 8) {
|
||||
+ /*
|
||||
+ * smbspool <uri> <job> <user> <title> <copies> <options> <file>
|
||||
+ * 0 1 2 3 4 5 6 7
|
||||
+ */
|
||||
+
|
||||
+ dev_uri = argv[1];
|
||||
+
|
||||
+ print_user = argv[3];
|
||||
+ print_title = argv[4];
|
||||
+ print_copies = argv[5];
|
||||
+ print_file = argv[7];
|
||||
+ } else if (argc == 7) {
|
||||
+ int cmp1;
|
||||
+ int cmp2;
|
||||
+
|
||||
+ /*
|
||||
+ * <uri> <job> <user> <title> <copies> <options> <file>
|
||||
+ * smbspool <uri> <job> <user> <title> <copies> <options>
|
||||
+ * smbspool <job> <user> <title> <copies> <options> <file> | DEVICE_URI
|
||||
+ */
|
||||
+ cmp1 = strncmp(argv[0], "smb://", 6);
|
||||
+ cmp2 = strncmp(argv[1], "smb://", 6);
|
||||
+
|
||||
+ if (cmp1 == 0) {
|
||||
+ /*
|
||||
+ * <uri> <job> <user> <title> <copies> <options> <file>
|
||||
+ * 0 1 2 3 4 5 6
|
||||
+ */
|
||||
+ dev_uri = argv[0];
|
||||
+
|
||||
+ print_user = argv[2];
|
||||
+ print_title = argv[3];
|
||||
+ print_copies = argv[4];
|
||||
+ print_file = argv[6];
|
||||
+ } else if (cmp2 == 0) {
|
||||
+ /*
|
||||
+ * smbspool <uri> <job> <user> <title> <copies> <options>
|
||||
+ * 0 1 2 3 4 5 6
|
||||
+ */
|
||||
+ dev_uri = argv[1];
|
||||
+
|
||||
+ print_user = argv[3];
|
||||
+ print_title = argv[4];
|
||||
+ print_copies = argv[5];
|
||||
+ print_file = NULL;
|
||||
} else {
|
||||
+ /*
|
||||
+ * smbspool <job> <user> <title> <copies> <options> <file> | DEVICE_URI
|
||||
+ * 0 1 2 3 4 5 6
|
||||
+ */
|
||||
+ print_user = argv[2];
|
||||
+ print_title = argv[3];
|
||||
print_copies = argv[4];
|
||||
print_file = argv[6];
|
||||
}
|
||||
- } else if (argc == 8) {
|
||||
- device_uri_cmdline = true;
|
||||
- print_copies = argv[5];
|
||||
- print_file = argv[7];
|
||||
+ } else if (argc == 6) {
|
||||
+ /*
|
||||
+ * <uri> <job> <user> <title> <copies> <options>
|
||||
+ * smbspool <job> <user> <title> <copies> <options> | DEVICE_URI
|
||||
+ * 0 1 2 3 4 5
|
||||
+ */
|
||||
+ cmp = strncmp(argv[0], "smb://", 6);
|
||||
+ if (cmp == 0) {
|
||||
+ dev_uri = argv[0];
|
||||
+ }
|
||||
+
|
||||
+ print_user = argv[2];
|
||||
+ print_title = argv[3];
|
||||
+ print_copies = argv[4];
|
||||
}
|
||||
|
||||
if (print_file != NULL) {
|
||||
@@ -178,18 +240,17 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
/*
|
||||
* Find the URI ...
|
||||
*/
|
||||
- if (device_uri_cmdline) {
|
||||
- dev_uri = argv[1];
|
||||
- } else {
|
||||
- dev_uri = getenv("DEVICE_URI");
|
||||
- if (dev_uri == NULL || strlen(dev_uri) == 0) {
|
||||
- dev_uri = "";
|
||||
+ if (dev_uri == NULL) {
|
||||
+ env = getenv("DEVICE_URI");
|
||||
+ if (env != NULL && env[0] != '\0') {
|
||||
+ dev_uri = env;
|
||||
}
|
||||
}
|
||||
|
||||
- auth_info_required = getenv("AUTH_INFO_REQUIRED");
|
||||
- if (auth_info_required == NULL) {
|
||||
- auth_info_required = "none";
|
||||
+ if (dev_uri == NULL) {
|
||||
+ fprintf(stderr,
|
||||
+ "ERROR: No valid device URI has been specified\n");
|
||||
+ goto done;
|
||||
}
|
||||
|
||||
cmp = strncmp(dev_uri, "smb://", 6);
|
||||
@@ -205,6 +266,11 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
goto done;
|
||||
}
|
||||
|
||||
+ auth_info_required = getenv("AUTH_INFO_REQUIRED");
|
||||
+ if (auth_info_required == NULL) {
|
||||
+ auth_info_required = "none";
|
||||
+ }
|
||||
+
|
||||
/*
|
||||
* Extract the destination from the URI...
|
||||
*/
|
||||
@@ -301,8 +367,14 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
load_interfaces();
|
||||
|
||||
do {
|
||||
- cli = smb_connect(workgroup, server, port, printer,
|
||||
- username, password, argv[3], &need_auth);
|
||||
+ cli = smb_connect(workgroup,
|
||||
+ server,
|
||||
+ port,
|
||||
+ printer,
|
||||
+ username,
|
||||
+ password,
|
||||
+ print_user,
|
||||
+ &need_auth);
|
||||
if (cli == NULL) {
|
||||
if (need_auth) {
|
||||
exit(2);
|
||||
@@ -338,7 +410,7 @@ main(int argc, /* I - Number of command-line arguments */
|
||||
*/
|
||||
|
||||
for (i = 0; i < copies; i++) {
|
||||
- status = smb_print(cli, argv[4] /* title */ , fp);
|
||||
+ status = smb_print(cli, print_title, fp);
|
||||
if (status != 0) {
|
||||
break;
|
||||
}
|
||||
--
|
||||
2.20.1
|
||||
|
@ -0,0 +1,33 @@ |
||||
From be97b5934ca163259676be27d5c254da30080fbe Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Thu, 9 May 2019 16:18:51 +0200
|
||||
Subject: [PATCH] s3:smbspool: Fix regression printing with Kerberos
|
||||
credentials
|
||||
|
||||
This is a regression which has been introduced with Samba 4.8.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13939
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Guenther Deschner <gd@samba.org>
|
||||
(cherry picked from commit fd4b1f4f16aee3e3c9a2cb449655edfed171963a)
|
||||
---
|
||||
source3/client/smbspool.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/source3/client/smbspool.c b/source3/client/smbspool.c
|
||||
index 97d00bdd011..c404b3a3f69 100644
|
||||
--- a/source3/client/smbspool.c
|
||||
+++ b/source3/client/smbspool.c
|
||||
@@ -660,7 +660,7 @@ smb_connect(const char *workgroup, /* I - Workgroup */
|
||||
* behavior with 3.0.14a
|
||||
*/
|
||||
|
||||
- if (username != NULL && username[0] != '\0') {
|
||||
+ if (username == NULL || username[0] == '\0') {
|
||||
if (kerberos_ccache_is_valid()) {
|
||||
goto kerberos_auth;
|
||||
}
|
||||
--
|
||||
2.21.0
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,39 @@ |
||||
From 38e6908f259b2bdbdba38a856b9d67585453af9a Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 29 Oct 2018 19:45:58 +0100
|
||||
Subject: [PATCH] s3:winbind: Check return code of initialize_password_db()
|
||||
|
||||
See https://retrace.fedoraproject.org/faf/reports/1577174/
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13668
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
|
||||
(cherry picked from commit ba17cae4cab686b8d018c39d16706e621f9f93ac)
|
||||
---
|
||||
source3/winbindd/winbindd.c | 8 +++++++-
|
||||
1 file changed, 7 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/source3/winbindd/winbindd.c b/source3/winbindd/winbindd.c
|
||||
index 254d93b344d..a8ffc31778c 100644
|
||||
--- a/source3/winbindd/winbindd.c
|
||||
+++ b/source3/winbindd/winbindd.c
|
||||
@@ -1845,7 +1845,13 @@ int main(int argc, const char **argv)
|
||||
if (!NT_STATUS_IS_OK(status)) {
|
||||
exit_daemon("Winbindd reinit_after_fork() failed", map_errno_from_nt_status(status));
|
||||
}
|
||||
- initialize_password_db(true, server_event_context());
|
||||
+
|
||||
+ ok = initialize_password_db(true, server_event_context());
|
||||
+ if (!ok) {
|
||||
+ exit_daemon("Failed to initialize passdb backend! "
|
||||
+ "Check the 'passdb backend' variable in your "
|
||||
+ "smb.conf file.", EINVAL);
|
||||
+ }
|
||||
|
||||
/*
|
||||
* Do not initialize the parent-child-pipe before becoming
|
||||
--
|
||||
2.19.1
|
||||
|
@ -0,0 +1,402 @@ |
||||
From b67bc28be3e0ab40e14f698951c9ba057ea8321d Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Thu, 15 Nov 2018 16:06:49 +0100
|
||||
Subject: [PATCH 1/4] selftest: Add gooduser and eviluser to Samba3
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13699
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Böhme <slow@samba.org>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
(cherry picked from commit 3b38dddff2c1d1b51aed96368b358f349682bea0)
|
||||
---
|
||||
selftest/target/Samba3.pm | 10 +++++++++-
|
||||
1 file changed, 9 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/selftest/target/Samba3.pm b/selftest/target/Samba3.pm
|
||||
index 438cb3409bb..373f8152ca3 100755
|
||||
--- a/selftest/target/Samba3.pm
|
||||
+++ b/selftest/target/Samba3.pm
|
||||
@@ -1610,8 +1610,10 @@ sub provision($$$$$$$$$)
|
||||
my ($gid_force_user);
|
||||
my ($uid_user1);
|
||||
my ($uid_user2);
|
||||
+ my ($uid_gooduser);
|
||||
+ my ($uid_eviluser);
|
||||
|
||||
- if ($unix_uid < 0xffff - 10) {
|
||||
+ if ($unix_uid < 0xffff - 12) {
|
||||
$max_uid = 0xffff;
|
||||
} else {
|
||||
$max_uid = $unix_uid;
|
||||
@@ -1627,6 +1629,8 @@ sub provision($$$$$$$$$)
|
||||
$uid_smbget = $max_uid - 8;
|
||||
$uid_user1 = $max_uid - 9;
|
||||
$uid_user2 = $max_uid - 10;
|
||||
+ $uid_gooduser = $max_uid - 11;
|
||||
+ $uid_eviluser = $max_uid - 12;
|
||||
|
||||
if ($unix_gids[0] < 0xffff - 8) {
|
||||
$max_gid = 0xffff;
|
||||
@@ -2248,6 +2252,8 @@ force_user:x:$uid_force_user:$gid_force_user:force user gecos:$prefix_abs:/bin/f
|
||||
smbget_user:x:$uid_smbget:$gid_domusers:smbget_user gecos:$prefix_abs:/bin/false
|
||||
user1:x:$uid_user1:$gid_nogroup:user1 gecos:$prefix_abs:/bin/false
|
||||
user2:x:$uid_user2:$gid_nogroup:user2 gecos:$prefix_abs:/bin/false
|
||||
+gooduser:x:$uid_gooduser:$gid_domusers:gooduser gecos:$prefix_abs:/bin/false
|
||||
+eviluser:x:$uid_eviluser:$gid_domusers:eviluser gecos::/bin/false
|
||||
";
|
||||
if ($unix_uid != 0) {
|
||||
print PASSWD "root:x:$uid_root:$gid_root:root gecos:$prefix_abs:/bin/false
|
||||
@@ -2324,6 +2330,8 @@ force_user:x:$gid_force_user:
|
||||
createuser($self, "smbget_user", $password, $conffile, \%createuser_env) || die("Unable to create smbget_user");
|
||||
createuser($self, "user1", $password, $conffile, \%createuser_env) || die("Unable to create user1");
|
||||
createuser($self, "user2", $password, $conffile, \%createuser_env) || die("Unable to create user2");
|
||||
+ createuser($self, "gooduser", $password, $conffile, \%createuser_env) || die("Unable to create gooduser");
|
||||
+ createuser($self, "eviluser", $password, $conffile, \%createuser_env) || die("Unable to create eviluser");
|
||||
|
||||
open(DNS_UPDATE_LIST, ">$prefix/dns_update_list") or die("Unable to open $$prefix/dns_update_list");
|
||||
print DNS_UPDATE_LIST "A $server. $server_ip\n";
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From ca57b6e4f02c725a3f47b8dde01d4b70dce42784 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Fri, 16 Nov 2018 15:40:59 +0100
|
||||
Subject: [PATCH 2/4] s3:tests: Test for users connecting to their 'homes'
|
||||
share
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
This adds a test for CVE-2009-2813.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13699
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Böhme <slow@samba.org>
|
||||
(cherry picked from commit cc471448df91c43fe38e2fcdf9b3874636ca51a6)
|
||||
---
|
||||
selftest/target/Samba3.pm | 4 ++
|
||||
source3/script/tests/test_homes.sh | 99 ++++++++++++++++++++++++++++++
|
||||
source3/selftest/tests.py | 1 +
|
||||
3 files changed, 104 insertions(+)
|
||||
create mode 100755 source3/script/tests/test_homes.sh
|
||||
|
||||
diff --git a/selftest/target/Samba3.pm b/selftest/target/Samba3.pm
|
||||
index 373f8152ca3..2031003210c 100755
|
||||
--- a/selftest/target/Samba3.pm
|
||||
+++ b/selftest/target/Samba3.pm
|
||||
@@ -921,6 +921,10 @@ sub setup_fileserver
|
||||
comment = inherit only unix owner
|
||||
inherit owner = unix only
|
||||
acl_xattr:ignore system acls = yes
|
||||
+[homes]
|
||||
+ comment = Home directories
|
||||
+ browseable = No
|
||||
+ read only = No
|
||||
";
|
||||
|
||||
my $vars = $self->provision($path, "WORKGROUP",
|
||||
diff --git a/source3/script/tests/test_homes.sh b/source3/script/tests/test_homes.sh
|
||||
new file mode 100755
|
||||
index 00000000000..06de0a0c301
|
||||
--- /dev/null
|
||||
+++ b/source3/script/tests/test_homes.sh
|
||||
@@ -0,0 +1,99 @@
|
||||
+#!/bin/sh
|
||||
+
|
||||
+# Copyright (c) Andreas Schneider <asn@samba.org>
|
||||
+# License: GPLv3
|
||||
+
|
||||
+if [ $# -lt 7 ]; then
|
||||
+ echo "Usage: test_homes.sh SERVER USERNAME PASSWORD LOCAL_PATH PREFIX SMBCLIENT CONFIGURATION"
|
||||
+ exit 1
|
||||
+fi
|
||||
+
|
||||
+SERVER="${1}"
|
||||
+USERNAME="${2}"
|
||||
+PASSWORD="${3}"
|
||||
+LOCAL_PATH="${4}"
|
||||
+PREFIX="${5}"
|
||||
+SMBCLIENT="${6}"
|
||||
+CONFIGURATION="${7}"
|
||||
+shift 7
|
||||
+
|
||||
+incdir=`dirname $0`/../../../testprogs/blackbox
|
||||
+. $incdir/subunit.sh
|
||||
+
|
||||
+failed=0
|
||||
+
|
||||
+test_gooduser_home()
|
||||
+{
|
||||
+ tmpfile=$PREFIX/smbclient_homes_gooduser_commands
|
||||
+ cat > $tmpfile <<EOF
|
||||
+ls
|
||||
+quit
|
||||
+EOF
|
||||
+
|
||||
+ USERNAME=gooduser
|
||||
+
|
||||
+ cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/$USERNAME $CONFIGURATION < $tmpfile 2>&1'
|
||||
+ eval echo "$cmd"
|
||||
+ out=$(eval $cmd)
|
||||
+ ret=$?
|
||||
+ rm -f $tmpfile
|
||||
+
|
||||
+ if [ $ret -ne 0 ] ; then
|
||||
+ echo "$out"
|
||||
+ echo "failed to connect error $ret"
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ echo "$out" | grep 'Try "help" to get a list of possible commands.'
|
||||
+ ret=$?
|
||||
+ if [ $ret -ne 0 ] ; then
|
||||
+ echo "$out"
|
||||
+ echo 'failed - should get: Try "help" to get a list of possible commands.'
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ return 0
|
||||
+}
|
||||
+
|
||||
+test_eviluser_home()
|
||||
+{
|
||||
+ tmpfile=$PREFIX/smbclient_homes_eviluser_commands
|
||||
+ cat > $tmpfile <<EOF
|
||||
+ls
|
||||
+quit
|
||||
+EOF
|
||||
+
|
||||
+ USERNAME=eviluser
|
||||
+
|
||||
+ cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/$USERNAME $CONFIGURATION < $tmpfile 2>&1'
|
||||
+ eval echo "$cmd"
|
||||
+ out=$(eval $cmd)
|
||||
+ ret=$?
|
||||
+ rm -f $tmpfile
|
||||
+
|
||||
+ if [ $ret -ne 1 ] ; then
|
||||
+ echo "$out"
|
||||
+ echo "The server should reject connecting ret=$ret"
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ echo "$out" | grep 'NT_STATUS_BAD_NETWORK_NAME'
|
||||
+ ret=$?
|
||||
+ if [ $ret -ne 0 ] ; then
|
||||
+ echo "$out"
|
||||
+ echo 'failed - should get: NT_STATUS_BAD_NETWORK_NAME.'
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ return 0
|
||||
+}
|
||||
+
|
||||
+testit "test gooduser home" \
|
||||
+ test_gooduser_home || \
|
||||
+ failed=`expr $failed + 1`
|
||||
+
|
||||
+testit "test eviluser home reject" \
|
||||
+ test_eviluser_home || \
|
||||
+ failed=`expr $failed + 1`
|
||||
+
|
||||
+testok $0 $failed
|
||||
diff --git a/source3/selftest/tests.py b/source3/selftest/tests.py
|
||||
index 09cd5159a0d..4aef7a4d596 100755
|
||||
--- a/source3/selftest/tests.py
|
||||
+++ b/source3/selftest/tests.py
|
||||
@@ -290,6 +290,7 @@ for env in ["fileserver"]:
|
||||
plantestsuite("samba3.blackbox.large_acl.NT1", env, [os.path.join(samba3srcdir, "script/tests/test_large_acl.sh"), '$SERVER', '$USERNAME', '$PASSWORD', smbclient3, smbcacls, '-m', 'NT1'])
|
||||
plantestsuite("samba3.blackbox.large_acl.SMB3", env, [os.path.join(samba3srcdir, "script/tests/test_large_acl.sh"), '$SERVER', '$USERNAME', '$PASSWORD', smbclient3, smbcacls, '-m', 'SMB3'])
|
||||
plantestsuite("samba3.blackbox.give_owner", env, [os.path.join(samba3srcdir, "script/tests/test_give_owner.sh"), '$SERVER', '$SERVER_IP', '$USERNAME', '$PASSWORD', '$PREFIX', smbclient3, smbcacls, net, 'tmp'])
|
||||
+ plantestsuite("samba3.blackbox.homes", env, [os.path.join(samba3srcdir, "script/tests/test_homes.sh"), '$SERVER', '$USERNAME', '$PASSWORD', '$LOCAL_PATH', '$PREFIX', smbclient3, configuration])
|
||||
|
||||
#
|
||||
# tar command tests
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From 274e960fde8e680a487fd7f3af57c824f9a5151b Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Thu, 22 Nov 2018 18:23:24 +0100
|
||||
Subject: [PATCH 3/4] s3:smbd: Make sure we do not export "/" (root) as home
|
||||
dir
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
If "/" (root) is returned as the home directory, prevent exporting it.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13699
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Böhme <slow@samba.org>
|
||||
(cherry picked from commit 99695528f7453023446956d5f8f0656574e243af)
|
||||
---
|
||||
source3/param/service.c | 6 +++++-
|
||||
source3/smbd/password.c | 7 +++++++
|
||||
2 files changed, 12 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/source3/param/service.c b/source3/param/service.c
|
||||
index b21be6093d4..22f46f08894 100644
|
||||
--- a/source3/param/service.c
|
||||
+++ b/source3/param/service.c
|
||||
@@ -149,7 +149,11 @@ int find_service(TALLOC_CTX *ctx, const char *service_in, char **p_service_out)
|
||||
DEBUG(3,("checking for home directory %s gave %s\n",*p_service_out,
|
||||
phome_dir?phome_dir:"(NULL)"));
|
||||
|
||||
- iService = add_home_service(*p_service_out,*p_service_out /* 'username' */, phome_dir);
|
||||
+ if (!strequal(phome_dir, "/")) {
|
||||
+ iService = add_home_service(*p_service_out,
|
||||
+ *p_service_out, /* username */
|
||||
+ phome_dir);
|
||||
+ }
|
||||
}
|
||||
|
||||
/* If we still don't have a service, attempt to add it as a printer. */
|
||||
diff --git a/source3/smbd/password.c b/source3/smbd/password.c
|
||||
index f472bda2c70..0576d2563eb 100644
|
||||
--- a/source3/smbd/password.c
|
||||
+++ b/source3/smbd/password.c
|
||||
@@ -129,6 +129,13 @@ int register_homes_share(const char *username)
|
||||
return -1;
|
||||
}
|
||||
|
||||
+ if (strequal(pwd->pw_dir, "/")) {
|
||||
+ DBG_NOTICE("Invalid home directory defined for user '%s'\n",
|
||||
+ username);
|
||||
+ TALLOC_FREE(pwd);
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
DEBUG(3, ("Adding homes service for user '%s' using home directory: "
|
||||
"'%s'\n", username, pwd->pw_dir));
|
||||
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From e26c6aa97e57432d2f2fee2eba870ba76c9b8d41 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 3 Dec 2018 11:05:46 +0100
|
||||
Subject: [PATCH 4/4] s3:tests: Add test for checking that root is not allowed
|
||||
as home dir
|
||||
MIME-Version: 1.0
|
||||
Content-Type: text/plain; charset=UTF-8
|
||||
Content-Transfer-Encoding: 8bit
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13699
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Ralph Böhme <slow@samba.org>
|
||||
Reviewed-by: Jeremy Allison <jra@samba.org>
|
||||
|
||||
Autobuild-User(master): Jeremy Allison <jra@samba.org>
|
||||
Autobuild-Date(master): Wed Dec 5 05:22:43 CET 2018 on sn-devel-144
|
||||
|
||||
(cherry picked from commit a92f0ccce606be12e851a4100fbb44b069c5fe87)
|
||||
---
|
||||
selftest/target/Samba3.pm | 6 ++++-
|
||||
source3/script/tests/test_homes.sh | 37 ++++++++++++++++++++++++++++++
|
||||
2 files changed, 42 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/selftest/target/Samba3.pm b/selftest/target/Samba3.pm
|
||||
index 2031003210c..583396b3818 100755
|
||||
--- a/selftest/target/Samba3.pm
|
||||
+++ b/selftest/target/Samba3.pm
|
||||
@@ -1616,8 +1616,9 @@ sub provision($$$$$$$$$)
|
||||
my ($uid_user2);
|
||||
my ($uid_gooduser);
|
||||
my ($uid_eviluser);
|
||||
+ my ($uid_slashuser);
|
||||
|
||||
- if ($unix_uid < 0xffff - 12) {
|
||||
+ if ($unix_uid < 0xffff - 13) {
|
||||
$max_uid = 0xffff;
|
||||
} else {
|
||||
$max_uid = $unix_uid;
|
||||
@@ -1635,6 +1636,7 @@ sub provision($$$$$$$$$)
|
||||
$uid_user2 = $max_uid - 10;
|
||||
$uid_gooduser = $max_uid - 11;
|
||||
$uid_eviluser = $max_uid - 12;
|
||||
+ $uid_slashuser = $max_uid - 13;
|
||||
|
||||
if ($unix_gids[0] < 0xffff - 8) {
|
||||
$max_gid = 0xffff;
|
||||
@@ -2258,6 +2260,7 @@ user1:x:$uid_user1:$gid_nogroup:user1 gecos:$prefix_abs:/bin/false
|
||||
user2:x:$uid_user2:$gid_nogroup:user2 gecos:$prefix_abs:/bin/false
|
||||
gooduser:x:$uid_gooduser:$gid_domusers:gooduser gecos:$prefix_abs:/bin/false
|
||||
eviluser:x:$uid_eviluser:$gid_domusers:eviluser gecos::/bin/false
|
||||
+slashuser:x:$uid_slashuser:$gid_domusers:slashuser gecos:/:/bin/false
|
||||
";
|
||||
if ($unix_uid != 0) {
|
||||
print PASSWD "root:x:$uid_root:$gid_root:root gecos:$prefix_abs:/bin/false
|
||||
@@ -2336,6 +2339,7 @@ force_user:x:$gid_force_user:
|
||||
createuser($self, "user2", $password, $conffile, \%createuser_env) || die("Unable to create user2");
|
||||
createuser($self, "gooduser", $password, $conffile, \%createuser_env) || die("Unable to create gooduser");
|
||||
createuser($self, "eviluser", $password, $conffile, \%createuser_env) || die("Unable to create eviluser");
|
||||
+ createuser($self, "slashuser", $password, $conffile, \%createuser_env) || die("Unable to create slashuser");
|
||||
|
||||
open(DNS_UPDATE_LIST, ">$prefix/dns_update_list") or die("Unable to open $$prefix/dns_update_list");
|
||||
print DNS_UPDATE_LIST "A $server. $server_ip\n";
|
||||
diff --git a/source3/script/tests/test_homes.sh b/source3/script/tests/test_homes.sh
|
||||
index 06de0a0c301..90e84550dbc 100755
|
||||
--- a/source3/script/tests/test_homes.sh
|
||||
+++ b/source3/script/tests/test_homes.sh
|
||||
@@ -88,6 +88,39 @@ EOF
|
||||
return 0
|
||||
}
|
||||
|
||||
+test_slashuser_home()
|
||||
+{
|
||||
+ tmpfile=$PREFIX/smbclient_homes_slashuser_commands
|
||||
+ cat > $tmpfile <<EOF
|
||||
+ls
|
||||
+quit
|
||||
+EOF
|
||||
+
|
||||
+ USERNAME=slashuser
|
||||
+
|
||||
+ cmd='CLI_FORCE_INTERACTIVE=yes $SMBCLIENT "$@" -U$USERNAME%$PASSWORD //$SERVER/$USERNAME $CONFIGURATION < $tmpfile 2>&1'
|
||||
+ eval echo "$cmd"
|
||||
+ out=$(eval $cmd)
|
||||
+ ret=$?
|
||||
+ rm -f $tmpfile
|
||||
+
|
||||
+ if [ $ret -ne 1 ] ; then
|
||||
+ echo "$out"
|
||||
+ echo "The server should reject connecting ret=$ret"
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ echo "$out" | grep 'NT_STATUS_BAD_NETWORK_NAME'
|
||||
+ ret=$?
|
||||
+ if [ $ret -ne 0 ] ; then
|
||||
+ echo "$out"
|
||||
+ echo 'failed - should get: NT_STATUS_BAD_NETWORK_NAME.'
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ return 0
|
||||
+}
|
||||
+
|
||||
testit "test gooduser home" \
|
||||
test_gooduser_home || \
|
||||
failed=`expr $failed + 1`
|
||||
@@ -96,4 +129,8 @@ testit "test eviluser home reject" \
|
||||
test_eviluser_home || \
|
||||
failed=`expr $failed + 1`
|
||||
|
||||
+testit "test slashuser home reject" \
|
||||
+ test_slashuser_home || \
|
||||
+ failed=`expr $failed + 1`
|
||||
+
|
||||
testok $0 $failed
|
||||
--
|
||||
2.19.2
|
@ -0,0 +1,119 @@ |
||||
From 1038892f651cbc1a924cd7e74b393eb356dd5266 Mon Sep 17 00:00:00 2001
|
||||
From: Justin Stephenson <jstephen@redhat.com>
|
||||
Date: Wed, 27 Jun 2018 11:32:31 -0400
|
||||
Subject: [PATCH] s3:libads: Add net ads leave keep-account option
|
||||
|
||||
Add the ability to leave the domain with --keep-account argument to avoid
|
||||
removal of the host machine account.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13498
|
||||
|
||||
Signed-off-by: Justin Stephenson <jstephen@redhat.com>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
Reviewed-by: Alexander Bokovoy <ab@samba.org>
|
||||
(cherry picked from commit d881f0c8a0ce2fc7cabf1966c5724e72c70d6694)
|
||||
---
|
||||
docs-xml/manpages/net.8.xml | 9 ++++++++-
|
||||
source3/libnet/libnet_join.c | 2 ++
|
||||
source3/utils/net.c | 3 ++-
|
||||
source3/utils/net.h | 1 +
|
||||
source3/utils/net_ads.c | 9 +++++++--
|
||||
5 files changed, 20 insertions(+), 4 deletions(-)
|
||||
|
||||
diff --git a/docs-xml/manpages/net.8.xml b/docs-xml/manpages/net.8.xml
|
||||
index 3154ee5ff85..d2bcd24c502 100644
|
||||
--- a/docs-xml/manpages/net.8.xml
|
||||
+++ b/docs-xml/manpages/net.8.xml
|
||||
@@ -377,6 +377,13 @@
|
||||
</para></listitem>
|
||||
</varlistentry>
|
||||
|
||||
+ <varlistentry>
|
||||
+ <term>--keep-account</term>
|
||||
+ <listitem><para>Prevent the machine account removal as
|
||||
+ part of "net ads leave".
|
||||
+ </para></listitem>
|
||||
+ </varlistentry>
|
||||
+
|
||||
&stdarg.encrypt;
|
||||
&popt.common.samba.client;
|
||||
|
||||
@@ -1276,7 +1283,7 @@ against an NT4 Domain Controller.
|
||||
</refsect2>
|
||||
|
||||
<refsect2>
|
||||
-<title>ADS LEAVE</title>
|
||||
+<title>ADS LEAVE [--keep-account]</title>
|
||||
|
||||
<para>Make the remote host leave the domain it is part of. </para>
|
||||
|
||||
diff --git a/source3/libnet/libnet_join.c b/source3/libnet/libnet_join.c
|
||||
index a9405e8d288..27fc5135442 100644
|
||||
--- a/source3/libnet/libnet_join.c
|
||||
+++ b/source3/libnet/libnet_join.c
|
||||
@@ -2868,6 +2868,8 @@ static WERROR libnet_DomainUnjoin(TALLOC_CTX *mem_ctx,
|
||||
return ntstatus_to_werror(status);
|
||||
}
|
||||
|
||||
+ r->out.dns_domain_name = talloc_strdup(mem_ctx,
|
||||
+ r->in.domain_name);
|
||||
r->out.disabled_machine_account = true;
|
||||
}
|
||||
|
||||
diff --git a/source3/utils/net.c b/source3/utils/net.c
|
||||
index 759d8cd442b..b3bd4b67118 100644
|
||||
--- a/source3/utils/net.c
|
||||
+++ b/source3/utils/net.c
|
||||
@@ -970,8 +970,9 @@ static struct functable net_func[] = {
|
||||
{"wipe", 0, POPT_ARG_NONE, &c->opt_wipe},
|
||||
/* Options for 'net registry import' */
|
||||
{"precheck", 0, POPT_ARG_STRING, &c->opt_precheck},
|
||||
- /* Options for 'net ads join' */
|
||||
+ /* Options for 'net ads join or leave' */
|
||||
{"no-dns-updates", 0, POPT_ARG_NONE, &c->opt_no_dns_updates},
|
||||
+ {"keep-account", 0, POPT_ARG_NONE, &c->opt_keep_account},
|
||||
POPT_COMMON_SAMBA
|
||||
{ 0, 0, 0, 0}
|
||||
};
|
||||
diff --git a/source3/utils/net.h b/source3/utils/net.h
|
||||
index d6dfeb6208f..5e70fd3aafa 100644
|
||||
--- a/source3/utils/net.h
|
||||
+++ b/source3/utils/net.h
|
||||
@@ -85,6 +85,7 @@ struct net_context {
|
||||
int opt_wipe;
|
||||
const char *opt_precheck;
|
||||
int opt_no_dns_updates;
|
||||
+ int opt_keep_account;
|
||||
|
||||
int opt_have_ip;
|
||||
struct sockaddr_storage opt_dest_ip;
|
||||
diff --git a/source3/utils/net_ads.c b/source3/utils/net_ads.c
|
||||
index ffa67d8f525..afe47dad839 100644
|
||||
--- a/source3/utils/net_ads.c
|
||||
+++ b/source3/utils/net_ads.c
|
||||
@@ -964,7 +964,7 @@ static int net_ads_leave(struct net_context *c, int argc, const char **argv)
|
||||
|
||||
if (c->display_usage) {
|
||||
d_printf( "%s\n"
|
||||
- "net ads leave\n"
|
||||
+ "net ads leave [--keep-account]\n"
|
||||
" %s\n",
|
||||
_("Usage:"),
|
||||
_("Leave an AD domain"));
|
||||
@@ -1009,7 +1009,12 @@ static int net_ads_leave(struct net_context *c, int argc, const char **argv)
|
||||
WKSSVC_JOIN_FLAGS_ACCOUNT_DELETE really means "disable */
|
||||
r->in.unjoin_flags = WKSSVC_JOIN_FLAGS_JOIN_TYPE |
|
||||
WKSSVC_JOIN_FLAGS_ACCOUNT_DELETE;
|
||||
- r->in.delete_machine_account = true;
|
||||
+ if (c->opt_keep_account) {
|
||||
+ r->in.delete_machine_account = false;
|
||||
+ } else {
|
||||
+ r->in.delete_machine_account = true;
|
||||
+ }
|
||||
+
|
||||
r->in.msg_ctx = c->msg_ctx;
|
||||
|
||||
werr = libnet_Unjoin(ctx, r);
|
||||
--
|
||||
2.17.1
|
||||
|
@ -0,0 +1,179 @@ |
||||
From 0bd36d040129f511762b89555d98851a9dcaf3f6 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 12 Nov 2018 10:09:23 +0100
|
||||
Subject: [PATCH 1/5] s3:rpcclient: Initialize domain_name
|
||||
|
||||
This could be passed uninitialized to dcerpc_netr_DsRGetDCName()
|
||||
|
||||
Found by cppcheck.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13680
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 56ac8944eb58f234422b4bd4dd9a64b8e51e874d)
|
||||
---
|
||||
source3/rpcclient/cmd_netlogon.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/source3/rpcclient/cmd_netlogon.c b/source3/rpcclient/cmd_netlogon.c
|
||||
index 8d62ef7e095..631740562c6 100644
|
||||
--- a/source3/rpcclient/cmd_netlogon.c
|
||||
+++ b/source3/rpcclient/cmd_netlogon.c
|
||||
@@ -216,7 +216,7 @@ static WERROR cmd_netlogon_dsr_getdcname(struct rpc_pipe_client *cli,
|
||||
WERROR werr = WERR_OK;
|
||||
uint32_t flags = DS_RETURN_DNS_NAME;
|
||||
const char *server_name = cli->desthost;
|
||||
- const char *domain_name;
|
||||
+ const char *domain_name = NULL;
|
||||
struct GUID domain_guid = GUID_zero();
|
||||
struct GUID site_guid = GUID_zero();
|
||||
struct netr_DsRGetDCNameInfo *info = NULL;
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From f14942265b08710d4e9bf6b17219f65b5ea79e01 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 12 Nov 2018 10:13:51 +0100
|
||||
Subject: [PATCH 2/5] librpc:ndr: Initialize inblob
|
||||
|
||||
Found by cppcheck.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13680
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 9c37ed26f0a814f77c934ae190f48d0a1e673f83)
|
||||
---
|
||||
librpc/ndr/ndr_backupkey.c | 4 +++-
|
||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
||||
|
||||
diff --git a/librpc/ndr/ndr_backupkey.c b/librpc/ndr/ndr_backupkey.c
|
||||
index 827bc694230..adb6e393287 100644
|
||||
--- a/librpc/ndr/ndr_backupkey.c
|
||||
+++ b/librpc/ndr/ndr_backupkey.c
|
||||
@@ -58,7 +58,9 @@ _PUBLIC_ void ndr_print_bkrp_BackupKey(struct ndr_print *ndr, const char *name,
|
||||
ndr->flags |= LIBNDR_PRINT_SET_VALUES;
|
||||
}
|
||||
if (flags & NDR_IN) {
|
||||
- union bkrp_data_in_blob inblob;
|
||||
+ union bkrp_data_in_blob inblob = {
|
||||
+ .empty._empty_ = '\0',
|
||||
+ };
|
||||
DATA_BLOB blob;
|
||||
uint32_t level;
|
||||
enum ndr_err_code ndr_err;
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From 865ad3bb69c487589f24c755b2082fe51e5a261a Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 12 Nov 2018 10:16:06 +0100
|
||||
Subject: [PATCH 3/5] libgpo: Make sure status is intialized
|
||||
|
||||
Found by cppcheck.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13680
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 159f753732cdc1e4491f93617779861fb9d73bc7)
|
||||
---
|
||||
libgpo/gpo_ldap.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/libgpo/gpo_ldap.c b/libgpo/gpo_ldap.c
|
||||
index fec00053b49..f087203f28a 100644
|
||||
--- a/libgpo/gpo_ldap.c
|
||||
+++ b/libgpo/gpo_ldap.c
|
||||
@@ -474,7 +474,7 @@ ADS_STATUS ads_get_gpo(ADS_STRUCT *ads,
|
||||
const char *guid_name,
|
||||
struct GROUP_POLICY_OBJECT *gpo)
|
||||
{
|
||||
- ADS_STATUS status;
|
||||
+ ADS_STATUS status = ADS_ERROR(LDAP_NO_SUCH_OBJECT);
|
||||
LDAPMessage *res = NULL;
|
||||
char *dn;
|
||||
const char *filter;
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From b40b21c5b2f6ed6e4e123cb55d9279f88b3e5c3b Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 12 Nov 2018 10:17:37 +0100
|
||||
Subject: [PATCH 4/5] lib:util Always initialize start and space
|
||||
|
||||
Found by cppcheck.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13680
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 050d1e7d53c068efac109ec4ff7a686d152e6a45)
|
||||
---
|
||||
lib/util/talloc_report.c | 7 ++-----
|
||||
1 file changed, 2 insertions(+), 5 deletions(-)
|
||||
|
||||
diff --git a/lib/util/talloc_report.c b/lib/util/talloc_report.c
|
||||
index 63213a014b6..bed0fd91e43 100644
|
||||
--- a/lib/util/talloc_report.c
|
||||
+++ b/lib/util/talloc_report.c
|
||||
@@ -33,8 +33,8 @@ static char *talloc_vasprintf_append_largebuf(char *buf, ssize_t *pstr_len,
|
||||
const char *fmt, va_list ap)
|
||||
{
|
||||
ssize_t str_len = *pstr_len;
|
||||
- size_t buflen, needed, space;
|
||||
- char *start, *tmpbuf;
|
||||
+ size_t buflen, needed, space = 0;
|
||||
+ char *start = NULL, *tmpbuf = NULL;
|
||||
va_list ap2;
|
||||
int printlen;
|
||||
|
||||
@@ -52,9 +52,6 @@ static char *talloc_vasprintf_append_largebuf(char *buf, ssize_t *pstr_len,
|
||||
if (buflen > str_len) {
|
||||
start = buf + str_len;
|
||||
space = buflen - str_len;
|
||||
- } else {
|
||||
- start = NULL;
|
||||
- space = 0;
|
||||
}
|
||||
|
||||
va_copy(ap2, ap);
|
||||
--
|
||||
2.19.2
|
||||
|
||||
|
||||
From 01c2b8c1920744b9b46e3b2010f0487f23aa865b Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 12 Nov 2018 10:21:15 +0100
|
||||
Subject: [PATCH 5/5] ctdb: Fix an out of bound array access
|
||||
|
||||
Found by cppcheck.
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13680
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 008b9652cacdfd99e68db9d88f4e0c33eefa87e9)
|
||||
---
|
||||
ctdb/common/logging.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
diff --git a/ctdb/common/logging.c b/ctdb/common/logging.c
|
||||
index dc8c4f75058..55e5d541735 100644
|
||||
--- a/ctdb/common/logging.c
|
||||
+++ b/ctdb/common/logging.c
|
||||
@@ -85,7 +85,7 @@ const char *debug_level_to_string(int log_level)
|
||||
{
|
||||
int i;
|
||||
|
||||
- for (i=0; ARRAY_SIZE(log_string_map); i++) {
|
||||
+ for (i=0; i < ARRAY_SIZE(log_string_map); i++) {
|
||||
if (log_string_map[i].log_level == log_level) {
|
||||
return log_string_map[i].log_string;
|
||||
}
|
||||
--
|
||||
2.19.2
|
@ -0,0 +1,117 @@ |
||||
From e2dd47233f467e2ab80564968be4af6da6505161 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 3 Sep 2018 10:35:08 +0200
|
||||
Subject: [PATCH 1/2] waf: Check for -fstack-protect-strong support
|
||||
|
||||
The -fstack-protector* flags are compiler only flags, don't pass them to
|
||||
the linker.
|
||||
|
||||
https://developers.redhat.com/blog/2018/03/21/compiler-and-linker-flags-gcc/
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13601
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit 38e97f8b52e85bdfcf2d74a4fb3c848fa46ba371)
|
||||
---
|
||||
buildtools/wafsamba/samba_autoconf.py | 36 ++++++++++++++-------------
|
||||
1 file changed, 19 insertions(+), 17 deletions(-)
|
||||
|
||||
diff --git a/buildtools/wafsamba/samba_autoconf.py b/buildtools/wafsamba/samba_autoconf.py
|
||||
index c4391d0c4dc..bfd6f9710db 100644
|
||||
--- a/buildtools/wafsamba/samba_autoconf.py
|
||||
+++ b/buildtools/wafsamba/samba_autoconf.py
|
||||
@@ -674,23 +674,25 @@ def SAMBA_CONFIG_H(conf, path=None):
|
||||
return
|
||||
|
||||
# we need to build real code that can't be optimized away to test
|
||||
- if conf.check(fragment='''
|
||||
- #include <stdio.h>
|
||||
-
|
||||
- int main(void)
|
||||
- {
|
||||
- char t[100000];
|
||||
- while (fgets(t, sizeof(t), stdin));
|
||||
- return 0;
|
||||
- }
|
||||
- ''',
|
||||
- execute=0,
|
||||
- ccflags='-fstack-protector',
|
||||
- ldflags='-fstack-protector',
|
||||
- mandatory=False,
|
||||
- msg='Checking if toolchain accepts -fstack-protector'):
|
||||
- conf.ADD_CFLAGS('-fstack-protector')
|
||||
- conf.ADD_LDFLAGS('-fstack-protector')
|
||||
+ stack_protect_list = ['-fstack-protector-strong', '-fstack-protector']
|
||||
+ for stack_protect_flag in stack_protect_list:
|
||||
+ flag_supported = conf.check(fragment='''
|
||||
+ #include <stdio.h>
|
||||
+
|
||||
+ int main(void)
|
||||
+ {
|
||||
+ char t[100000];
|
||||
+ while (fgets(t, sizeof(t), stdin));
|
||||
+ return 0;
|
||||
+ }
|
||||
+ ''',
|
||||
+ execute=0,
|
||||
+ ccflags=[ '-Werror', '-Wp,-D_FORTIFY_SOURCE=2', stack_protect_flag],
|
||||
+ mandatory=False,
|
||||
+ msg='Checking if compiler accepts %s' % (stack_protect_flag))
|
||||
+ if flag_supported:
|
||||
+ conf.ADD_CFLAGS('-Wp,-D_FORTIFY_SOURCE=2 %s' % (stack_protect_flag))
|
||||
+ break
|
||||
|
||||
if Options.options.debug:
|
||||
conf.ADD_CFLAGS('-g', testflags=True)
|
||||
--
|
||||
2.18.0
|
||||
|
||||
|
||||
From 09f3acb3497efb9ebb8a0d7d199726a8c318e4f8 Mon Sep 17 00:00:00 2001
|
||||
From: Andreas Schneider <asn@samba.org>
|
||||
Date: Mon, 3 Sep 2018 10:49:52 +0200
|
||||
Subject: [PATCH 2/2] waf: Add -fstack-clash-protection
|
||||
|
||||
https://developers.redhat.com/blog/2018/03/21/compiler-and-linker-flags-gcc/
|
||||
|
||||
BUG: https://bugzilla.samba.org/show_bug.cgi?id=13601
|
||||
|
||||
Signed-off-by: Andreas Schneider <asn@samba.org>
|
||||
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
|
||||
(cherry picked from commit fc4df251c88365142515a81bea1120b2b84cc4a0)
|
||||
---
|
||||
buildtools/wafsamba/samba_autoconf.py | 17 +++++++++++++++++
|
||||
1 file changed, 17 insertions(+)
|
||||
|
||||
diff --git a/buildtools/wafsamba/samba_autoconf.py b/buildtools/wafsamba/samba_autoconf.py
|
||||
index bfd6f9710db..f2b3ec8db8d 100644
|
||||
--- a/buildtools/wafsamba/samba_autoconf.py
|
||||
+++ b/buildtools/wafsamba/samba_autoconf.py
|
||||
@@ -694,6 +694,23 @@ def SAMBA_CONFIG_H(conf, path=None):
|
||||
conf.ADD_CFLAGS('-Wp,-D_FORTIFY_SOURCE=2 %s' % (stack_protect_flag))
|
||||
break
|
||||
|
||||
+ flag_supported = conf.check(fragment='''
|
||||
+ #include <stdio.h>
|
||||
+
|
||||
+ int main(void)
|
||||
+ {
|
||||
+ char t[100000];
|
||||
+ while (fgets(t, sizeof(t), stdin));
|
||||
+ return 0;
|
||||
+ }
|
||||
+ ''',
|
||||
+ execute=0,
|
||||
+ ccflags=[ '-Werror', '-fstack-clash-protection'],
|
||||
+ mandatory=False,
|
||||
+ msg='Checking if compiler accepts -fstack-clash-protection')
|
||||
+ if flag_supported:
|
||||
+ conf.ADD_CFLAGS('-fstack-clash-protection')
|
||||
+
|
||||
if Options.options.debug:
|
||||
conf.ADD_CFLAGS('-g', testflags=True)
|
||||
|
||||
--
|
||||
2.18.0
|
||||
|
@ -0,0 +1,6 @@ |
||||
-----BEGIN PGP SIGNATURE----- |
||||
|
||||
iFwEABECABwFAluomosVHHNhbWJhLWJ1Z3NAc2FtYmEub3JnAAoJEG8zkVtlaLfq |
||||
Ef0AoLUiZNu1bqD0YjbzI8KCisfwPF/2AKDGrFuyL4ds6Ege/OiUbg7krCXrOg== |
||||
=2NTz |
||||
-----END PGP SIGNATURE----- |
Binary file not shown.
@ -0,0 +1,7 @@ |
||||
/var/log/samba/* { |
||||
notifempty |
||||
olddir /var/log/samba/old |
||||
missingok |
||||
sharedscripts |
||||
copytruncate |
||||
} |
@ -0,0 +1,6 @@ |
||||
#%PAM-1.0 |
||||
auth required pam_nologin.so |
||||
auth include password-auth |
||||
account include password-auth |
||||
session include password-auth |
||||
password include password-auth |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,313 @@ |
||||
# This is the main Samba configuration file. For detailed information about the |
||||
# options listed here, refer to the smb.conf(5) manual page. Samba has a huge |
||||
# number of configurable options, most of which are not shown in this example. |
||||
# |
||||
# The Samba Wiki contains a lot of step-by-step guides installing, configuring, |
||||
# and using Samba: |
||||
# https://wiki.samba.org/index.php/User_Documentation |
||||
# |
||||
# In this file, lines starting with a semicolon (;) or a hash (#) are |
||||
# comments and are ignored. This file uses hashes to denote commentary and |
||||
# semicolons for parts of the file you may wish to configure. |
||||
# |
||||
# NOTE: Run the "testparm" command after modifying this file to check for basic |
||||
# syntax errors. |
||||
# |
||||
#--------------- |
||||
# Security-Enhanced Linux (SELinux) Notes: |
||||
# |
||||
# Turn the samba_domain_controller Boolean on to allow a Samba PDC to use the |
||||
# useradd and groupadd family of binaries. Run the following command as the |
||||
# root user to turn this Boolean on: |
||||
# setsebool -P samba_domain_controller on |
||||
# |
||||
# Turn the samba_enable_home_dirs Boolean on if you want to share home |
||||
# directories via Samba. Run the following command as the root user to turn this |
||||
# Boolean on: |
||||
# setsebool -P samba_enable_home_dirs on |
||||
# |
||||
# If you create a new directory, such as a new top-level directory, label it |
||||
# with samba_share_t so that SELinux allows Samba to read and write to it. Do |
||||
# not label system directories, such as /etc/ and /home/, with samba_share_t, as |
||||
# such directories should already have an SELinux label. |
||||
# |
||||
# Run the "ls -ldZ /path/to/directory" command to view the current SELinux |
||||
# label for a given directory. |
||||
# |
||||
# Set SELinux labels only on files and directories you have created. Use the |
||||
# chcon command to temporarily change a label: |
||||
# chcon -t samba_share_t /path/to/directory |
||||
# |
||||
# Changes made via chcon are lost when the file system is relabeled or commands |
||||
# such as restorecon are run. |
||||
# |
||||
# Use the samba_export_all_ro or samba_export_all_rw Boolean to share system |
||||
# directories. To share such directories and only allow read-only permissions: |
||||
# setsebool -P samba_export_all_ro on |
||||
# To share such directories and allow read and write permissions: |
||||
# setsebool -P samba_export_all_rw on |
||||
# |
||||
# To run scripts (preexec/root prexec/print command/...), copy them to the |
||||
# /var/lib/samba/scripts/ directory so that SELinux will allow smbd to run them. |
||||
# Note that if you move the scripts to /var/lib/samba/scripts/, they retain |
||||
# their existing SELinux labels, which may be labels that SELinux does not allow |
||||
# smbd to run. Copying the scripts will result in the correct SELinux labels. |
||||
# Run the "restorecon -R -v /var/lib/samba/scripts" command as the root user to |
||||
# apply the correct SELinux labels to these files. |
||||
# |
||||
#-------------- |
||||
# |
||||
#======================= Global Settings ===================================== |
||||
|
||||
[global] |
||||
|
||||
# ----------------------- Network-Related Options ------------------------- |
||||
# |
||||
# workgroup = the Windows NT domain name or workgroup name, for example, MYGROUP. |
||||
# |
||||
# server string = the equivalent of the Windows NT Description field. |
||||
# |
||||
# netbios name = used to specify a server name that is not tied to the hostname, |
||||
# maximum is 15 characters. |
||||
# |
||||
# interfaces = used to configure Samba to listen on multiple network interfaces. |
||||
# If you have multiple interfaces, you can use the "interfaces =" option to |
||||
# configure which of those interfaces Samba listens on. Never omit the localhost |
||||
# interface (lo). |
||||
# |
||||
# hosts allow = the hosts allowed to connect. This option can also be used on a |
||||
# per-share basis. |
||||
# |
||||
# hosts deny = the hosts not allowed to connect. This option can also be used on |
||||
# a per-share basis. |
||||
# |
||||
workgroup = MYGROUP |
||||
server string = Samba Server Version %v |
||||
|
||||
; netbios name = MYSERVER |
||||
|
||||
; interfaces = lo eth0 192.168.12.2/24 192.168.13.2/24 |
||||
; hosts allow = 127. 192.168.12. 192.168.13. |
||||
|
||||
# --------------------------- Logging Options ----------------------------- |
||||
# |
||||
# log file = specify where log files are written to and how they are split. |
||||
# |
||||
# max log size = specify the maximum size log files are allowed to reach. Log |
||||
# files are rotated when they reach the size specified with "max log size". |
||||
# |
||||
|
||||
# log files split per-machine: |
||||
log file = /var/log/samba/log.%m |
||||
# maximum size of 50KB per log file, then rotate: |
||||
max log size = 50 |
||||
|
||||
# ----------------------- Standalone Server Options ------------------------ |
||||
# |
||||
# security = the mode Samba runs in. This can be set to user, share |
||||
# (deprecated), or server (deprecated). |
||||
# |
||||
# passdb backend = the backend used to store user information in. New |
||||
# installations should use either tdbsam or ldapsam. No additional configuration |
||||
# is required for tdbsam. The "smbpasswd" utility is available for backwards |
||||
# compatibility. |
||||
# |
||||
|
||||
security = user |
||||
passdb backend = tdbsam |
||||
|
||||
|
||||
# ----------------------- Domain Members Options ------------------------ |
||||
# |
||||
# security = must be set to domain or ads. |
||||
# |
||||
# passdb backend = the backend used to store user information in. New |
||||
# installations should use either tdbsam or ldapsam. No additional configuration |
||||
# is required for tdbsam. The "smbpasswd" utility is available for backwards |
||||
# compatibility. |
||||
# |
||||
# realm = only use the realm option when the "security = ads" option is set. |
||||
# The realm option specifies the Active Directory realm the host is a part of. |
||||
# |
||||
# password server = only use this option when the "security = server" |
||||
# option is set, or if you cannot use DNS to locate a Domain Controller. The |
||||
# argument list can include My_PDC_Name, [My_BDC_Name], and [My_Next_BDC_Name]: |
||||
# |
||||
# password server = My_PDC_Name [My_BDC_Name] [My_Next_BDC_Name] |
||||
# |
||||
# Use "password server = *" to automatically locate Domain Controllers. |
||||
|
||||
; security = domain |
||||
; passdb backend = tdbsam |
||||
; realm = MY_REALM |
||||
|
||||
; password server = <NT-Server-Name> |
||||
|
||||
# ----------------------- Domain Controller Options ------------------------ |
||||
# |
||||
# security = must be set to user for domain controllers. |
||||
# |
||||
# passdb backend = the backend used to store user information in. New |
||||
# installations should use either tdbsam or ldapsam. No additional configuration |
||||
# is required for tdbsam. The "smbpasswd" utility is available for backwards |
||||
# compatibility. |
||||
# |
||||
# domain master = specifies Samba to be the Domain Master Browser, allowing |
||||
# Samba to collate browse lists between subnets. Do not use the "domain master" |
||||
# option if you already have a Windows NT domain controller performing this task. |
||||
# |
||||
# domain logons = allows Samba to provide a network logon service for Windows |
||||
# workstations. |
||||
# |
||||
# logon script = specifies a script to run at login time on the client. These |
||||
# scripts must be provided in a share named NETLOGON. |
||||
# |
||||
# logon path = specifies (with a UNC path) where user profiles are stored. |
||||
# |
||||
# |
||||
; security = user |
||||
; passdb backend = tdbsam |
||||
|
||||
; domain master = yes |
||||
; domain logons = yes |
||||
|
||||
# the following login script name is determined by the machine name |
||||
# (%m): |
||||
; logon script = %m.bat |
||||
# the following login script name is determined by the UNIX user used: |
||||
; logon script = %u.bat |
||||
; logon path = \\%L\Profiles\%u |
||||
# use an empty path to disable profile support: |
||||
; logon path = |
||||
|
||||
# various scripts can be used on a domain controller or a stand-alone |
||||
# machine to add or delete corresponding UNIX accounts: |
||||
|
||||
; add user script = /usr/sbin/useradd "%u" -n -g users |
||||
; add group script = /usr/sbin/groupadd "%g" |
||||
; add machine script = /usr/sbin/useradd -n -c "Workstation (%u)" -M -d /nohome -s /bin/false "%u" |
||||
; delete user script = /usr/sbin/userdel "%u" |
||||
; delete user from group script = /usr/sbin/userdel "%u" "%g" |
||||
; delete group script = /usr/sbin/groupdel "%g" |
||||
|
||||
|
||||
# ----------------------- Browser Control Options ---------------------------- |
||||
# |
||||
# local master = when set to no, Samba does not become the master browser on |
||||
# your network. When set to yes, normal election rules apply. |
||||
# |
||||
# os level = determines the precedence the server has in master browser |
||||
# elections. The default value should be reasonable. |
||||
# |
||||
# preferred master = when set to yes, Samba forces a local browser election at |
||||
# start up (and gives itself a slightly higher chance of winning the election). |
||||
# |
||||
; local master = no |
||||
; os level = 33 |
||||
; preferred master = yes |
||||
|
||||
#----------------------------- Name Resolution ------------------------------- |
||||
# |
||||
# This section details the support for the Windows Internet Name Service (WINS). |
||||
# |
||||
# Note: Samba can be either a WINS server or a WINS client, but not both. |
||||
# |
||||
# wins support = when set to yes, the NMBD component of Samba enables its WINS |
||||
# server. |
||||
# |
||||
# wins server = tells the NMBD component of Samba to be a WINS client. |
||||
# |
||||
# wins proxy = when set to yes, Samba answers name resolution queries on behalf |
||||
# of a non WINS capable client. For this to work, there must be at least one |
||||
# WINS server on the network. The default is no. |
||||
# |
||||
# dns proxy = when set to yes, Samba attempts to resolve NetBIOS names via DNS |
||||
# nslookups. |
||||
|
||||
; wins support = yes |
||||
; wins server = w.x.y.z |
||||
; wins proxy = yes |
||||
|
||||
; dns proxy = yes |
||||
|
||||
# --------------------------- Printing Options ----------------------------- |
||||
# |
||||
# The options in this section allow you to configure a non-default printing |
||||
# system. |
||||
# |
||||
# load printers = when set you yes, the list of printers is automatically |
||||
# loaded, rather than setting them up individually. |
||||
# |
||||
# cups options = allows you to pass options to the CUPS library. Setting this |
||||
# option to raw, for example, allows you to use drivers on your Windows clients. |
||||
# |
||||
# printcap name = used to specify an alternative printcap file. |
||||
# |
||||
|
||||
load printers = yes |
||||
cups options = raw |
||||
|
||||
; printcap name = /etc/printcap |
||||
# obtain a list of printers automatically on UNIX System V systems: |
||||
; printcap name = lpstat |
||||
; printing = cups |
||||
|
||||
# --------------------------- File System Options --------------------------- |
||||
# |
||||
# The options in this section can be un-commented if the file system supports |
||||
# extended attributes, and those attributes are enabled (usually via the |
||||
# "user_xattr" mount option). These options allow the administrator to specify |
||||
# that DOS attributes are stored in extended attributes and also make sure that |
||||
# Samba does not change the permission bits. |
||||
# |
||||
# Note: These options can be used on a per-share basis. Setting them globally |
||||
# (in the [global] section) makes them the default for all shares. |
||||
|
||||
; map archive = no |
||||
; map hidden = no |
||||
; map read only = no |
||||
; map system = no |
||||
; store dos attributes = yes |
||||
|
||||
|
||||
#============================ Share Definitions ============================== |
||||
|
||||
[homes] |
||||
comment = Home Directories |
||||
browseable = no |
||||
writable = yes |
||||
; valid users = %S |
||||
; valid users = MYDOMAIN\%S |
||||
|
||||
[printers] |
||||
comment = All Printers |
||||
path = /var/spool/samba |
||||
browseable = no |
||||
guest ok = no |
||||
writable = no |
||||
printable = yes |
||||
|
||||
# Un-comment the following and create the netlogon directory for Domain Logons: |
||||
; [netlogon] |
||||
; comment = Network Logon Service |
||||
; path = /var/lib/samba/netlogon |
||||
; guest ok = yes |
||||
; writable = no |
||||
; share modes = no |
||||
|
||||
# Un-comment the following to provide a specific roaming profile share. |
||||
# The default is to use the user's home directory: |
||||
; [Profiles] |
||||
; path = /var/lib/samba/profiles |
||||
; browseable = no |
||||
; guest ok = yes |
||||
|
||||
# A publicly accessible directory that is read only, except for users in the |
||||
# "staff" group (which have write permissions): |
||||
; [public] |
||||
; comment = Public Stuff |
||||
; path = /home/samba |
||||
; public = yes |
||||
; writable = no |
||||
; printable = no |
||||
; write list = +staff |
@ -0,0 +1,37 @@ |
||||
# See smb.conf.example for a more detailed config file or |
||||
# read the smb.conf manpage. |
||||
# Run 'testparm' to verify the config is correct after |
||||
# you modified it. |
||||
|
||||
[global] |
||||
workgroup = SAMBA |
||||
security = user |
||||
|
||||
passdb backend = tdbsam |
||||
|
||||
printing = cups |
||||
printcap name = cups |
||||
load printers = yes |
||||
cups options = raw |
||||
|
||||
[homes] |
||||
comment = Home Directories |
||||
valid users = %S, %D%w%S |
||||
browseable = No |
||||
read only = No |
||||
inherit acls = Yes |
||||
|
||||
[printers] |
||||
comment = All Printers |
||||
path = /var/tmp |
||||
printable = Yes |
||||
create mask = 0600 |
||||
browseable = No |
||||
|
||||
[print$] |
||||
comment = Printer Drivers |
||||
path = /var/lib/samba/drivers |
||||
write list = @printadmin root |
||||
force group = @printadmin |
||||
create mask = 0664 |
||||
directory mask = 0775 |
Loading…
Reference in new issue