mirror of
https://github.com/clinton-hall/nzbToMedia.git
synced 2025-07-05 20:51:11 -07:00
Add comments.
This commit is contained in:
parent
6e52bb2b33
commit
2c2d7f24b1
2 changed files with 28 additions and 4 deletions
|
@ -82,7 +82,7 @@ class DBConnection(object):
|
|||
" Mode : {1}\n"
|
||||
" Owner: {2}\n"
|
||||
" Group: {3}\n"
|
||||
"===========================================".format(path, mode[-3:], owner, group),
|
||||
"===========================================".format(path, mode, owner, group),
|
||||
)
|
||||
else:
|
||||
self.connection.row_factory = Row
|
||||
|
|
|
@ -28,36 +28,60 @@ except ImportError:
|
|||
|
||||
def mode(path):
|
||||
"""Get permissions."""
|
||||
return oct(os.stat(path).st_mode & 0o777)
|
||||
stat_result = os.stat(path) # Get information from path
|
||||
permissions_mask = 0o777 # Set mask for permissions info
|
||||
|
||||
# Get only the permissions part of st_mode as an integer
|
||||
int_mode = stat_result.st_mode & permissions_mask
|
||||
oct_mode = oct(int_mode) # Convert to octal representation
|
||||
|
||||
return oct_mode[2:] # Return mode but strip octal prefix
|
||||
|
||||
|
||||
def nt_ownership(path):
|
||||
"""Get the owner and group for a file or directory."""
|
||||
def fully_qualified_name(sid):
|
||||
"""Return a fully qualified account name."""
|
||||
# Look up the account information for the given SID
|
||||
# https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-lookupaccountsida
|
||||
name, domain, _acct_type = LookupAccountSid(None, sid)
|
||||
# Return account information formatted as DOMAIN\ACCOUNT_NAME
|
||||
return '{}\\{}'.format(domain, name)
|
||||
|
||||
# Get the Windows security descriptor for the path
|
||||
# https://learn.microsoft.com/en-us/windows/win32/api/aclapi/nf-aclapi-getnamedsecurityinfoa
|
||||
security_descriptor = GetNamedSecurityInfo(
|
||||
os.fspath(path),
|
||||
SE_FILE_OBJECT,
|
||||
path, # Name of the item to query
|
||||
SE_FILE_OBJECT, # Type of item to query (file or directory)
|
||||
# Add OWNER and GROUP security information to result
|
||||
OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION,
|
||||
)
|
||||
# Get the Security Identifier for the owner and group from the security descriptor
|
||||
# https://learn.microsoft.com/en-us/windows/win32/api/securitybaseapi/nf-securitybaseapi-getsecuritydescriptorowner
|
||||
# https://learn.microsoft.com/en-us/windows/win32/api/securitybaseapi/nf-securitybaseapi-getsecuritydescriptorgroup
|
||||
owner_sid = security_descriptor.GetSecurityDescriptorOwner()
|
||||
group_sid = security_descriptor.GetSecurityDescriptorGroup()
|
||||
|
||||
# Get the fully qualified account name (e.g. DOMAIN\ACCOUNT_NAME)
|
||||
owner = fully_qualified_name(owner_sid)
|
||||
group = fully_qualified_name(group_sid)
|
||||
|
||||
return owner, group
|
||||
|
||||
|
||||
def posix_ownership(path):
|
||||
"""Get the owner and group for a file or directory."""
|
||||
# Get path information
|
||||
stat_result = os.stat(path)
|
||||
|
||||
# Get account name from path stat result
|
||||
owner = pwd.getpwuid(stat_result.st_uid)
|
||||
group = grp.getgrgid(stat_result.st_gid)
|
||||
|
||||
return owner, group
|
||||
|
||||
|
||||
# Select the ownership function appropriate for the platform
|
||||
if WINDOWS:
|
||||
ownership = nt_ownership
|
||||
else:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue