Skip to main content

Google Drive Link Fixer

Project description

GitHub PyPI PyPI - Status GitHub last commit GitHub issues PyPI - Downloads GitHub repo size PyPI - Python Version


glinkfix


Dinobox logo

Google Drive Link Fixer

Notes (please read)

  1. It's turning into an arms race. Google keeps changing how links are handled on their servers, which often breaks tools like glinkfix. Direct downloading and embedding G-Drive links is definitely an unsupported "off the books" feature as far as Google is concerned. As of Jan 2024, Google made a significant change, which definitely broke some links created with this tool. This update (Apr 2024) works, for now, but if Google changes again, things may break.

  2. Viewing links that point to animated gifs may just show up as static images.

  3. 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-based operating systems (not Server installs). Even without automatic copying, link fixing will still work and the results will be displayed on the screen, regardless of where you run it (Server or Desktop). glinkfix uses the pyperclip library, and automatic copying to the clipboard should work seamlessly on Windows/Mac. If you're running Linux and links are not automatically copied to the clipboard, refer to this note from the pyperclip developer.

To Developers

If you're just using glinkfix, then carry on!

If you're a developer looking to fork this repository and modify glinkfix, there are two important considerations:

  1. glinkfix requires uv for dependency management. uv is well behaved and extremely fast. If you're a Python developer you should check it out. Visit the uv site and install it using your preferred method, with the instructions for your operating system.

  2. I've included a file called global-gitignore.txt which is a copy of the .gitignore I placed in my home directory and configured globally for all my development projects. The global-gitignore.txt file reflects my development setup (for example using tools like vscode), but yours may be different. Just cherry-pick any necessary elements from global-gitignore.txt for your own use.

    Details on gitignore files are available on GitHub.

Installation

The preferred way to install glinkfix is with pipx:

pipx 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 / Usage

When you share files with Google Drive, the sharing link you get is only good for accessing the content through a web browser. If you want to use a Google Drive 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's a pain. 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 it starts to get very tedious. This tool is designed to remove the tedium.

Note: The images below are actually hosted on Google Drive and the "fixed" links are embedded into this README file.


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):

Getting Link


Getting Link

Now run glinkfix and paste the link into the terminal. Copy the "fixed" version and use it as required.


To display the help menu, run: glinkfix -h

usage: glinkfix [-h] [-d]

This program takes a Google Drive sharing link for a file and repackages
it into a link that can be downloaded directly (e.g. using curl) or
embedded in a document to be viewed (e.g. an image in a markdown
document). Note: there is a size limit of 40MB for a single file when
using Google Drive links in this manner.

optional arguments:
  -h, --help      show this help message and exit
  -d, --download  The default behavior for glinkfix is to repackage a
                  Google Drive link to make it suitable for embedding in
                  a website. Use this option if you want to repackage
                  Google Drive link for direct downloading (e.g.
                  downloading using curl).

Usage Notes

  • There is a 40MB size limit for a single file when using Google Drive sharing links directly for viewing or downloading. Individual files larger than 40MB will not render/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 use curl's -L option to allow for redirects.
  • glinkfix supports links that use Google's resource key security feature.

Version History

View releases on the glinkfix git repository

License

This project is licensed under the MIT License. See the LICENSE file for details.

Acknowledgements

This project uses the pyperclip library which is licensed under the BSD 3 Clause License. The full license text can be found in the LICENSE-BSD-3-CLAUSE file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

glinkfix-2.0.3.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

glinkfix-2.0.3-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file glinkfix-2.0.3.tar.gz.

File metadata

  • Download URL: glinkfix-2.0.3.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.20

File hashes

Hashes for glinkfix-2.0.3.tar.gz
Algorithm Hash digest
SHA256 09faca600240059d21e611e82d278acb4efd07aa593c638358749cfd73271295
MD5 7da3e7df459ac11c703d999ad8a7d52a
BLAKE2b-256 7c04c9017029666ffcb381318907892c77b0f10f26fe1a3bfda5af5daff22757

See more details on using hashes here.

File details

Details for the file glinkfix-2.0.3-py3-none-any.whl.

File metadata

  • Download URL: glinkfix-2.0.3-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.20

File hashes

Hashes for glinkfix-2.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 42cd3faadeb621172e534f7d3917a9d2fdad99d89a42622b0f5a6c4a7b289636
MD5 63e91362ae834e0cd6418ca1f4bb5a0e
BLAKE2b-256 c64f9c4fbd7aefd9671ff54a81d1fb7462381fef5c0828ebf396acc18cdfbb8d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page