Looking for help/directions on the following issue:
Apps script Web App losing permissions frequently.
A detailed explanation of the deployment:
I have a GAS Web App that has been published as a Web App and it is being "Executed as Me".
I have also created a version, and the script is then published on this specific version. Script also has a few time-driven triggers which are also set up on a specific published version.
According to Google Apps Script Documentation,
above are the best practices to be used for the deployment of an Apps Script project as Web App.
But recently, this GAS/Web app is losing permissions automatically even though there is no change in the script. So eventually, script triggers start throwing an error: "Authorization is required to perform that action".
Is there anything I am missing?
FYI, below are the permissions required for my script:
"oauthScopes": ["https://www.googleapis.com/auth/spreadsheets.readonly",
"https://www.googleapis.com/auth/userinfo.email",
"https://www.googleapis.com/auth/spreadsheets.currentonly",
"https://www.googleapis.com/auth/spreadsheets",
"https://www.googleapis.com/auth/gmail.readonly",
"https://www.googleapis.com/auth/gmail.modify",
"https://mail.google.com/",
"https://www.googleapis.com/auth/script.scriptapp",
"https://www.googleapis.com/auth/script.container.ui",
"https://www.googleapis.com/auth/forms",
"https://www.googleapis.com/auth/drive.readonly",
"https://www.googleapis.com/auth/drive"],
Related
I am new to google app script. I don't know how to deploy the Google add-on. I have tried some setups for deployment but have not been able to do the deployment. so, I have some questions below.?
Can we use the google app script add-on without deploying on google marketplace? or
how to use google add-on local environment?.
or
Can we use the google add-on just by passing appscript.json? as we do in excel? In the excel add-in we just pass the manifest file and we put the dist folder on the local server so anyone can use that add-in.
Can anyone guide me about this.
I suggest you read https://developers.google.com/apps-script/add-ons/ and https://developers.google.com/workspace/marketplace
To deploy an add-on (i.e. create a version of the script that can be used by an app in the Google Workspace Marketplace) see https://developers.google.com/apps-script/concepts/deployments
To test an add-on (install it without having to publish it in the Google Workspace Marketplace)
See https://developers.google.com/apps-script/add-ons/how-tos/testing-editor-addons.
To publish an app in the Google Workspace Marketplace see https://developers.google.com/apps-script/add-ons/how-tos/publish-add-on-overview and https://developers.google.com/workspace/marketplace/how-to-publish.
Sheets and other Google Workspace products are on the cloud, so you can't copy a file somewhere to install and add-on. If you have are a Google Workspace customer you can publish a private app in the Marketplace. Then the admin can install the app for its users.
I made a script that get a Drive folder by ID and then processes a function. I first used this script on the Apps Script Editor linked to a Google Sheet file on my Drive, before migrate to an Addon : it worked like a charm. This is what the code looks like :
Line 93 :
var parentFolder = DriveApp.getFolderById('##folderId##');
Then, I published a private AddOn of that script for our domain on the Google Workspace MarketPlace. The function "DriveApp" won't work and the only log i received is :
Uncaught at functionName (Code:93)
I specify that my AddOn is published domain-wide and installed by administrator... The Google Docs says (here : https://developers.google.com/apps-script/reference/drive):
However, if an add-on using the Drive service is published for
domain-wide installation and is installed by the administrator for
some or all users in the domain, or any Apps Script that has its OAuth
client allowlisted by the domain administrator, the add-on functions
for those users even if the Drive SDK is disabled in the domain.
I prefer using DriveApp than the Advance Drive API Service. Maybe a problem with "Google Workspace Add-ons" OAuth or ...? I am stucked.
I've been trying to update my add-on in the Google Workspace Marketplace and every time I try to deploy, my manifest file (appscript.json) changes, making it impossible to deploy a new version of my add-on.
https://youtu.be/PcNn39z9pac
Does anyone know why this is happening / what I can do to fix this error?
Thanks in advance!
I currently use a Google App Scripts on Google Sheets for my budgeting spreadsheet. Essentially, the way I have it set up is:
Buy item
Input expense onto Google form (which feeds into a spreadsheet)
Use Apps scripts to convert timestamp into yyyy-MM-dd
I've been using this process for 4 years but all of a sudden, today it stopped working by giving me this error below.
Error 401: deleted_client The OAuth client was deleted
Here's my app script:
Here's my trigger:
At some point your Apps Script project's attached Google Cloud Platform (GCP) project (which manages the Oauth client) was likely deleted. You could confirm this by going to the Apps Script project editor, click the gear on the left for Project Settings, then click the Project Number link in the Google Cloud Platform (GCP) Project section. If it loads the GCP console (using the correct Google account) but gives you an error instead of bringing you to the project, then it probably doesn't exist anymore.
First, check if it's been deleted within the past 30 days and could be recovered:
In the GCP console, go to the Manage resources page (project picker → three dots button → select your organization → Manage resources).
Below the list of organizations, folders, and projects, click Resources pending deletion.
If you see the project there, check the box then click Restore. In the dialog that appears, confirm that you want to restore the project.
Go back to the Apps Script project editor and run one of your functions, and it should allow you to authorize the project again instead of giving you the 401 error.
If the project does not appear in the Resources pending deletion list because it'd been deleted over 30 days ago:
Copy all of your Apps Script projects' files to your local machine. If there are many files, consider using the clasp CLI tool, which would allow you to clone the entire project locally with one clasp pull command.
[IMPORTANT] Confirm that all of the files have been stored locally (and backed up, if desired), because the Apps Script project will be deleted permanently.
Make note of any services which are enabled in the Services section of the Apps Script project editor sidebar.
Delete the Apps Script project by going to the Apps Script project's Overview page, then click the trash can labeled Delete project forever.
In your Google Sheets doc, go to Extensions → Apps Script again and it will create a new Apps Script project (with attached GCP project).
Save the default Code.gs file
Re-create the projects' files. If you'd used clasp pull in the first step, then you can use clasp push to push the files from your local machine back to the project. In this case, go to the Apps Script project's Project Settings page and copy the Script ID. Then update the scriptId in the local .clasp.json file, save it, then clasp push.
If there were Services enabled in the previous project, enable them again in the Services section of the editor sidebar.
Run one of your functions and it should allow you to authorize the project again instead of giving you the 401 error.
I have several dozen Google Sheets that I manage for my company that all use the same Apps Scripts library and I am trying to find the easiest way to be able to update the library and have the changes propagated to the Google Sheets. I understand the use Development mode so that the Google Sheets using the library have the most up-to-date code however that requires giving edit privileges of the Apps Scripts project to the Google Sheets users.
The alternative is to turn Development Mode off so that users would only require read privileges however, to then update the code used by the Google Sheets, I would need to save a new version of the Apps Scripts library and then manually update every Google Sheet with the new library version.
Is there anyway to update the library version used by a Google Sheet using one of the Google APIs or some other way that could be done programmatically?
Sorry for answering after 1 year,
If i understand, you have a Script Project which is a library for several users project and your problem is to deploy a livrary version in every client project.
As Alan Wells says, you just have to replace the manifest of each client project.
Your manifest is a appsscript.json file. (you could show/hide the manifest file in a project)
Manifest file syntax :
{
"timeZone": "XXX",
"dependencies": {
**** SOME dependencies you need for the client****
,
"libraries": [{
"userSymbol": "MAIN_SCRIPT_NAME",
"libraryId": "MAIN_SCRIPT_ID",
"version": "MAIN_SCRIPT_VERSION"
}]
},
"exceptionLogging": "STACKDRIVER"
}
You could use CLASP to manage your script easily.
In your example, in clasp, you create a master folder for your project and a subfolder for every Clients Script. You need to sync every subfolder to his GoogleAppsScript.
The initialisation could be long and boring, but with a little shell you be able to push the manifest to every client script with on click/script..
You just have to modify the manifest into your Master Folder and run a script like :
for x in `ls -d SubFolder*`; do (cp appsscript.json $x ; cd $x; clasp push -f >/dev/null ; cd ..; echo "Update done on "$x) ; done
Now you can update the manifest for every client, Library version is available, but the dependencies too... (if you need start some new, or end others)