Files
google-apis-rs/google_drive2_cli/index.html
2022-03-08 15:36:16 +08:00

717 lines
27 KiB
HTML

<!DOCTYPE html>
<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>drive v3.0.0+20220225</title>
<link href='https://fonts.googleapis.com/css?family=Lato:400,700|Roboto+Slab:400,700|Inconsolata:400,700' rel='stylesheet' type='text/css'>
<link rel="stylesheet" href="./css/theme.css" type="text/css" />
<link rel="stylesheet" href="./css/theme_extra.css" type="text/css" />
<link rel="stylesheet" href="./css/highlight.css">
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/modernizr/2.8.3/modernizr.min.js"></script>
<script type="text/javascript" src="./js/highlight.pack.js"></script>
<script src="./js/theme.js"></script>
<style>
body {font-size: 90%;}
pre, code {font-size: 100%;}
h3, h4, h5, h6 {color: #2980b9; font-weight: 300}
</style>
</head>
<body class="wy-body-for-nav" role="document">
<div class="wy-grid-for-nav">
<nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
<div class="wy-side-nav-search">
<a href="." class="icon icon-home"> drive v3.0.0+20220225</a>
</div>
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
<ul class="current">
<span>About</span>
<li class="toctree-l1 ">
<a class="" href="about_get/">Get</a>
</li>
<span>Apps</span>
<li class="toctree-l1 ">
<a class="" href="apps_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="apps_list/">List</a>
</li>
<span>Changes</span>
<li class="toctree-l1 ">
<a class="" href="changes_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="changes_get-start-page-token/">Get Start Page Token</a>
</li>
<li class="toctree-l1 ">
<a class="" href="changes_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="changes_watch/">Watch</a>
</li>
<span>Channels</span>
<li class="toctree-l1 ">
<a class="" href="channels_stop/">Stop</a>
</li>
<span>Children</span>
<li class="toctree-l1 ">
<a class="" href="children_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="children_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="children_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="children_list/">List</a>
</li>
<span>Comments</span>
<li class="toctree-l1 ">
<a class="" href="comments_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="comments_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="comments_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="comments_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="comments_patch/">Patch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="comments_update/">Update</a>
</li>
<span>Drives</span>
<li class="toctree-l1 ">
<a class="" href="drives_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="drives_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="drives_hide/">Hide</a>
</li>
<li class="toctree-l1 ">
<a class="" href="drives_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="drives_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="drives_unhide/">Unhide</a>
</li>
<li class="toctree-l1 ">
<a class="" href="drives_update/">Update</a>
</li>
<span>Files</span>
<li class="toctree-l1 ">
<a class="" href="files_copy/">Copy</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_empty-trash/">Empty Trash</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_export/">Export</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_generate-ids/">Generate Ids</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_patch/">Patch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_touch/">Touch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_trash/">Trash</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_untrash/">Untrash</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_update/">Update</a>
</li>
<li class="toctree-l1 ">
<a class="" href="files_watch/">Watch</a>
</li>
<span>Parents</span>
<li class="toctree-l1 ">
<a class="" href="parents_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="parents_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="parents_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="parents_list/">List</a>
</li>
<span>Permissions</span>
<li class="toctree-l1 ">
<a class="" href="permissions_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="permissions_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="permissions_get-id-for-email/">Get Id For Email</a>
</li>
<li class="toctree-l1 ">
<a class="" href="permissions_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="permissions_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="permissions_patch/">Patch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="permissions_update/">Update</a>
</li>
<span>Properties</span>
<li class="toctree-l1 ">
<a class="" href="properties_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="properties_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="properties_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="properties_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="properties_patch/">Patch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="properties_update/">Update</a>
</li>
<span>Replies</span>
<li class="toctree-l1 ">
<a class="" href="replies_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="replies_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="replies_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="replies_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="replies_patch/">Patch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="replies_update/">Update</a>
</li>
<span>Revisions</span>
<li class="toctree-l1 ">
<a class="" href="revisions_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="revisions_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="revisions_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="revisions_patch/">Patch</a>
</li>
<li class="toctree-l1 ">
<a class="" href="revisions_update/">Update</a>
</li>
<span>Teamdrives</span>
<li class="toctree-l1 ">
<a class="" href="teamdrives_delete/">Delete</a>
</li>
<li class="toctree-l1 ">
<a class="" href="teamdrives_get/">Get</a>
</li>
<li class="toctree-l1 ">
<a class="" href="teamdrives_insert/">Insert</a>
</li>
<li class="toctree-l1 ">
<a class="" href="teamdrives_list/">List</a>
</li>
<li class="toctree-l1 ">
<a class="" href="teamdrives_update/">Update</a>
</li>
</ul>
</div>
&nbsp;
</nav>
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
<nav class="wy-nav-top" role="navigation" aria-label="top navigation">
<i data-toggle="wy-nav-top" class="icon icon-reorder"></i>
<a href="."></a>
</nav>
<div class="wy-nav-content">
<div class="rst-content">
<div role="navigation" aria-label="breadcrumbs navigation">
<ul class="wy-breadcrumbs">
<li><a href=".">Docs</a> &raquo;</li>
<li>Home</li>
<li class="wy-breadcrumbs-aside">
<a href="https://github.com/Byron/google-apis-rs/tree/main/gen/drive2-cli" class="icon icon-github"> Edit on GitHub</a>
</li>
</ul>
<hr/>
</div>
<div role="main">
<div class="section">
<!---
DO NOT EDIT !
This file was generated automatically from 'src/mako/cli/README.md.mako'
DO NOT EDIT !
-->
<p>The <code>drive2</code> command-line interface <em>(CLI)</em> allows to use most features of the <em>Google drive</em> service from the comfort of your terminal.</p>
<p>By default all output is printed to standard out, but flags can be set to direct it into a file independent of your shell's
capabilities. Errors will be printed to standard error, and cause the program's exit code to be non-zero.</p>
<p>If data-structures are requested, these will be returned as pretty-printed JSON, to be useful as input to other tools.</p>
<p>Everything else about the <em>drive</em> API can be found at the
<a href="https://developers.google.com/drive/">official documentation site</a>.</p>
<h1 id="installation-and-source-code">Installation and Source Code</h1>
<p>Install the command-line interface with cargo using:</p>
<pre><code class="bash">cargo install google-drive2-cli
</code></pre>
<p>Find the source code <a href="https://github.com/Byron/google-apis-rs/tree/main/gen/drive2-cli">on github</a>.</p>
<h1 id="usage">Usage</h1>
<p>This documentation was generated from the <em>drive</em> API at revision <em>20220225</em>. The CLI is at version <em>3.0.0</em>.</p>
<pre><code class="bash">drive2 [options]
about
get [-p &lt;v&gt;]... [-o &lt;out&gt;]
apps
get &lt;app-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
list [-p &lt;v&gt;]... [-o &lt;out&gt;]
changes
get &lt;change-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
get-start-page-token [-p &lt;v&gt;]... [-o &lt;out&gt;]
list [-p &lt;v&gt;]... [-o &lt;out&gt;]
watch (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
channels
stop (-r &lt;kv&gt;)... [-p &lt;v&gt;]...
children
delete &lt;folder-id&gt; &lt;child-id&gt; [-p &lt;v&gt;]...
get &lt;folder-id&gt; &lt;child-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;folder-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;folder-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
comments
delete &lt;file-id&gt; &lt;comment-id&gt; [-p &lt;v&gt;]...
get &lt;file-id&gt; &lt;comment-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
patch &lt;file-id&gt; &lt;comment-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;file-id&gt; &lt;comment-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
drives
delete &lt;drive-id&gt; [-p &lt;v&gt;]...
get &lt;drive-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
hide &lt;drive-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;request-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list [-p &lt;v&gt;]... [-o &lt;out&gt;]
unhide &lt;drive-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;drive-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
files
copy &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
delete &lt;file-id&gt; [-p &lt;v&gt;]...
empty-trash [-p &lt;v&gt;]...
export &lt;file-id&gt; &lt;mime-type&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
generate-ids [-p &lt;v&gt;]... [-o &lt;out&gt;]
get &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert (-r &lt;kv&gt;)... (-u simple -f &lt;file&gt; [-m &lt;mime&gt;]) [-p &lt;v&gt;]... [-o &lt;out&gt;]
list [-p &lt;v&gt;]... [-o &lt;out&gt;]
patch &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
touch &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
trash &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
untrash &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;file-id&gt; (-r &lt;kv&gt;)... (-u simple -f &lt;file&gt; [-m &lt;mime&gt;]) [-p &lt;v&gt;]... [-o &lt;out&gt;]
watch &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
parents
delete &lt;file-id&gt; &lt;parent-id&gt; [-p &lt;v&gt;]...
get &lt;file-id&gt; &lt;parent-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
permissions
delete &lt;file-id&gt; &lt;permission-id&gt; [-p &lt;v&gt;]...
get &lt;file-id&gt; &lt;permission-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
get-id-for-email &lt;email&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
patch &lt;file-id&gt; &lt;permission-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;file-id&gt; &lt;permission-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
properties
delete &lt;file-id&gt; &lt;property-key&gt; [-p &lt;v&gt;]...
get &lt;file-id&gt; &lt;property-key&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;file-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
patch &lt;file-id&gt; &lt;property-key&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;file-id&gt; &lt;property-key&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
replies
delete &lt;file-id&gt; &lt;comment-id&gt; &lt;reply-id&gt; [-p &lt;v&gt;]...
get &lt;file-id&gt; &lt;comment-id&gt; &lt;reply-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;file-id&gt; &lt;comment-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;file-id&gt; &lt;comment-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
patch &lt;file-id&gt; &lt;comment-id&gt; &lt;reply-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;file-id&gt; &lt;comment-id&gt; &lt;reply-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
revisions
delete &lt;file-id&gt; &lt;revision-id&gt; [-p &lt;v&gt;]...
get &lt;file-id&gt; &lt;revision-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
list &lt;file-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
patch &lt;file-id&gt; &lt;revision-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;file-id&gt; &lt;revision-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
teamdrives
delete &lt;team-drive-id&gt; [-p &lt;v&gt;]...
get &lt;team-drive-id&gt; [-p &lt;v&gt;]... [-o &lt;out&gt;]
insert &lt;request-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
list [-p &lt;v&gt;]... [-o &lt;out&gt;]
update &lt;team-drive-id&gt; (-r &lt;kv&gt;)... [-p &lt;v&gt;]... [-o &lt;out&gt;]
drive2 --help
Configuration:
[--scope &lt;url&gt;]...
Specify the authentication a method should be executed in. Each scope
requires the user to grant this application permission to use it.
If unset, it defaults to the shortest scope url for a particular method.
--config-dir &lt;folder&gt;
A directory into which we will store our persistent data. Defaults to
a user-writable directory that we will create during the first invocation.
[default: ~/.google-service-cli]
</code></pre>
<h1 id="configuration">Configuration</h1>
<p>The program will store all persistent data in the <code>~/.google-service-cli</code> directory in <em>JSON</em> files prefixed with <code>drive2-</code>. You can change the directory used to store configuration with the <code>--config-dir</code> flag on a per-invocation basis.</p>
<p>More information about the various kinds of persistent data are given in the following paragraphs.</p>
<h1 id="authentication">Authentication</h1>
<p>Most APIs require a user to authenticate any request. If this is the case, the <a href="https://developers.google.com/+/api/oauth#scopes">scope</a> determines the
set of permissions granted. The granularity of these is usually no more than <em>read-only</em> or <em>full-access</em>.</p>
<p>If not set, the system will automatically select the smallest feasible scope, e.g. when invoking a
method that is read-only, it will ask only for a read-only scope.
You may use the <code>--scope</code> flag to specify a scope directly.
All applicable scopes are documented in the respective method's CLI documentation.</p>
<p>The first time a scope is used, the user is asked for permission. Follow the instructions given
by the CLI to grant permissions, or to decline.</p>
<p>If a scope was authenticated by the user, the respective information will be stored as <em>JSON</em> in the configuration
directory, e.g. <code>~/.google-service-cli/drive2-token-&lt;scope-hash&gt;.json</code>. No manual management of these tokens
is necessary.</p>
<p>To revoke granted authentication, please refer to the <a href="http://webapps.stackexchange.com/a/30849">official documentation</a>.</p>
<h1 id="application-secrets">Application Secrets</h1>
<p>In order to allow any application to use Google services, it will need to be registered using the
<a href="https://console.developers.google.com/">Google Developer Console</a>. APIs the application may use are then enabled for it
one by one. Most APIs can be used for free and have a daily quota.</p>
<p>To allow more comfortable usage of the CLI without forcing anyone to register an own application, the CLI
comes with a default application secret that is configured accordingly. This also means that heavy usage
all around the world may deplete the daily quota.</p>
<p>You can workaround this limitation by putting your own secrets file at this location:
<code>~/.google-service-cli/drive2-secret.json</code>, assuming that the required <em>drive</em> API
was enabled for it. Such a secret file can be downloaded in the <em>Google Developer Console</em> at
<em>APIs &amp; auth -&gt; Credentials -&gt; Download JSON</em> and used as is.</p>
<p>Learn more about how to setup Google projects and enable APIs using the <a href="https://developers.google.com/console/help/new/">official documentation</a>.</p>
<h1 id="debugging">Debugging</h1>
<p>Even though the CLI does its best to provide usable error messages, sometimes it might be desirable to know
what exactly led to a particular issue. This is done by allowing all client-server communication to be
output to standard error <em>as-is</em>.</p>
<p>The <code>--debug</code> flag will print errors using the <code>Debug</code> representation to standard error.</p>
<p>You may consider redirecting standard error into a file for ease of use, e.g. <code>drive2 --debug &lt;resource&gt; &lt;method&gt; [options] 2&gt;debug.txt</code>.</p>
</div>
</div>
<footer>
<div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
<a href="about_get/" class="btn btn-neutral float-right" title="Get"/>Next <span class="icon icon-circle-arrow-right"></span></a>
</div>
<hr/>
<div role="contentinfo">
<p>
<!-- Copyright etc -->
</p>
</div>
Built with <a href="http://www.mkdocs.org">MkDocs</a>, using a <a href="https://github.com/snide/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
</footer>
</div>
</div>
</section>
</div>
<div class="rst-versions" role="note" style="cursor: pointer">
<span class="rst-current-version" data-toggle="rst-current-version">
<a class="icon icon-github" style="float: left; color: #fcfcfc"> GitHub</a>
<span><a href="" style="color: #fcfcfc;">&laquo; Previous</a></span>
<span style="margin-left: 15px"><a href="about_get/" style="color: #fcfcfc">Next &raquo;</a></span>
</span>
</div>
</body>
</html>