Search code examples
node.jsgoogle-cloud-platformgoogle-drive-apigoogle-workspaceservice-accounts

How to fix the storage exceeded issue for Google Drive when uploading using Service Accounts


If you're using Google Apps for Work (also called G-Suite) and uploading files to your Google Drive via the Drive API you'll eventually find yourself with an error message that looks like this:

Error: The user's Drive storage quota has been exceeded.

Read below to learn why this happens and how to solve it.


Solution

  • Background:

    Google Drive API is authorized using "service accounts", not regular "human users". Google does not currently have a way to increase the 15GB limit for service accounts, and there is no mechanism for buying additional space. Once you've consumed your standard space allocation you'll be prevented from uploading any additional files.

    Human/regular G-Suite users also get the standard 15GB but with simple options to increase it to 100GB or more for mere pennies.

    So how do you upload files against the storage quota of a human account rather than a service account so you can have as much space as you want? It's actually really simple! Just not super well documented...

    Solution:

    This solution is to configure your service account to impersonate a human account. This means you still authenticate to the Drive API using the service account but the service account is authorized to act on behalf of a human account and the storage space will be allocated from that user's quota.

    Prep: This is important. Carefully review the instructions here to make sure your service account is set up correctly for impersonation. Any deviation from this will give you random errors that will frustrate you and waste time. The service account needs to have DwD (domain-wide-delegation) enabled in the Google IAM Console AND it needs to be permitted to access the Drive scope in the API client access page of the Google Admin site.

    Now that your service account is properly set up, to impersonate a regular account you simply need to specify the human account email address when creating the JWT client.

    In NodeJS it looks like this (note the last parameter):

       let jwtClient = new GoogleApi.auth.JWT(
       service_account_email, 
       null, 
       private_key, 
       ['https://www.googleapis.com/auth/drive'],
       '[email protected]');
    

    For other languages, please refer to the official Google documentation for how to impersonate a user.

    When your Drive API script now uploads files they will be owned by this regular user and the space will be allocated from their quota. Increasing this is trivial and can be done by any administrator or by contacting G-Suite support.