mirror of
https://github.com/samba-team/samba.git
synced 2025-02-02 09:47:23 +03:00
samba-tool: Move smb_connection to a common file
This is in preparation for needing it here later. Signed-off-by: David Mulder <dmulder@samba.org> Reviewed-by: Andrew Bartlett <abartlet@samba.org>
This commit is contained in:
parent
d6194600c1
commit
a0f8d7ca05
@ -16,6 +16,10 @@
|
|||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
from samba.credentials import SMB_SIGNING_REQUIRED
|
||||||
|
from samba.samba3 import param as s3param
|
||||||
|
from samba.samba3 import libsmb_samba_internal as libsmb
|
||||||
|
from samba.netcmd import CommandError
|
||||||
|
|
||||||
def create_directory_hier(conn, remotedir):
|
def create_directory_hier(conn, remotedir):
|
||||||
elems = remotedir.replace('/', '\\').split('\\')
|
elems = remotedir.replace('/', '\\').split('\\')
|
||||||
@ -24,3 +28,19 @@ def create_directory_hier(conn, remotedir):
|
|||||||
path = path + '\\' + e
|
path = path + '\\' + e
|
||||||
if not conn.chkpath(path):
|
if not conn.chkpath(path):
|
||||||
conn.mkdir(path)
|
conn.mkdir(path)
|
||||||
|
|
||||||
|
def smb_connection(dc_hostname, service, lp, creds):
|
||||||
|
# SMB connect to DC
|
||||||
|
# Force signing for the smb connection
|
||||||
|
saved_signing_state = creds.get_smb_signing()
|
||||||
|
creds.set_smb_signing(SMB_SIGNING_REQUIRED)
|
||||||
|
try:
|
||||||
|
# the SMB bindings rely on having a s3 loadparm
|
||||||
|
s3_lp = s3param.get_context()
|
||||||
|
s3_lp.load(lp.configfile)
|
||||||
|
conn = libsmb.Conn(dc_hostname, service, lp=s3_lp, creds=creds)
|
||||||
|
except Exception:
|
||||||
|
raise CommandError("Error connecting to '%s' using SMB" % dc_hostname)
|
||||||
|
# Reset signing state
|
||||||
|
creds.set_smb_signing(saved_signing_state)
|
||||||
|
return conn
|
||||||
|
@ -43,7 +43,6 @@ import samba.auth
|
|||||||
from samba.auth import AUTH_SESSION_INFO_DEFAULT_GROUPS, AUTH_SESSION_INFO_AUTHENTICATED, AUTH_SESSION_INFO_SIMPLE_PRIVILEGES
|
from samba.auth import AUTH_SESSION_INFO_DEFAULT_GROUPS, AUTH_SESSION_INFO_AUTHENTICATED, AUTH_SESSION_INFO_SIMPLE_PRIVILEGES
|
||||||
from samba.netcmd.common import netcmd_finddc
|
from samba.netcmd.common import netcmd_finddc
|
||||||
from samba import policy
|
from samba import policy
|
||||||
from samba.samba3 import param as s3param
|
|
||||||
from samba.samba3 import libsmb_samba_internal as libsmb
|
from samba.samba3 import libsmb_samba_internal as libsmb
|
||||||
from samba import NTSTATUSError
|
from samba import NTSTATUSError
|
||||||
import uuid
|
import uuid
|
||||||
@ -62,7 +61,6 @@ from samba.gp_parse.gp_csv import GPAuditCsvParser
|
|||||||
from samba.gp_parse.gp_inf import GptTmplInfParser
|
from samba.gp_parse.gp_inf import GptTmplInfParser
|
||||||
from samba.gp_parse.gp_aas import GPAasParser
|
from samba.gp_parse.gp_aas import GPAasParser
|
||||||
from samba import param
|
from samba import param
|
||||||
from samba.credentials import SMB_SIGNING_REQUIRED
|
|
||||||
from samba.netcmd.common import attr_default
|
from samba.netcmd.common import attr_default
|
||||||
from samba.common import get_bytes, get_string
|
from samba.common import get_bytes, get_string
|
||||||
from configparser import ConfigParser
|
from configparser import ConfigParser
|
||||||
@ -77,7 +75,7 @@ from samba.ntstatus import (
|
|||||||
NT_STATUS_OBJECT_PATH_NOT_FOUND,
|
NT_STATUS_OBJECT_PATH_NOT_FOUND,
|
||||||
NT_STATUS_ACCESS_DENIED
|
NT_STATUS_ACCESS_DENIED
|
||||||
)
|
)
|
||||||
from samba.netcmd.gpcommon import create_directory_hier
|
from samba.netcmd.gpcommon import create_directory_hier, smb_connection
|
||||||
|
|
||||||
|
|
||||||
def gpo_flags_string(value):
|
def gpo_flags_string(value):
|
||||||
@ -383,23 +381,6 @@ def copy_directory_local_to_remote(conn, localdir, remotedir,
|
|||||||
conn.savefile(r_name, data)
|
conn.savefile(r_name, data)
|
||||||
|
|
||||||
|
|
||||||
def smb_connection(dc_hostname, service, lp, creds):
|
|
||||||
# SMB connect to DC
|
|
||||||
# Force signing for the smb connection
|
|
||||||
saved_signing_state = creds.get_smb_signing()
|
|
||||||
creds.set_smb_signing(SMB_SIGNING_REQUIRED)
|
|
||||||
try:
|
|
||||||
# the SMB bindings rely on having a s3 loadparm
|
|
||||||
s3_lp = s3param.get_context()
|
|
||||||
s3_lp.load(lp.configfile)
|
|
||||||
conn = libsmb.Conn(dc_hostname, service, lp=s3_lp, creds=creds)
|
|
||||||
except Exception:
|
|
||||||
raise CommandError("Error connecting to '%s' using SMB" % dc_hostname)
|
|
||||||
# Reset signing state
|
|
||||||
creds.set_smb_signing(saved_signing_state)
|
|
||||||
return conn
|
|
||||||
|
|
||||||
|
|
||||||
class GPOCommand(Command):
|
class GPOCommand(Command):
|
||||||
def construct_tmpdir(self, tmpdir, gpo):
|
def construct_tmpdir(self, tmpdir, gpo):
|
||||||
"""Ensure that the temporary directory structure used in fetch,
|
"""Ensure that the temporary directory structure used in fetch,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user