No internet connection
  1. Home
  2. General

Announcing Google Sheet Sync

By Matt Frisbie @mattfriz
    2024-09-03 18:03:20.046Z2024-09-04 19:21:33.884Z

    Today, I'm launching a new feature for the T3 API that lets you sync your Metrc data to Google Sheets: Google Sheet Sync!

    What is Google Sheet Sync?

    Google Sheet Sync allows you to import entire Metrc datasets into a Google sheet with a single cell formula. The sheet will stay up-to-date with Metrc (updating at least once per hour).

    How does it work?

    T3 API Reports capture snapshots of your Metrc data all in a single request. Google Sheet Sync allows you to form a single Sync Link that loads your report data. This Sync Link can then be passed to the IMPORTDATA() formula in Google Sheets.

    How to get started with Google Sheet Sync?

    Become a T3+ subscriber.

    Google Sheet Sync is only available to T3+ subscribers. You can start your 30 day free trial here.

    1) Generate your secret key

    • Generate your secret key here.
    • Store this secret key in a secure place, there is no way to access it again.
    • Do not share this secret key! It allows access to your Metrc data

    2) Create your Google Sheet Sync Link

    All the information needed to generate the report is included in the Sync Link. At minimum, you will need:

    • The path of the report you wish to generate (available in the API docs
    • The license number for the data that should appear in the report
    • Your secret key

    For example, let's say you want to create an Active Packages report for the EX-00001 license.

    • Report path (taken from the API docs): /v2/packages/active/report
    • License number: EX-00001
    • Secret key: 1234-1234-1234-1234-1234-1234

    Your Sync Link would be: https://api.trackandtrace.tools/v2/packages/active/report?secretKey=1234-1234-1234-1234-1234-1234&licenseNumber=EX-00001&contentType=csv

    Note: contentType=csv is required

    Note: Do not share this Sync Link! Anyone who has it can load all your Metrc Data

    3) Import Data into Google Sheets

    Pass your Sync Link to the Google Sheets IMPORTDATA() function. Every hour, this function will load the report data using your Sync Link and insert it into the sheet.

    In Google Sheets, in Cell A1, you would paste =IMPORTDATA("https://api.trackandtrace.tools/v2/packages/active/report?secretKey=1234-1234-1234-1234-1234-1234&licenseNumber=EX-00001&contentType=csv")

    Loading your data usually takes 15-20 seconds. The IMPORTDATA function automatically refreshes the information about once per hour.

    Example output (redacted):

    Bonus: Advanced Usage

    These reports can be configured to include filters, sorting, and can return either JSON or CSV data.

    • If you wanted to only return packages in the Bulk Storage room, you would add &filter=locationName__eq:Bulk Storage to your Sync Link
    • If you wanted to control which columns you want in the report, you would add &fieldnames=label,productionBatchNumber,labTestingStateName to your Sync Link

    Details here: https://api.trackandtrace.tools/v2/docs/#/Reports/get_v2_packages_active_report

    • 9 replies
    1. J
      Joey Espinoza @joey
        2024-09-07 05:15:50.214Z

        Could you provide a list of field names?

        1. JJoey Espinoza @joey
            2024-09-08 09:09:22.561Z

            specifically was trying to learn what category should be titled

            1. MMatt Frisbie @mattfriz
                2024-09-09 13:41:34.694Z

                I'll be making a followup YouTube video to demo all the advanced ways to use this, but I'll give a crash course here.

                In the video at 2:28, the report header shows dataModel, which is listed as MetrcPackage. The dataModel describes what objects are being returned for the current report, and what columns are available.

                To see a list of columns for MetrcPackage, refer to the API docs (https://api.trackandtrace.tools/v2/docs/): at the bottom of the page, there is a Schemas section:

                In Schemas, find MetrcPackage and expand it to see all the possible columns:

                So if you wanted to specify the columns to show License Number, Facility Name, Label, and Production Batch Number, you would add the following to your Sync Link:

                https://api.trackandtrace.tools/v2/packages/active/report?licenseNumber=...&secretKey=...&contentType=csv&fieldnames=licenseNumber,facilityName,label,productionBatchNumber

                These will be returned as the column headers.


                MetrcPackage has a special scenario, where item is nested inside it.

                If you want to show an item column, you add item.* in front of it. For example, the Item Category, you would use item.productCategoryName.

                Example sync link:

                https://api.trackandtrace.tools/v2/packages/active/report?licenseNumber=...&secretKey=...&contentType=csv&fieldnames=licenseNumber,facilityName,label,productionBatchNumber,item.productCategoryName

                1. In reply tojoey:
                  MMatt Frisbie @mattfriz
                    2024-09-10 18:00:37.680Z
                2. J
                  In reply tomattfriz:
                  Joey Espinoza @joey
                    2025-01-17 02:44:39.805Z

                    Is it possible to get a list of pending incoming/outgoing transfers via this at all?

                    1. In reply tojoey:
                      MMatt Frisbie @mattfriz
                        2025-01-17 03:20:23.250Z

                        Not currently, but it could be added.

                        The returned values would not have the lists of packages in the transfers, is this OK? If packages are needed it's a little bit trickier.

                        1. JJoey Espinoza @joey
                            2025-01-17 06:10:21.170Z

                            With packages would be better. I noticed the intransit google sync is almost as good. If it's possible to show who the transfer is going to via that method & it's easier that way could be another option to achieve my goal.

                            1. MMatt Frisbie @mattfriz
                                2025-01-17 15:07:23.973Z

                                Outgoing transfers could be cleverly zipped together with intransit packages, that wouldn't be too bad. The problem is that for incoming transfers, you need to look up what packages they have one at a time, which is really slow. There's no equivalent index to outgoing since the packages aren't in custody yet. For this to work, there's some additional infrastructure needed. Fortunately it aligns with other efforts I'm currently developing.

                                For now, I can roll out the transfer-only endpoints, and then iterate on top of them as other efforts progress.

                                1. JJoey Espinoza @joey
                                    2025-01-17 17:30:16.696Z

                                    For incoming transfers not knowing packages is okay. Knowing is best but there's still value without