Google Drive Link Fixer
Project description
glinkfix
Google Drive Link Fixer
Notes (please read)
-
Google periodically changes how Drive links are handled, which can affect tools like glinkfix. Direct downloading and embedding Google Drive links is unsupported behavior as far as Google is concerned. As of January 2024, Google made a significant change that broke some links created with this tool. glinkfix now accepts current Drive file link formats such as
usp=drive_link, but future Google changes may break link handling again. -
Viewing links that point to animated GIFs may appear as static images.
-
In the v2 update, in addition to displaying the fixed link on the screen, glinkfix will also attempt to copy the fixed link to the clipboard. Copying to the clipboard only works for desktop operating systems, not server environments. Even without automatic copying, link fixing will still work and the results will be displayed on the screen, regardless of where you run it. glinkfix uses the pyperclip library, and automatic copying to the clipboard should work seamlessly on Windows and macOS. If you're running Linux and links are not automatically copied to the clipboard, refer to this note from the pyperclip documentation.
-
glinkfix is tested on Linux, macOS, and Windows in continuous integration. Clipboard behavior still depends on the local desktop or server environment.
Installation
The preferred way to install glinkfix is with pipx:
pipx install glinkfix
You can also install glinkfix as a tool with uv:
uv tool install glinkfix
Alternatively, you can create a separate virtual environment and install it the traditional way:
pip3 install glinkfix
If you just need a quick one-time link fix and don't want to commit to a full installation, use:
pipx run glinkfix -h
and follow the directions to run it again with the option you want.
Purpose and Usage
When you share files with Google Drive, the sharing link you get is
intended primarily for accessing the content through a web browser.
glinkfix supports Google Drive file links such as
https://drive.google.com/file/d/<file-id>/view?usp=drive_link,
.../preview, and bare /file/d/<file-id> links. If you want to use a
Google Drive file sharing link to embed an image in a document (e.g. in
a Markdown or HTML file), or you want to directly download a file pointed
to by a Google Drive sharing link using something like curl or wget
in Linux, the link needs to be adjusted ("fixed") for these purposes.
It's not especially hard to repackage the link, but it can be tedious. You have to copy the link to a text editor, carve it up manually, and reassemble it. If you've got a lot of links to deal with, the process gets repetitive. This tool is designed to remove that tedium.
Note: The images below demonstrate Google Drive sharing links and their "fixed" equivalents.
Start by getting a sharing link to a file on Google Drive. Make sure it's set up for public access (Anyone with the link):
Now run glinkfix with the sharing link:
glinkfix "https://drive.google.com/file/d/<file-id>/view?usp=drive_link"
By default, glinkfix creates an embeddable link, prints the result, and attempts to copy the fixed link to the clipboard. To create a direct-download link instead, use:
glinkfix --download "https://drive.google.com/file/d/<file-id>/view?usp=drive_link"
For shell scripts, use --quiet to print only the converted URL:
glinkfix --quiet "https://drive.google.com/file/d/<file-id>/view?usp=drive_link"
To print the normal output without copying to the clipboard, use:
glinkfix --no-copy "https://drive.google.com/file/d/<file-id>/view?usp=drive_link"
If you run glinkfix without a URL, it prompts for one interactively.
Press Ctrl-C at the prompt to exit cleanly.
To display the help menu, run: glinkfix -h
usage: glinkfix [-h] [-d] [--no-copy] [--quiet] [-v] [url]
Convert a Google Drive file sharing link into a link suitable for
embedding in a document, such as an image in Markdown or HTML, or for
direct download, such as with curl. glinkfix accepts current Drive file
link formats such as usp=drive_link and uses Python's standard-library
URL parser for lightweight, dependency-minimal processing. Google Drive
links used this way have a single-file size limit of 40 MB.
positional arguments:
url Google Drive file sharing link to convert. If omitted,
prompt for one.
options:
-h, --help show this help message and exit
-d, --download Create a direct-download link instead of the default
embeddable link.
--no-copy Do not copy the converted link to the clipboard.
--quiet Print only the converted link and skip clipboard copying.
-v, --version show program's version number and exit
Usage Notes
- There is a 40 MB size limit for a single file when using Google Drive sharing links directly for viewing or downloading. Individual files larger than 40 MB will not render or download properly. This limit is a function of how Google Drive works and is not related to glinkfix.
- When creating a download link for use with
curl, make sure to usecurl's-Loption to allow for redirects. - glinkfix supports current Google Drive file sharing links, including
usp=drive_link,usp=drivesdk,usp=sharing, andusp=share_link. - glinkfix supports links that use Google's resource key security feature and preserves the resource key in fixed links.
- glinkfix supports Drive file links only. It does not convert Google Drive folder links or native Google Docs, Sheets, or Slides editor links.
- The link parser uses Python's standard-library URL parsing tools for lightweight, dependency-minimal processing. New dependencies are acceptable when they provide a clear correctness, performance, or maintainability benefit.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Acknowledgements
This project uses the pyperclip library, an external dependency licensed under the BSD 3-Clause License. See the pyperclip project for license details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file glinkfix-2.2.0.tar.gz.
File metadata
- Download URL: glinkfix-2.2.0.tar.gz
- Upload date:
- Size: 701.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0e1068918b397aa9f6df4735f5fa1b1cfaf44b38625ffca26ac5038f06485db4
|
|
| MD5 |
c23b5aad68641815f42a4aca459b8eb1
|
|
| BLAKE2b-256 |
57441aea69f905796d19ca5a281eda0a21830f97d2da788685741f3d1ec3e330
|
File details
Details for the file glinkfix-2.2.0-py3-none-any.whl.
File metadata
- Download URL: glinkfix-2.2.0-py3-none-any.whl
- Upload date:
- Size: 8.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
28a8d01606186042cc8496a6529f15668e86fa2cc6ab561343b07eb55da1c28d
|
|
| MD5 |
179533a5293415f0e706f3024e93af7f
|
|
| BLAKE2b-256 |
97376c5520873ad6bd7fe5c5f07d6122d5099b5a2ba92e6abcaf200baa884fca
|