diff --git a/libufps/ufps.py b/libufps/ufps.py index 724a3bf..bb64d04 100644 --- a/libufps/ufps.py +++ b/libufps/ufps.py @@ -173,10 +173,12 @@ class ufps: """ realpath = self.basedir+path + # Get file user id and group id stats = os.stat(realpath) uid = stats.st_uid gid = stats.st_gid + # Turn the funny numbers we just got into names. ownername = pwd.getpwuid(stats.st_uid).pw_name groupname = grp.getgrgid(stats.st_gid).gr_name @@ -206,18 +208,24 @@ class ufps: outputIndex = "" realpath = self.basedir+path + # The magic prinf sauce makes it so the command returns only relative paths. + # For example: test/testdir instead of ./path/to/test/testdir findCommand = "find " + realpath + " -printf '%P\n'" + # Run the find command and turn it into a list. fileList = subprocess.check_output(findCommand, shell=True, text=True) fileList = fileList.split('\n') # Remove tailing newline which causes the root directory to be indexed twice. fileList = fileList[:-1] + # For every item in the list, we get it's permissions and owner/group info. for p in fileList: pPerms, pIsDir, pIsLink, pLinkTarget = self.getFilePermissions(p) ownername, groupname = self.getFileOwner(p) + # Stanardized table entry for ufps indexes. + # Future additions get added to the end. D_userFriendlyString = pPerms + " | " + ownername + " | " + groupname + " | " + str(pIsDir) + " | " + str(pIsLink) + " | " + p + " | " + str(pLinkTarget) + "\n" outputIndex+=D_userFriendlyString @@ -239,20 +247,28 @@ class ufps: :rtype results: str """ realpath = self.basedir+path - print(realpath) results = "" + + # Read index file into variable and split it into an array. + # At this point, we have a variable that's exactly the same as it was at the + # time of index creation. file = open(index) idx = file.read() file.close() - idx = idx.split('\n') - for p in idx: - indexEntry = p.split(' | ') - print(indexEntry) - indexRealPath = realpath + indexEntry[self.I_IPATH] - permsToSet = int(indexEntry[self.I_PERMS], base=8) - pathExists = os.path.exists(indexRealPath) + # For every entry in the index... + for p in idx: + # Split the entry into a list. + indexEntry = p.split(' | ') + + # Then get the real path of the indexed file, figure out if it exists, + # and get the entry's permissions. + indexRealPath = realpath + indexEntry[self.I_IPATH] + pathExists = os.path.exists(indexRealPath) + permsToSet = int(indexEntry[self.I_PERMS], base=8) + + # If the path doesn't exist, we log this. Otherwise, set the permissions. if pathExists: os.chmod(indexRealPath, permsToSet) else: