|
|
|
@ -60,3 +60,18 @@ class Samba(object):
|
|
|
|
|
if m:
|
|
|
|
|
return m.group(1)
|
|
|
|
|
raise SambaError(_("Failed to determine domain name on %s") % host)
|
|
|
|
|
|
|
|
|
|
def password_check(self, username, password, server, resource, domain=None):
|
|
|
|
|
"""
|
|
|
|
|
Подключиться к указанному samba ресурсу сервера по логину паролю
|
|
|
|
|
"""
|
|
|
|
|
if not domain:
|
|
|
|
|
domain = self.get_server_domainname(server)
|
|
|
|
|
|
|
|
|
|
smbclient = getProgPath('/usr/sbin/smbclient')
|
|
|
|
|
if not smbclient:
|
|
|
|
|
raise SambaError(_("%s command not found") % "smbclient")
|
|
|
|
|
p = process(smbclient, "-c", "ls", "-U", r"%s\%s"%(domain,username),
|
|
|
|
|
"//%s/%s" % (server, resource),
|
|
|
|
|
envdict={'PASSWD': password})
|
|
|
|
|
return p.success()
|
|
|
|
|