Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lionello/onedrive-cli
Command line interface for OneDrive
https://github.com/lionello/onedrive-cli
command-line command-line-tool nodejs onedrive onedrive-api onedrive-client onedrive-storage
Last synced: 3 days ago
JSON representation
Command line interface for OneDrive
- Host: GitHub
- URL: https://github.com/lionello/onedrive-cli
- Owner: lionello
- License: mit
- Created: 2016-12-11T13:10:15.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-02-20T19:31:39.000Z (9 months ago)
- Last Synced: 2024-11-06T17:05:06.331Z (11 days ago)
- Topics: command-line, command-line-tool, nodejs, onedrive, onedrive-api, onedrive-client, onedrive-storage
- Language: Nix
- Homepage: https://www.lunesu.com/onedrive-cli/
- Size: 260 KB
- Stars: 142
- Watchers: 7
- Forks: 19
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - lionello/onedrive-cli - Command line interface for OneDrive (Nix)
README
# onedrive-cli
Cross-platform command line interface for OneDrive (Personal)## Development
The provided `shell.nix` for the [Nix](https://nixos.org) package manager contains all development dependencies.
Use it with `nix-shell` or [Direnv](https://direnv.net)'s `use nix`.### Update Nix files
```sh
node2nix -l package-lock.json
```## Installation
From source:
```sh
$ git clone https://github.com/lionello/onedrive-cli.git
$ cd onedrive-cli
$ npm install
$ bin/onedrive login
```Or use `npm`:
```sh
npm install @lionello/onedrive-cli
```Or use `nix-env`:
```sh
nix-env -if https://github.com/lionello/onedrive-cli/archive/master.tar.gz -A package
```## Usage
`usage: onedrive COMMAND [arguments]`This little utility supports the following commands:
* `cat` - dumps the contents of a file to stdout
* `chmod` - change sharing permissions
* `cp` - copies local file(s) to OneDrive or vice-versa
* `df` - shows OneDrive storage usage stats
* `find` - find file(s) or folder(s) by name, optionally separated by `NUL`
* `help` - shows list of supported commands
* `ln` - create a link to the remote item
* `login` - request/store an OAuth access token
* `ls` - list the contents of a folder
* `mkdir` - create a remote folder
* `mv` - move a local file to OneDrive or vice-versa
* `rm` - delete a file from OneDrive (not implemented)
* `sendmail` - send an invitation email for editing to recipients
* `stat` - dump all information for particular file(s)
* `wget` - copy a remote URL to OneDrive (server side)## Examples
##### List the contents of the Public folder
`onedrive ls Public`##### Grep one file
`onedrive cat Documents/passwords | grep boa`##### Let OneDrive upload a file server side
`onedrive wget http://mega.com/somehugepublicfile Documents/somehugepublicfile`##### Upload files recursively
`find * -type f -print0 | xargs -0 -n1 -I{} onedrive cp "./{}" "Shared Favorites/{}"`##### Move remote files to a new folder
`onedrive find 'Pictures/Camera Roll' -regex 2015 -type f -print0 | xargs -0 onedrive mv -t :/Pictures/2015/`## FAQ
##### Access token was not found; 'login' first.
The `onedrive` utility needs an access token in order to read/write to your OneDrive storage.
Use the`onedrive login` command to get the address of the Microsoft login page. After login,
this page will redirect to the file `oauthcallbackhandler.html` (https://github.com/lionello/onedrive-cli/blob/master/docs/oauthcallbackhandler.html)
and extract the `access_token` from the URL parameters. Copy-paste this token into the command line.
This will save the token in a file called `~/.onedrive-cli-token`. These tokens have a validity of 1 hour.##### "An item with the same name already exists under the parent"
Currently, a copy will fail if a file with the same it already exists.
Change the name of the target, or use other means to delete/rename the existing file in your OneDrive.##### Invalid source name
You cannot copy folders. Specify a source file instead, or use wildcards.##### Invalid target name
The target file name cannot be determined from the source path. Specify a target file name.##### Use ./ or :/ path prefix for local or remote paths.
The `cp` command supports both local->remote as well as remote->local copy.
To make it clear which path is remote and which is local, either use `./` as a prefix for
the local path, or use `:/` as a prefix for the remote path. Either one will suffice.##### chmod: Invalid file mode
The `chmod` command currently only supports `-w` or `-rw`. The former tried to downgrade *write*
shares to *read*-only, whereas the latter removes all shares for the given item(s). Octal modes are accepted (for example `644`, `0700`) as well as `og-rw` or `g-w`.## TODO
* Implement `rm`
* Support gzip/deflate encoding for downloads
* Uploads larger than 100MiB are not yet supported (needs range API)
* Support OneDrive for Business
* Ability to get the link for a file
* Skip upload/download if the SHA1 matches
* Adding write permissions (+w) to existing share links## DONE
* Register with NPM ([@lionello/onedrive-cli](https://www.npmjs.com/package/@lionello/onedrive-cli))
* Fixed OAuth redirect on Safari (https://bugs.webkit.org/show_bug.cgi?id=24175)
* Use XDG path spec for token file (https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html)
* Using `async`/`await`