Browse Source
* list files add cols and sort * bug * day subset * add listcontent.py * parentfolderudi * add folder path * print root folders * remove folders from output + verbose * path to item verbose Co-authored-by: cloud-user <cloud-user@race.sas.com>master
committed by
GitHub
3 changed files with 176 additions and 23 deletions
@ -0,0 +1,142 @@ |
|||
#!/usr/bin/python |
|||
# -*- coding: utf-8 -*- |
|||
# |
|||
# listcontent.py |
|||
# february 2018 |
|||
# |
|||
# Pass in a folder path and list content |
|||
# Change History |
|||
|
|||
# |
|||
# Copyright © 2018, SAS Institute Inc., Cary, NC, USA. All Rights Reserved. |
|||
# |
|||
# Licensed under the Apache License, Version 2.0 (the License); |
|||
# you may not use this file except in compliance with the License. |
|||
# You may obtain a copy of the License at |
|||
# |
|||
# http://www.apache.org/licenses/LICENSE-2.0 |
|||
# |
|||
# Unless required by applicable law or agreed to in writing, software |
|||
# distributed under the License is distributed on an "AS IS" BASIS, |
|||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|||
# See the License for the specific language governing permissions and |
|||
# limitations under the License. |
|||
# |
|||
|
|||
# Import Python modules |
|||
|
|||
import argparse, sys |
|||
|
|||
from sharedfunctions import getfolderid, callrestapi, printresult, getfolderid, getidsanduris, getpath, json |
|||
from datetime import datetime as dt, timedelta as td |
|||
|
|||
# get python version |
|||
version=int(str(sys.version_info[0])) |
|||
|
|||
# get input parameters |
|||
parser = argparse.ArgumentParser(description="List folder and its sub-folders and content.") |
|||
parser.add_argument("-f","--folderpath", help="Enter the path to the viya folder to start the listing.",required='True') |
|||
parser.add_argument("-v","--verbosecsv", help="Verbose CSV(only used with -o=csv) ", action='store_true' ) |
|||
parser.add_argument("-o","--output", help="Output Style", choices=['csv','json','simple','simplejson'],default='json') |
|||
parser.add_argument("--debug", action='store_true', help="Debug") |
|||
|
|||
args = parser.parse_args() |
|||
debug=args.debug |
|||
path_to_folder=args.folderpath |
|||
verbosecsv=args.verbosecsv |
|||
output_style=args.output |
|||
|
|||
delimiter = ',' |
|||
|
|||
if verbosecsv: cols=cols=["id","pathtoitem","name","type","contentType","description","typeDefName","documentType","contentDisposition","fileStatus","searchable","size","createdBy","creationTimeStamp","modifiedBy","modifiedTimeStamp","expirationTimeStamp","encoding","parentUri"] |
|||
else: cols=["id","pathtoitem","name","contentType","createdBy","creationTimeStamp","modifiedBy","modifiedTimeStamp","uri"] |
|||
|
|||
def getfoldercontent(path_to_folder): |
|||
|
|||
# call getfolderid to get the folder id |
|||
targets=getfolderid(path_to_folder) |
|||
|
|||
#if debug: print(targets) |
|||
|
|||
# if the folder is found |
|||
if targets[0] is not None: |
|||
|
|||
uri=targets[1] |
|||
|
|||
#get folder content, recursive call returns all children |
|||
reqval=uri+"/members?recursive=true&limit=100000" |
|||
reqtype='get' |
|||
|
|||
if debug: print(reqval) |
|||
folders_result_json=callrestapi(reqval,reqtype) |
|||
|
|||
# add a loop of folder result that adds the parent folder path |
|||
# add the path back into the json for printing |
|||
total_items=folders_result_json['count'] |
|||
itemlist=folders_result_json['items'] |
|||
returned_items=len(itemlist) |
|||
|
|||
for i in range(0,returned_items): |
|||
|
|||
contenttype=itemlist[i]["contentType"] |
|||
itemuri=itemlist[i]["uri"] |
|||
name=itemlist[i]["name"] |
|||
|
|||
parentFolderUri=itemlist[i]["parentFolderUri"] |
|||
path_to_item=getpath(itemuri) |
|||
|
|||
itemlist[i]["pathtoitem"]=path_to_item |
|||
itemlist[i]["pathanditemname"]=path_to_item+name |
|||
#print(path_to_item,name,contenttype) |
|||
|
|||
newitems = [ ] |
|||
|
|||
# remove folders |
|||
for i in range(0,returned_items): |
|||
|
|||
if folders_result_json['items'][i]["contentType"]!="folder": |
|||
newitems.append(folders_result_json['items'][i]) |
|||
|
|||
folders_result_json["count"]=len(newitems) |
|||
folders_result_json["items"]=newitems |
|||
|
|||
return folders_result_json |
|||
|
|||
# root folder, loop sub-folders and print |
|||
if path_to_folder=="/": |
|||
|
|||
# get a list of root folders |
|||
|
|||
# get the json result for each one |
|||
|
|||
# append them together for printing |
|||
|
|||
reqval='/folders/rootFolders' |
|||
reqtype='get' |
|||
rootfolderresult=callrestapi(reqval,reqtype) |
|||
rootfolders=rootfolderresult["items"] |
|||
|
|||
z=0 |
|||
|
|||
for folder in rootfolders: |
|||
|
|||
foldername="/"+folder["name"] |
|||
result_json=getfoldercontent(foldername) |
|||
|
|||
content_count=result_json['count'] |
|||
|
|||
# print if there is content in the folder |
|||
if content_count: |
|||
|
|||
# printer header only for the first group |
|||
if z==0: printresult(result_json,output_style,cols) |
|||
else: printresult(result_json,output_style,cols,header=0) |
|||
z=z+1 |
|||
|
|||
else: |
|||
|
|||
# print folder content |
|||
result_json=getfoldercontent(path_to_folder) |
|||
printresult(result_json,output_style,cols) |
|||
|
|||
|
|||
Loading…
Reference in new issue