mirror of
https://github.com/GAM-team/GAM.git
synced 2025-07-05 12:13:34 +00:00
Fixed bug in gam <UserTypeEntity> print filelist ... countsrowfilter
Some checks are pending
Build and test GAM / build (Win64, build, 8, VC-WIN64A, windows-2022) (push) Waiting to run
Build and test GAM / build (aarch64, build, 2, linux-aarch64, [self-hosted linux arm64]) (push) Waiting to run
Build and test GAM / build (aarch64, build, 4, linux-aarch64, [self-hosted linux arm64], yes) (push) Waiting to run
Build and test GAM / build (aarch64, build, 6, darwin64-arm64, macos-14) (push) Waiting to run
Build and test GAM / build (universal2, build, 7, darwin64-arm64 darwin64-x86_64, macos-14) (push) Waiting to run
Build and test GAM / build (x86_64, build, 1, linux-x86_64, ubuntu-20.04) (push) Waiting to run
Build and test GAM / build (x86_64, build, 3, linux-x86_64, ubuntu-20.04, yes) (push) Waiting to run
Build and test GAM / build (x86_64, build, 5, darwin64-x86_64, macos-12) (push) Waiting to run
Build and test GAM / build (x86_64, test, 10, ubuntu-22.04, 3.9) (push) Waiting to run
Build and test GAM / build (x86_64, test, 11, ubuntu-22.04, 3.10) (push) Waiting to run
Build and test GAM / build (x86_64, test, 12, ubuntu-22.04, 3.11) (push) Waiting to run
Build and test GAM / build (x86_64, test, 9, ubuntu-22.04, 3.8) (push) Waiting to run
Build and test GAM / merge (push) Blocked by required conditions
Build and test GAM / publish (push) Blocked by required conditions
CodeQL / Analyze (python) (push) Waiting to run
Check for Google Root CA Updates / check-apis (push) Waiting to run
Some checks are pending
Build and test GAM / build (Win64, build, 8, VC-WIN64A, windows-2022) (push) Waiting to run
Build and test GAM / build (aarch64, build, 2, linux-aarch64, [self-hosted linux arm64]) (push) Waiting to run
Build and test GAM / build (aarch64, build, 4, linux-aarch64, [self-hosted linux arm64], yes) (push) Waiting to run
Build and test GAM / build (aarch64, build, 6, darwin64-arm64, macos-14) (push) Waiting to run
Build and test GAM / build (universal2, build, 7, darwin64-arm64 darwin64-x86_64, macos-14) (push) Waiting to run
Build and test GAM / build (x86_64, build, 1, linux-x86_64, ubuntu-20.04) (push) Waiting to run
Build and test GAM / build (x86_64, build, 3, linux-x86_64, ubuntu-20.04, yes) (push) Waiting to run
Build and test GAM / build (x86_64, build, 5, darwin64-x86_64, macos-12) (push) Waiting to run
Build and test GAM / build (x86_64, test, 10, ubuntu-22.04, 3.9) (push) Waiting to run
Build and test GAM / build (x86_64, test, 11, ubuntu-22.04, 3.10) (push) Waiting to run
Build and test GAM / build (x86_64, test, 12, ubuntu-22.04, 3.11) (push) Waiting to run
Build and test GAM / build (x86_64, test, 9, ubuntu-22.04, 3.8) (push) Waiting to run
Build and test GAM / merge (push) Blocked by required conditions
Build and test GAM / publish (push) Blocked by required conditions
CodeQL / Analyze (python) (push) Waiting to run
Check for Google Root CA Updates / check-apis (push) Waiting to run
This commit is contained in:
@ -10,6 +10,17 @@ Add the `-s` option to the end of the above commands to suppress creating the `g
|
|||||||
|
|
||||||
See [Downloads-Installs](https://github.com/taers232c/GAMADV-XTD3/wiki/Downloads-Installs) for Windows or other options, including manual installation
|
See [Downloads-Installs](https://github.com/taers232c/GAMADV-XTD3/wiki/Downloads-Installs) for Windows or other options, including manual installation
|
||||||
|
|
||||||
|
### 6.80.15
|
||||||
|
|
||||||
|
Fixed bug in `gam <UserTypeEntity> print filelist ... countsrowfilter` that caused a trap.
|
||||||
|
|
||||||
|
Added option `continueoninvalidquery [<Boolean>]` to `gam <UserTypeEntity> print filelist|filecounts` that can be used
|
||||||
|
in special cases where a query of the form `query "'labels/mRoha85IbwCRl490E00xGLvBsSbkwIiuZ6PRNNEbwxyz' in labels"
|
||||||
|
causes Google to issue an error saying that the query is invalid when, in fact, it is but the user does not have a
|
||||||
|
license that suppprts drive file labels. When `continueoninvalidquery` is true, GAM prints an error message and
|
||||||
|
proceeds to the next user rather that terminating as it does now. Of course, if the query really is invalid, you will
|
||||||
|
get the message for every user.
|
||||||
|
|
||||||
### 6.80.14
|
### 6.80.14
|
||||||
|
|
||||||
Updated `gam <UserTypeEntity> print messages|threads` to display all default headers
|
Updated `gam <UserTypeEntity> print messages|threads` to display all default headers
|
||||||
|
@ -251,7 +251,7 @@ writes the credentials into the file oauth2.txt.
|
|||||||
admin@server:/Users/admin$ rm -f /Users/admin/GAMConfig/oauth2.txt
|
admin@server:/Users/admin$ rm -f /Users/admin/GAMConfig/oauth2.txt
|
||||||
admin@server:/Users/admin$ gam version
|
admin@server:/Users/admin$ gam version
|
||||||
WARNING: Config File: /Users/admin/GAMConfig/gam.cfg, Section: DEFAULT, Item: oauth2_txt, Value: /Users/admin/GAMConfig/oauth2.txt, Not Found
|
WARNING: Config File: /Users/admin/GAMConfig/gam.cfg, Section: DEFAULT, Item: oauth2_txt, Value: /Users/admin/GAMConfig/oauth2.txt, Not Found
|
||||||
GAMADV-XTD3 6.80.14 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
GAMADV-XTD3 6.80.15 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
||||||
Ross Scroggs <ross.scroggs@gmail.com>
|
Ross Scroggs <ross.scroggs@gmail.com>
|
||||||
Python 3.12.5 64-bit final
|
Python 3.12.5 64-bit final
|
||||||
MacOS Sonoma 14.5 x86_64
|
MacOS Sonoma 14.5 x86_64
|
||||||
@ -923,7 +923,7 @@ writes the credentials into the file oauth2.txt.
|
|||||||
C:\>del C:\GAMConfig\oauth2.txt
|
C:\>del C:\GAMConfig\oauth2.txt
|
||||||
C:\>gam version
|
C:\>gam version
|
||||||
WARNING: Config File: C:\GAMConfig\gam.cfg, Section: DEFAULT, Item: oauth2_txt, Value: C:\GAMConfig\oauth2.txt, Not Found
|
WARNING: Config File: C:\GAMConfig\gam.cfg, Section: DEFAULT, Item: oauth2_txt, Value: C:\GAMConfig\oauth2.txt, Not Found
|
||||||
GAMADV-XTD3 6.80.14 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
GAMADV-XTD3 6.80.15 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
||||||
Ross Scroggs <ross.scroggs@gmail.com>
|
Ross Scroggs <ross.scroggs@gmail.com>
|
||||||
Python 3.12.5 64-bit final
|
Python 3.12.5 64-bit final
|
||||||
Windows-10-10.0.17134 AMD64
|
Windows-10-10.0.17134 AMD64
|
||||||
|
@ -684,6 +684,7 @@ Print or show file counts by MIME type and/or file name.
|
|||||||
gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
||||||
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
||||||
(querytime<String> <Time>)*]
|
(querytime<String> <Time>)*]
|
||||||
|
[continueoninvalidquery [<Boolean>]]
|
||||||
[corpora <CorporaAttribute>]
|
[corpora <CorporaAttribute>]
|
||||||
[select <SharedDriveEntity>]
|
[select <SharedDriveEntity>]
|
||||||
[anyowner|(showownedby any|me|others)]
|
[anyowner|(showownedby any|me|others)]
|
||||||
@ -697,6 +698,7 @@ gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
|||||||
gam <UserTypeEntity> show filecounts
|
gam <UserTypeEntity> show filecounts
|
||||||
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
||||||
(querytime<String> <Time>)*]
|
(querytime<String> <Time>)*]
|
||||||
|
[continueoninvalidquery [<Boolean>]]
|
||||||
[corpora <CorporaAttribute>]
|
[corpora <CorporaAttribute>]
|
||||||
[select <SharedDriveEntity>]
|
[select <SharedDriveEntity>]
|
||||||
[anyowner|(showownedby any|me|others)]
|
[anyowner|(showownedby any|me|others)]
|
||||||
@ -711,6 +713,12 @@ gam <UserTypeEntity> show filecounts
|
|||||||
|
|
||||||
By default, print filecounts displays counts of all files owned by the specified [`<UserTypeEntity>`](Collections-of-Users).
|
By default, print filecounts displays counts of all files owned by the specified [`<UserTypeEntity>`](Collections-of-Users).
|
||||||
|
|
||||||
|
The option `continueoninvalidquery [<Boolean>] can be used in special cases where a query of the form
|
||||||
|
`query "'labels/mRoha85IbwCRl490E00xGLvBsSbkwIiuZ6PRNNEbwxyz' in labels" causes Google to issue an error
|
||||||
|
saying that the query is invalid when, in fact, it is but the user does not have a license that suppprts drive file labels.
|
||||||
|
When `continueoninvalidquery` is true, GAM prints an error message and proceeds to the next user rather that terminating
|
||||||
|
as it does now. Of course, if the query really is invalid, you will get the message for every user.
|
||||||
|
|
||||||
The `showsize` option displays the total size (in bytes) of the files counted.
|
The `showsize` option displays the total size (in bytes) of the files counted.
|
||||||
|
|
||||||
The showmimetypesize' displays the total size (in bytes) of each MIME type counted.
|
The showmimetypesize' displays the total size (in bytes) of each MIME type counted.
|
||||||
@ -1035,6 +1043,7 @@ Display a list of file/folder details in CSV format.
|
|||||||
gam <UserTypeEntity> print|show filelist [todrive <ToDriveAttribute>*]
|
gam <UserTypeEntity> print|show filelist [todrive <ToDriveAttribute>*]
|
||||||
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
||||||
(querytime<String> <Time>)*]
|
(querytime<String> <Time>)*]
|
||||||
|
[continueoninvalidquery [<Boolean>]]
|
||||||
[choose <DriveFileNameEntity>|<DriveFileEntityShortcut>]
|
[choose <DriveFileNameEntity>|<DriveFileEntityShortcut>]
|
||||||
[corpora <CorporaAttribute>]
|
[corpora <CorporaAttribute>]
|
||||||
[select <DriveFileEntity> [selectsubquery <QueryDriveFile>]
|
[select <DriveFileEntity> [selectsubquery <QueryDriveFile>]
|
||||||
@ -1061,6 +1070,12 @@ gam <UserTypeEntity> print|show filelist [todrive <ToDriveAttribute>*]
|
|||||||
```
|
```
|
||||||
By default, `print filelist` displays all files owned by the specified [`<UserTypeEntity>`](https://github.com/taers232c/GAMADV-XTD3/wiki/Collections-of-Users)
|
By default, `print filelist` displays all files owned by the specified [`<UserTypeEntity>`](https://github.com/taers232c/GAMADV-XTD3/wiki/Collections-of-Users)
|
||||||
|
|
||||||
|
The option `continueoninvalidquery [<Boolean>] can be used in special cases where a query of the form
|
||||||
|
`query "'labels/mRoha85IbwCRl490E00xGLvBsSbkwIiuZ6PRNNEbwxyz' in labels" causes Google to issue an error
|
||||||
|
saying that the query is invalid when, in fact, it is but the user does not have a license that suppprts drive file labels.
|
||||||
|
When `continueoninvalidquery` is true, GAM prints an error message and proceeds to the next user rather that terminating
|
||||||
|
as it does now. Of course, if the query really is invalid, you will get the message for every user.
|
||||||
|
|
||||||
When `allfields` is specified (or no fields are specified), use `showshareddrivepermissions` to display permissions
|
When `allfields` is specified (or no fields are specified), use `showshareddrivepermissions` to display permissions
|
||||||
when shared drives are queried/selected. In this case, the Drive API returns the permission IDs
|
when shared drives are queried/selected. In this case, the Drive API returns the permission IDs
|
||||||
but not the permissions themselves so GAM makes an additional API call per file to get the permissions.
|
but not the permissions themselves so GAM makes an additional API call per file to get the permissions.
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
Print the current version of Gam with details
|
Print the current version of Gam with details
|
||||||
```
|
```
|
||||||
gam version
|
gam version
|
||||||
GAMADV-XTD3 6.80.14 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
GAMADV-XTD3 6.80.15 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
||||||
Ross Scroggs <ross.scroggs@gmail.com>
|
Ross Scroggs <ross.scroggs@gmail.com>
|
||||||
Python 3.12.5 64-bit final
|
Python 3.12.5 64-bit final
|
||||||
MacOS Sonoma 14.5 x86_64
|
MacOS Sonoma 14.5 x86_64
|
||||||
@ -15,7 +15,7 @@ Time: 2023-06-02T21:10:00-07:00
|
|||||||
Print the current version of Gam with details and time offset information
|
Print the current version of Gam with details and time offset information
|
||||||
```
|
```
|
||||||
gam version timeoffset
|
gam version timeoffset
|
||||||
GAMADV-XTD3 6.80.14 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
GAMADV-XTD3 6.80.15 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
||||||
Ross Scroggs <ross.scroggs@gmail.com>
|
Ross Scroggs <ross.scroggs@gmail.com>
|
||||||
Python 3.12.5 64-bit final
|
Python 3.12.5 64-bit final
|
||||||
MacOS Sonoma 14.5 x86_64
|
MacOS Sonoma 14.5 x86_64
|
||||||
@ -27,7 +27,7 @@ Your system time differs from www.googleapis.com by less than 1 second
|
|||||||
Print the current version of Gam with extended details and SSL information
|
Print the current version of Gam with extended details and SSL information
|
||||||
```
|
```
|
||||||
gam version extended
|
gam version extended
|
||||||
GAMADV-XTD3 6.80.14 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
GAMADV-XTD3 6.80.15 - https://github.com/taers232c/GAMADV-XTD3 - pythonsource
|
||||||
Ross Scroggs <ross.scroggs@gmail.com>
|
Ross Scroggs <ross.scroggs@gmail.com>
|
||||||
Python 3.12.5 64-bit final
|
Python 3.12.5 64-bit final
|
||||||
MacOS Sonoma 14.5 x86_64
|
MacOS Sonoma 14.5 x86_64
|
||||||
@ -64,7 +64,7 @@ MacOS High Sierra 10.13.6 x86_64
|
|||||||
Path: /Users/Admin/bin/gamadv-xtd3
|
Path: /Users/Admin/bin/gamadv-xtd3
|
||||||
Version Check:
|
Version Check:
|
||||||
Current: 5.35.08
|
Current: 5.35.08
|
||||||
Latest: 6.80.14
|
Latest: 6.80.15
|
||||||
echo $?
|
echo $?
|
||||||
1
|
1
|
||||||
```
|
```
|
||||||
@ -72,7 +72,7 @@ echo $?
|
|||||||
Print the current version number without details
|
Print the current version number without details
|
||||||
```
|
```
|
||||||
gam version simple
|
gam version simple
|
||||||
6.80.14
|
6.80.15
|
||||||
```
|
```
|
||||||
In Linux/MacOS you can do:
|
In Linux/MacOS you can do:
|
||||||
```
|
```
|
||||||
@ -82,7 +82,7 @@ echo $VER
|
|||||||
Print the current version of Gam and address of this Wiki
|
Print the current version of Gam and address of this Wiki
|
||||||
```
|
```
|
||||||
gam help
|
gam help
|
||||||
GAM 6.80.14 - https://github.com/taers232c/GAMADV-XTD3
|
GAM 6.80.15 - https://github.com/taers232c/GAMADV-XTD3
|
||||||
Ross Scroggs <ross.scroggs@gmail.com>
|
Ross Scroggs <ross.scroggs@gmail.com>
|
||||||
Python 3.12.5 64-bit final
|
Python 3.12.5 64-bit final
|
||||||
MacOS Sonoma 14.5 x86_64
|
MacOS Sonoma 14.5 x86_64
|
||||||
|
@ -7032,6 +7032,7 @@ gam <UserTypeEntity> print filepath <DriveFileEntity> [todrive <ToDriveAttribute
|
|||||||
gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
||||||
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
||||||
(querytime<String> <Time>)*]
|
(querytime<String> <Time>)*]
|
||||||
|
[continueoninvalidquery [<Boolean>]]
|
||||||
[corpora <CorporaAttribute>]
|
[corpora <CorporaAttribute>]
|
||||||
[select <SharedDriveEntity>]
|
[select <SharedDriveEntity>]
|
||||||
[anyowner|(showownedby any|me|others)]
|
[anyowner|(showownedby any|me|others)]
|
||||||
@ -7045,6 +7046,7 @@ gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
|||||||
gam <UserTypeEntity> show filecounts
|
gam <UserTypeEntity> show filecounts
|
||||||
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
||||||
(querytime<String> <Time>)*]
|
(querytime<String> <Time>)*]
|
||||||
|
[continueoninvalidquery [<Boolean>]]
|
||||||
[corpora <CorporaAttribute>]
|
[corpora <CorporaAttribute>]
|
||||||
[select <SharedDriveEntity>]
|
[select <SharedDriveEntity>]
|
||||||
[anyowner|(showownedby any|me|others)]
|
[anyowner|(showownedby any|me|others)]
|
||||||
@ -7107,6 +7109,7 @@ gam <UserTypeEntity> print fileparenttree <DriveFileEntity> [todrive <ToDriveAtt
|
|||||||
gam <UserTypeEntity> print filelist [todrive <ToDriveAttribute>*]
|
gam <UserTypeEntity> print filelist [todrive <ToDriveAttribute>*]
|
||||||
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
[((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>)
|
||||||
(querytime<String> <Time>)*]
|
(querytime<String> <Time>)*]
|
||||||
|
[continueoninvalidquery [<Boolean>]]
|
||||||
[choose <DriveFileNameEntity>|<DriveFileEntityShortcut>]
|
[choose <DriveFileNameEntity>|<DriveFileEntityShortcut>]
|
||||||
[corpora <CorporaAttribute>]
|
[corpora <CorporaAttribute>]
|
||||||
[select <DriveFileEntity> [selectsubquery <QueryDriveFile>]
|
[select <DriveFileEntity> [selectsubquery <QueryDriveFile>]
|
||||||
|
@ -2,6 +2,17 @@
|
|||||||
|
|
||||||
Merged GAM-Team version
|
Merged GAM-Team version
|
||||||
|
|
||||||
|
6.80.15
|
||||||
|
|
||||||
|
Fixed bug in `gam <UserTypeEntity> print filelist ... countsrowfilter` that caused a trap.
|
||||||
|
|
||||||
|
Added option `continueoninvalidquery [<Boolean>]` to `gam <UserTypeEntity> print filelist|filecounts` that can be used
|
||||||
|
in special cases where a query of the form `query "'labels/mRoha85IbwCRl490E00xGLvBsSbkwIiuZ6PRNNEbwxyz' in labels"
|
||||||
|
causes Google to issue an error saying that the query is invalid when, in fact, it is but the user does not have a
|
||||||
|
license that suppprts drive file labels. When `continueoninvalidquery` is true, GAM prints an error message and
|
||||||
|
proceeds to the next user rather that terminating as it does now. Of course, if the query really is invalid, you will
|
||||||
|
get the message for every user.
|
||||||
|
|
||||||
6.80.14
|
6.80.14
|
||||||
|
|
||||||
Updated `gam <UserTypeEntity> print messages|threads` to display all default headers
|
Updated `gam <UserTypeEntity> print messages|threads` to display all default headers
|
||||||
|
@ -54490,6 +54490,7 @@ SIZE_FIELD_CHOICE_MAP = {
|
|||||||
|
|
||||||
# gam <UserTypeEntity> print filelist [todrive <ToDriveAttribute>*]
|
# gam <UserTypeEntity> print filelist [todrive <ToDriveAttribute>*]
|
||||||
# [((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>) (querytime<String> <Time>)*]
|
# [((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>) (querytime<String> <Time>)*]
|
||||||
|
# [continueoninvalidquery [<Boolean>]]
|
||||||
# [choose <DriveFileNameEntity>|<DriveFileEntityShortcut>]
|
# [choose <DriveFileNameEntity>|<DriveFileEntityShortcut>]
|
||||||
# [corpora <CorporaAttribute>]
|
# [corpora <CorporaAttribute>]
|
||||||
# [select <DriveFileEntity> [selectsubquery <QueryDriveFile>]
|
# [select <DriveFileEntity> [selectsubquery <QueryDriveFile>]
|
||||||
@ -54654,12 +54655,12 @@ def printFileList(users):
|
|||||||
_printFileInfoRow(baserow, fileInfo)
|
_printFileInfoRow(baserow, fileInfo)
|
||||||
else:
|
else:
|
||||||
if not countsRowFilter:
|
if not countsRowFilter:
|
||||||
csvPF.UpdateMimeTypeCounts(flattenJSON(fileInfo, flattened=row, skipObjects=skipObjects, timeObjects=timeObjects,
|
csvPFco.UpdateMimeTypeCounts(flattenJSON(fileInfo, flattened=row, skipObjects=skipObjects, timeObjects=timeObjects,
|
||||||
simpleLists=simpleLists, delimiter=delimiter), mimeTypeInfo)
|
simpleLists=simpleLists, delimiter=delimiter), mimeTypeInfo)
|
||||||
else:
|
else:
|
||||||
mimeTypeInfo.setdefault(fileInfo['mimeType'], {'count': 0, 'size': 0})
|
mimeTypeInfo.setdefault(fileInfo['mimeType'], {'count': 0, 'size': 0})
|
||||||
mimeTypeInfo[fileInfo['mimeType']['count']] += 1
|
mimeTypeInfo[fileInfo['mimeType']]['count'] += 1
|
||||||
mimeTypeInfo[fileInfo['mimeType']['size']] += int(fileInfo.get(sizeField, '0'))
|
mimeTypeInfo[fileInfo['mimeType']]['size'] += int(fileInfo.get(sizeField, '0'))
|
||||||
|
|
||||||
def _printChildDriveFolderContents(drive, fileEntry, user, i, count, depth):
|
def _printChildDriveFolderContents(drive, fileEntry, user, i, count, depth):
|
||||||
parentFileEntry = fileTree.get(fileEntry['id'])
|
parentFileEntry = fileTree.get(fileEntry['id'])
|
||||||
@ -54738,7 +54739,7 @@ def printFileList(users):
|
|||||||
|
|
||||||
csvPF = CSVPrintFile('Owner', indexedTitles=DRIVE_INDEXED_TITLES)
|
csvPF = CSVPrintFile('Owner', indexedTitles=DRIVE_INDEXED_TITLES)
|
||||||
FJQC = FormatJSONQuoteChar(csvPF)
|
FJQC = FormatJSONQuoteChar(csvPF)
|
||||||
addPathsToJSON = countsRowFilter = buildTree = countsOnly = filepath = fullpath = folderPathOnly = \
|
addPathsToJSON = continueOnInvalidQuery = countsRowFilter = buildTree = countsOnly = filepath = fullpath = folderPathOnly = \
|
||||||
getPermissionsForSharedDrives = mimeTypeInQuery = noRecursion = oneItemPerRow = stripCRsFromName = \
|
getPermissionsForSharedDrives = mimeTypeInQuery = noRecursion = oneItemPerRow = stripCRsFromName = \
|
||||||
showParentsIdsAsList = showDepth = showParent = showSize = showMimeTypeSize = showSource = False
|
showParentsIdsAsList = showDepth = showParent = showSize = showMimeTypeSize = showSource = False
|
||||||
sizeField = 'quotaBytesUsed'
|
sizeField = 'quotaBytesUsed'
|
||||||
@ -54853,6 +54854,8 @@ def printFileList(users):
|
|||||||
elif myarg == 'addcsvdata':
|
elif myarg == 'addcsvdata':
|
||||||
k = getString(Cmd.OB_STRING)
|
k = getString(Cmd.OB_STRING)
|
||||||
addCSVData[k] = getString(Cmd.OB_STRING, minLen=0)
|
addCSVData[k] = getString(Cmd.OB_STRING, minLen=0)
|
||||||
|
elif myarg == 'continueoninvalidquery':
|
||||||
|
continueOnInvalidQuery = getBoolean()
|
||||||
else:
|
else:
|
||||||
FJQC.GetFormatJSONQuoteChar(myarg)
|
FJQC.GetFormatJSONQuoteChar(myarg)
|
||||||
if not filepath and not fullpath:
|
if not filepath and not fullpath:
|
||||||
@ -55034,8 +55037,10 @@ def printFileList(users):
|
|||||||
extendFileTreeParents(drive, fileTree, fields)
|
extendFileTreeParents(drive, fileTree, fields)
|
||||||
DLP.GetLocationFileIdsFromTree(fileTree, fileIdEntity)
|
DLP.GetLocationFileIdsFromTree(fileTree, fileIdEntity)
|
||||||
except (GAPI.invalidQuery, GAPI.invalid, GAPI.badRequest):
|
except (GAPI.invalidQuery, GAPI.invalid, GAPI.badRequest):
|
||||||
entityActionFailedWarning([Ent.USER, user, Ent.DRIVE_FILE, None], invalidQuery(DLP.fileIdEntity['query']), i, count)
|
entityActionFailedWarning([Ent.USER, user, Ent.DRIVE_FILE_OR_FOLDER, None], invalidQuery(DLP.fileIdEntity['query']), i, count)
|
||||||
break
|
if not continueOnInvalidQuery:
|
||||||
|
break
|
||||||
|
continue
|
||||||
except GAPI.fileNotFound:
|
except GAPI.fileNotFound:
|
||||||
printGotEntityItemsForWhom(0)
|
printGotEntityItemsForWhom(0)
|
||||||
continue
|
continue
|
||||||
@ -55577,6 +55582,7 @@ def printFileParentTree(users):
|
|||||||
|
|
||||||
# gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
# gam <UserTypeEntity> print filecounts [todrive <ToDriveAttribute>*]
|
||||||
# [((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>) (querytime<String> <Time>)*]
|
# [((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>) (querytime<String> <Time>)*]
|
||||||
|
# [continueoninvalidquery [<Boolean>]]
|
||||||
# [corpora <CorporaAttribute>]
|
# [corpora <CorporaAttribute>]
|
||||||
# [select <SharedDriveEntity>]
|
# [select <SharedDriveEntity>]
|
||||||
# [anyowner|(showownedby any|me|others)]
|
# [anyowner|(showownedby any|me|others)]
|
||||||
@ -55589,6 +55595,7 @@ def printFileParentTree(users):
|
|||||||
# [summary none|only|plus] [summaryuser <String>]
|
# [summary none|only|plus] [summaryuser <String>]
|
||||||
# gam <UserTypeEntity> show filecounts
|
# gam <UserTypeEntity> show filecounts
|
||||||
# [((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>) (querytime<String> <Time>)*]
|
# [((query <QueryDriveFile>) | (fullquery <QueryDriveFile>) | <DriveFileQueryShortcut>) (querytime<String> <Time>)*]
|
||||||
|
# [continueoninvalidquery [<Boolean>]]
|
||||||
# [corpora <CorporaAttribute>]
|
# [corpora <CorporaAttribute>]
|
||||||
# [select <SharedDriveEntity>]
|
# [select <SharedDriveEntity>]
|
||||||
# [anyowner|(showownedby any|me|others)]
|
# [anyowner|(showownedby any|me|others)]
|
||||||
@ -55666,7 +55673,7 @@ def printShowFileCounts(users):
|
|||||||
fieldsList = ['mimeType']
|
fieldsList = ['mimeType']
|
||||||
DLP = DriveListParameters({'allowChoose': False, 'allowCorpora': True, 'allowQuery': True, 'mimeTypeInQuery': True})
|
DLP = DriveListParameters({'allowChoose': False, 'allowCorpora': True, 'allowQuery': True, 'mimeTypeInQuery': True})
|
||||||
sharedDriveId = sharedDriveName = ''
|
sharedDriveId = sharedDriveName = ''
|
||||||
showSize = showMimeTypeSize = False
|
continueOnInvalidQuery = showSize = showMimeTypeSize = False
|
||||||
sizeField = 'quotaBytesUsed'
|
sizeField = 'quotaBytesUsed'
|
||||||
summary = FILECOUNT_SUMMARY_NONE
|
summary = FILECOUNT_SUMMARY_NONE
|
||||||
summaryUser = FILECOUNT_SUMMARY_USER
|
summaryUser = FILECOUNT_SUMMARY_USER
|
||||||
@ -55696,6 +55703,8 @@ def printShowFileCounts(users):
|
|||||||
elif csvPF and myarg == 'addcsvdata':
|
elif csvPF and myarg == 'addcsvdata':
|
||||||
k = getString(Cmd.OB_STRING)
|
k = getString(Cmd.OB_STRING)
|
||||||
addCSVData[k] = getString(Cmd.OB_STRING, minLen=0)
|
addCSVData[k] = getString(Cmd.OB_STRING, minLen=0)
|
||||||
|
elif myarg == 'continueoninvalidquery':
|
||||||
|
continueOnInvalidQuery = getBoolean()
|
||||||
else:
|
else:
|
||||||
unknownArgumentExit()
|
unknownArgumentExit()
|
||||||
if not fileIdEntity:
|
if not fileIdEntity:
|
||||||
@ -55776,7 +55785,9 @@ def printShowFileCounts(users):
|
|||||||
showMimeTypeInfo(user, mimeTypeInfo, sharedDriveId, sharedDriveName, i, count)
|
showMimeTypeInfo(user, mimeTypeInfo, sharedDriveId, sharedDriveName, i, count)
|
||||||
except (GAPI.invalidQuery, GAPI.invalid, GAPI.badRequest):
|
except (GAPI.invalidQuery, GAPI.invalid, GAPI.badRequest):
|
||||||
entityActionFailedWarning([Ent.USER, user, Ent.DRIVE_FILE_OR_FOLDER, None], invalidQuery(DLP.fileIdEntity['query']), i, count)
|
entityActionFailedWarning([Ent.USER, user, Ent.DRIVE_FILE_OR_FOLDER, None], invalidQuery(DLP.fileIdEntity['query']), i, count)
|
||||||
break
|
if not continueOnInvalidQuery:
|
||||||
|
break
|
||||||
|
continue
|
||||||
except GAPI.fileNotFound:
|
except GAPI.fileNotFound:
|
||||||
printGotEntityItemsForWhom(0)
|
printGotEntityItemsForWhom(0)
|
||||||
except (GAPI.notFound, GAPI.teamDriveMembershipRequired) as e:
|
except (GAPI.notFound, GAPI.teamDriveMembershipRequired) as e:
|
||||||
|
Reference in New Issue
Block a user