How to handle Google SpreadSheet with Magic xpi using REST Google API
1/ Connect to Google Developer Console (https://console.cloud.google.com) with your gmail account
2/ Create a new project « SpreadSheet »
data:image/s3,"s3://crabby-images/adfb6/adfb6f076c92b33355f719c6a29775395fe9ad6d" alt=""
3/ Choose APIs & services => Library and choose Sheets and enable it
data:image/s3,"s3://crabby-images/6e118/6e11860b8c6aee113c3a2f37508d378e7287d8f6" alt=""
data:image/s3,"s3://crabby-images/247d9/247d9116369ea2bf98600a6997360cbd2013eca3" alt=""
4/ Choose credentials Define an OAuth client ID with type Desktop Application
data:image/s3,"s3://crabby-images/fa401/fa401858d11480c2a336b79c0f453c34e90396a7" alt=""
You need to set the scope to :
https://www.googleapis.com/auth/spreadsheets and https://www.googleapis.com/auth/drive
data:image/s3,"s3://crabby-images/58c7b/58c7bcf0d22b4615579c2c0696e13a3166b3972b" alt=""
data:image/s3,"s3://crabby-images/1929b/1929bf65b645dd154254909dde03ac9817cd69e9" alt=""
Keep the client Id and ClientSecret and the call Back URL (http://localhost)
5/ Check with Postman that you can interact with a Google Sheet.
Fill all the relevant informations to get the Access Token and execute a Put operation
data:image/s3,"s3://crabby-images/368b3/368b3f01c099bb8ac466193bb654f053cbdf985e" alt=""
data:image/s3,"s3://crabby-images/ac4e7/ac4e7d3a5a9a0be9c1257b153d2dbf78940cd41f" alt=""
6/ Define a REST Client resource in a magic xpi project
data:image/s3,"s3://crabby-images/d7163/d7163080b49c2016b4fbad07292411e4da4c9e9a" alt=""
Call Back URL must be in our case : http://localhost
Fill the Client id and Client Secret.
Set the Authorization URL to : https://accounts.google.com/o/oauth2/auth
Set the Access Token URL to : https://oauth2.googleapis.com/token
Set the scope to : https://www.googleapis.com/auth/spreadsheets https://www.googleapis.com/auth/drive
Click on Access Token to acquire the Token
data:image/s3,"s3://crabby-images/fab0a/fab0adc94e03938f9acc5260944ac0e4b99bfbcf" alt=""
Sign with you gmail account then you will be redirected to a page and choose go to Spreadsheet at the bottom
data:image/s3,"s3://crabby-images/75aee/75aeeed7585f632d98e73ff30469173a9d6e9618" alt=""
And confirm the access
data:image/s3,"s3://crabby-images/4d265/4d265cf9f9debe9ce24594c34b5ab2d39ecab69e" alt=""
data:image/s3,"s3://crabby-images/4f277/4f277d7f240a115c4fa5fe0d507b6d86a592085b" alt=""
data:image/s3,"s3://crabby-images/4a24a/4a24a82c809a56b8d6473510d3ace07defba97b3" alt=""
Define Paths that you want to interact with the API (use {} to use parameter)
data:image/s3,"s3://crabby-images/8340a/8340ad885d09dddd6865936c7b6d020d679bef5f" alt=""
You can use Google Workspace explorer ( Sheet API) to test and to get the different paths (https://developers.google.com/workspace/)
data:image/s3,"s3://crabby-images/6e416/6e416a0be7f1bc3ef2eca9610baec6dce70a6508" alt=""
Google Sheet API specification can be found at https://sheets.googleapis.com/$discovery/rest?version=v4
7/ To get a Google SpreadSheet, Drag and Drop a REST Client connector
Configure the connector to GET a SpreadSheet
data:image/s3,"s3://crabby-images/e13f1/e13f1dff99e6ae3eaed546c399d89761c6330f89" alt=""
Set {endpath} parameter to 1KSrbWrBezXI437ZgdJAozE8tssdj6OtRnJyimsBwRAw/values/A2%3AB (<sheetid>/values/<range>)
data:image/s3,"s3://crabby-images/26806/268060233ec96dbcf2c4a4230e9d97efd5727aa4" alt=""
After flow execution, you should receive the result in a a json format
data:image/s3,"s3://crabby-images/ef9c2/ef9c2955800148fc8e8009dd8ca3e993c7361685" alt=""
8/ To send data to a Google SpreadSheet
Build a json request in the format below (use a datamapper for this step)
{« values »: [[« ALEM », »JOHN »],[« DAVID », »ISNER »],[« MAHER », »METHENY »],[« ROSS », »HARRIS »]]}
Configure the REST Client connector for PUT operation and set {upload} parameter to 1KSrbWrBezXI437ZgdJAozE8tssdj6OtRnJyimsBwRAw/values/A2%3AB (<sheetid>/values/<range>)
Pass the Blob Json request to DataBlob
data:image/s3,"s3://crabby-images/b2fc5/b2fc563903f2d3aa8749b2cd9d78f4438d9340f3" alt=""
You should receive this type of JSON response
data:image/s3,"s3://crabby-images/1ffab/1ffab8c363f5857b63cfa24b0b5e16d379a9b049" alt=""
data:image/s3,"s3://crabby-images/0a3ff/0a3ff5f30cdaf586c960d9b2b5c38565af473198" alt=""
9/ To clear data, do a POST with this parameter in the URL
https://sheets.googleapis.com/v4/spreadsheets/<SpreadSheetId>/values/<Range>:clear
with empty json {}
example fill the {endpath} parameter with : 1KSrbWrBezXI437ZgdJAozE8tssdj6OtRnJyimsBwRAw/values/A4%3AB:clear
and leave the DataBlob empty
data:image/s3,"s3://crabby-images/914eb/914eb1a1abd685bf84671e1c995b0321c2b14654" alt=""
data:image/s3,"s3://crabby-images/a2bd2/a2bd21f7153994e3cb954921b3087ae4bac14b60" alt=""
10/ Relevant links