Skip to content

Ville-Eurometropole-Strasbourg/grist-ctl

Repository files navigation

GristCTL : Command Line Interface (CLI) for Grist

img REUSE status

Grist is a versatile platform for creating and managing custom data applications. It blends the capabilities of a relational database with the adaptability of a spreadsheet, empowering users to design advanced data workflows, collaborate in real-time, and automate tasks—all without requiring code.

GRIST logo

gristctl is a command-line utility designed for interacting with Grist. It allows users to automate and manage tasks related to Grist documents, including creating, updating, listing, deleting documents, and retrieving data from them.

Installation

To get started with gristctl, follow the steps below to install the tool on your machine.

Installing from exec files

Download exec files from release. Extract the archive and copy the gristctl file corresponding to your runtime environment into a directory in your PATH.

Windows

That means you can either:

  • copy the gristctl.exe into a directory that is in your PATH
  • add the directory that contains gristctl.exe in your PATH environment variable

Installing from Source

Prerequisites

  • If you want to build from sources, ensure you have a working installation of Go (version 1.23 or later).
  • You should also have access to a Grist instance.

Build

To install gristctl from source:

  1. Clone the repository:

    git clone https://github.com/Ville-Eurometropole-Strasbourg/gristctl.git
  2. Open a terminal (or command prompt on Windows) and navigate to the gristctl directory:

    cd gristctl
  3. Build the tool:

    go build
    • Note: If dependencies don't install automatically you may need to install them manually (ex: go get gristctl/gristapi) then build again.
  4. Once the build is completed, you can move the binary (gristctl.exe) to your PATH.

Windows

That means you can either:

  • copy the gristctl.exe into a directory that is in your PATH
  • add the directory that contains gristctl.exe in your PATH environment variable
Linux/macOS

Exemple:

sudo mv gristctl /usr/local/bin/

Configuration

You will need your Grist instance URL and your Grist user token/API key (to find it you can follow the official documentation).

Interactively

You can configure gristctl with the following command :

$ gristctl config
----------------------------------------------------------------------------------
Setting the url and token for access to the grist server (/Users/me/.gristctl)
----------------------------------------------------------------------------------
Actual URL : https://wpgrist.cus.fr
Token : ✅
Would you like to configure (Y/N) ?
y
Grist server URL (https://......... without '/' in the end): https://grist.numerique.gouv.fr
User token : secrettoken
Url : https://grist.numerique.gouv.fr --- Token: secrettoken
Is it OK (Y/N) ? y
Config saved in /Users/me/.gristctl

Manually

Create a .gristctl file in your home directory containing the following information:

GRIST_TOKEN="user session token"
GRIST_URL="https://<GRIST server URL, without /api>"

Usage

List of commands :

  • config : configure url & token of Grist server
  • delete doc <id> : delete a document
  • delete user <id> : delete a user
  • delete workspace <id> : delete a workspace
  • get doc <id> : document details
  • get doc <id> access : list of document access rights
  • get doc <id> excel : export document as an Excel file (xlsx) in stdout
  • get doc <id> grist : export document as a Grist file (Sqlite) in stdout
  • get doc <id> table : export content of a document's table as a CSV file (xlsx) in stdout
  • get org : organization list
  • get org <id> : organization details
  • get users : displays all user rights
  • get workspace <id> access : list of workspace access rights
  • get workspace <id> : workspace details
  • import users : imports users from standard input
  • purge doc <id> [<number of states to keep>] : purges document history (retains last 3 operations by default)
  • version : displays the version of the program

List Grist organization

To list all available Grist organization:

$ gristctl get org
+----+----------+
| ID |   NAME   |
+----+----------+
|  2 | Personal |
|  3 | ems      |
+----+----------+

Displays information about an organization

Example : get organization n°3 information, including the list of his workspaces :

$ gristctl get org 3
---------------------------------------
Organization n°3 : ems (30 workspaces)
---------------------------------------
+--------------+--------------------------------+-----+--------------+
| WORKSPACE ID |         WORKSPACE NAME         | DOC | DIRECT USERS |
+--------------+--------------------------------+-----+--------------+
|          350 | Direction-DSI                  |   4 |          285 |
|          341 | Service-INF                    |   2 |          284 |
|          649 | Service-PSS                    |   4 |            3 |
...
+--------------+--------------------------------+-----+--------------+

Describe a workspace

To fetch data from a Grist workspace with ID 676, including the list of his documents:

$ gristctl get workspace 676
-----------------------------------------------------------------------------------
Organization n°3 : "ems", workspace n°676 : "Cellule Stratégie Logiciels Libres"
-----------------------------------------------------------------------------------
Contains 1 documents :
+------------------------+------------+--------+
|           ID           |    NAME    | PINNED |
+------------------------+------------+--------+
| b8RzZzAJ4JgPWN1HKFTb48 | Ressources | 📌     |
+------------------------+------------+--------+

View workspace access rights

$ gristctl get workspace 676 access
--------------------------------------------------------------------
Workspace n°676 access rights : Cellule Stratégie Logiciels Libres
--------------------------------------------------------------------
Full inheritance of rights from the next level up

Accessible to the following users :
+-----+---------------+-----------------------------+------------------+---------------+
| ID  |      NOM      |            EMAIL            | INHERITED ACCESS | DIRECT ACCESS |
+-----+---------------+-----------------------------+------------------+---------------+
|   5 | xxxx xxxxxxx  | xxxx.xxxxxxx@strasbourg.eu  | owners           |               |
| 237 | xxxxxxx xxxxx | xxxxxxx.xxxxx@strasbourg.eu | owners           | owners        |
+-----+---------------+-----------------------------+------------------+---------------+
2 users

Delete a workspace

To delete a Grist workspace with ID 676:

gristctl delete workspace 676

Import users from an ActiveDirectory directory

Extract the list of members of AD groups GA_GRIST_PU and GA_GRIST_PA :

foreach ($grp in ('a', 'u')) {
    get-adgroupmember ga_grist_p$grp | get-aduser -properties mail, extensionAttribute6, extensionAttribute15 |select-object mail, extensionAttribute6, extensionAttribute15 | export-csv -Path ga_grist_p$grp.csv -NoTypeInformation -Encoding:UTF8
}
cat ga_grist_pu.csv | awk -F',' 'NR>1 {gsub(/"/, "", $0); print tolower($1)";3;Direction-"$2";viewers"}' | gristctl import users
cat ga_grist_pu.csv | awk -F',' 'NR>1 {gsub(/"/, "", $0); print tolower($1)";3;Service-"$3";viewers"}' | gristctl import users
cat ga_grist_pa.csv | awk -F',' 'NR>1 {gsub(/"/, "", $0); print tolower($1)";3;Direction-"$2";editors"}' | gristctl import users
cat ga_grist_pa.csv | awk -F',' 'NR>1 {gsub(/"/, "", $0); print tolower($1)";3;Service-"$3";editors"}' | gristctl import users

Contributing

We welcome contributions to gristctl. If you find a bug or want to improve the tool, feel free to open an issue or submit a pull request.

Steps for contributing

  1. Fork the repository.
  2. Create a new branch for your feature or bug fix.
  3. Commit your changes.
  4. Push your branch and create a pull request.

Please ensure that your code adheres to the project's coding style and includes tests where applicable.

License

This project is licensed under the MIT License