גישה לטריגרים ולפרסום של סקריפטים, וביצוע פעולות בהם. הכיתה הזו מאפשרת למשתמשים ליצור טריגרים של סקריפטים ולשלוט בפרסום הסקריפט כשירות.
מאפיינים
נכס | סוג | תיאור |
---|---|---|
Auth | Auth | ספירה שמזהה את הקטגוריות של השירותים המורשים ש-Apps Script יכול להריץ באמצעות פונקציה מופעלת. |
Authorization | Authorization | ספירה שמציינת את סטטוס ההרשאה של סקריפט. |
Event | Event | ספירה שמציינת את סוג האירוע שהופעל. |
Installation | Installation | ספירה שמציינת איך הסקריפט הותקן אצל המשתמש כתוסף. |
Trigger | Trigger | ספירה שמציינת את המקור של האירוע שגורם להפעלת הטריגר. |
Week | Weekday | Enumeration שמייצג את ימי השבוע. |
Methods
שיטה | סוג הערך המוחזר | תיאור קצר |
---|---|---|
delete | void | הסרת הטריגר הנתון כדי שהוא לא יפעל יותר. |
get | Authorization | הפונקציה מקבלת אובייקט שבודק אם המשתמש העניק הרשאה לכל הדרישות של הסקריפט. |
get | Authorization | הפונקציה מקבלת אובייקט שבודק אם המשתמש העניק הרשאה להיקפי ההרשאות המבוקשים. |
get | String | הפונקציה מקבלת אסימון זהות של Openopenid הוענק. |
get | Installation | הפונקציה מחזירה ערך enum שמציין איך הסקריפט הותקן כתוסף למשתמש הנוכחי (לדוגמה, אם המשתמש התקין אותו באופן אישי דרך חנות האינטרנט של Chrome, או אם אדמין דומיין התקין אותו לכל המשתמשים). |
get | String | הפונקציה מקבלת את אסימון הגישה מסוג OAuth 2.0 של המשתמש בפועל. |
get | Trigger[] | הפונקציה מקבלת את כל הגורמים המפעילים שניתן להתקין שמשויכים לפרויקט הנוכחי ולמשתמש הנוכחי. |
get | String | הפונקציה מקבלת את המזהה הייחודי של פרויקט הסקריפט. |
get | Service | הפונקציה מקבלת אובייקט שמשמש לשלוט בפרסום הסקריפט כאפליקציית אינטרנט. |
get | Trigger[] | הפונקציה מקבלת את כל הטריגרים שניתן להתקין שבבעלות המשתמש הזה במסמך הנתון, עבור הסקריפט או התוסף האלה בלבד. |
get | Trigger[] | הפונקציה מקבלת את כל הטריגרים שניתן להתקין שבבעלות המשתמש הזה בטופס הנתון, עבור הסקריפט או התוסף האלה בלבד. |
get | Trigger[] | הפונקציה מקבלת את כל הטריגרים שניתן להתקין שבבעלות המשתמש הזה בגיליון האלקטרוני הנתון, עבור הסקריפט או התוסף האלה בלבד. |
invalidate | void | מבטלת את ההרשאה של המשתמש בפועל להריץ את הסקריפט הנוכחי. |
new | State | יצירת בונה לאסימון מצב שאפשר להשתמש בו ב-API של קריאה חוזרת (כמו תהליך OAuth). |
new | Trigger | התחלת התהליך של יצירת טריגר שניתן להתקנה, שמפעיל פונקציה נתונה. |
require | void | בדיקה אם המשתמש נתן הסכמה לכל ההיקפים שבהם ביקש הסקריפט להשתמש. |
require | void | בדיקה אם המשתמש נתן הסכמה להיקפי הגישה המבוקשים. |
מסמכים מפורטים
delete Trigger(trigger)
הסרת הטריגר הנתון כדי שהוא לא יפעל יותר.
// Deletes all triggers in the current project. const triggers = ScriptApp.getProjectTriggers(); for (let i = 0; i < triggers.length; i++) { ScriptApp.deleteTrigger(triggers[i]); }
פרמטרים
שם | סוג | תיאור |
---|---|---|
trigger | Trigger | הגורם להפעלת המחיקה. |
אישור
סקריפטים שמשתמשים בשיטה הזו דורשים הרשאה עם אחד או יותר מהיקפי הגישה הבאים:
-
https://www.googleapis.com/auth/script.scriptapp
get Authorization Info(authMode)
הפונקציה מקבלת אובייקט שבודק אם המשתמש העניק הרשאה לכל הדרישות של הסקריפט. האובייקט מספק גם כתובת URL להרשאה, כדי שהמשתמשים יוכלו להעניק את ההרשאות האלה, במקרה שאחת מדרישות הסקריפט לא מאושרת.
חלק מההפעלות של סקריפטים יכולות להתחיל בלי הסכמה של המשתמש לכל ההיקפים הנדרשים שבהם הסקריפט משתמש. המידע באובייקט הזה מאפשר לשלוט בגישה לקטעי קוד שדורשים היקפים מסוימים, ולבקש הרשאה להיקפים האלה לביצועים הבאים.
const authInfo = ScriptApp.getAuthorizationInfo(ScriptApp.AuthMode.FULL); const status = authInfo.getAuthorizationStatus(); const url = authInfo.getAuthorizationUrl();
פרמטרים
שם | סוג | תיאור |
---|---|---|
auth | Auth | מצב ההרשאה שאליו מתייחסים פרטי ההרשאה המבוקשים. ברוב המקרים, הערך של auth צריך להיות Script , כי בשום מצב הרשאה אחר המשתמשים לא נדרשים להעניק הרשאה. |
חזרה
Authorization
– אובייקט שיכול לספק מידע על סטטוס ההרשאה של המשתמש.
get Authorization Info(authMode, oAuthScopes)
הפונקציה מקבלת אובייקט שבודק אם המשתמש העניק הרשאה להיקפי ההרשאות המבוקשים. האובייקט מספק גם כתובת URL להרשאה, כדי שהמשתמשים יוכלו להעניק את ההרשאות האלה, במקרה שאחד מההיקפים המבוקשים לא מורשה.
חלק מההפעלות של סקריפטים יכולות להתחיל בלי הסכמה של המשתמש לכל ההיקפים הנדרשים שבהם הסקריפט משתמש. המידע באובייקט הזה מאפשר לשלוט בגישה לקטעי קוד שדורשים היקפים מסוימים, ולבקש הרשאה להיקפים האלה לביצועים הבאים. היקפים לא תקינים או היקפים שלא נדרשים על ידי הסקריפט יגרמו לשגיאה.
const authInfo = ScriptApp.getAuthorizationInfo(ScriptApp.AuthMode.FULL, [ 'https://www.googleapis.com/auth/documents', 'https://www.googleapis.com/auth/presentations', ]); const status = authInfo.getAuthorizationStatus(); const url = authInfo.getAuthorizationUrl();
פרמטרים
שם | סוג | תיאור |
---|---|---|
auth | Auth | מצב ההרשאה שאליו מתייחסים פרטי ההרשאה המבוקשים. ברוב המקרים, הערך של auth צריך להיות Script , כי בשום מצב הרשאה אחר המשתמשים לא נדרשים להעניק הרשאה. |
oAuthScopes | String[] | היקפי ההרשאות של OAuth שבשבילם מתבקש מידע לגבי הרשאה. |
חזרה
Authorization
— אובייקט שמספק מידע על סטטוס ההרשאה של המשתמש ועל כתובת URL להרשאה, למקרה שחסרות הסכמות מסוימות.
get Identity Token()
הפונקציה מקבלת אסימון זהות של Openopenid
הוענק. ההיקף הזה לא נכלל כברירת מחדל, וצריך להוסיף אותו כהיקף מפורש בקובץ המניפסט כדי לבקש אותו. כדי להחזיר פרטי משתמש נוספים באסימון, צריך לכלול את ההיקפים https://www.googleapis.com/auth/userinfo.email
או https://www.googleapis.com/auth/userinfo.profile
.
אסימון המזהה המוחזר הוא אסימון אינטרנט מסוג JSON (JWT) מקודד, וצריך לבצע פענוח כדי לחלץ ממנו מידע. בדוגמאות הבאות מוסבר איך לפענח את האסימון ולחלץ את מזהה פרופיל Google של המשתמש בפועל.
const idToken = ScriptApp.getIdentityToken(); const body = idToken.split('.')[1]; const decoded = Utilities .newBlob( Utilities.base64Decode(body), ) .getDataAsString(); const payload = JSON.parse(decoded); Logger.log(`Profile ID: ${payload.sub}`);
חזרה
String
– אסימון הזהות, אם הוא זמין. אחרת, null
.
get Installation Source()
הפונקציה מחזירה ערך enum שמציין איך הסקריפט הותקן כתוסף למשתמש הנוכחי (לדוגמה, אם המשתמש התקין אותו באופן אישי דרך חנות האינטרנט של Chrome, או אם אדמין דומיין התקין אותו לכל המשתמשים).
חזרה
Installation
– מקור ההתקנה.
get OAuth Token()
הפונקציה מקבלת את אסימון הגישה מסוג OAuth 2.0 של המשתמש בפועל. אם היקפי ההרשאות של OAuth בסקריפט מספיקים כדי להעניק הרשאה ל-Google API אחר שבדרך כלל נדרש תהליך OAuth משלו (כמו Google Picker), סקריפטים יכולים לעקוף את ההודעה השנייה לגבי הרשאה על ידי העברת הטוקן הזה במקום זאת. תוקף האסימון פג לאחר זמן מה (לפחות כמה דקות). סקריפטים צריכים לטפל בכשלים באישור ולהפעיל את השיטה הזו כדי לקבל אסימון חדש לפי הצורך.
האסימון שהשיטה הזו מחזירה כולל רק את ההיקפים הנחוצים כרגע לסקריפט. הרשאות שהתקבלו בעבר אבל הסקריפט כבר לא משתמש בהן לא נכללות באסימון המוחזר. אם אתם זקוקים להיקפי הרשאות נוספים של OAuth מעבר לאלה שנדרשים בסקריפט עצמו, תוכלו לציין אותם בקובץ המניפסט של הסקריפט.
חזרה
String
– ייצוג מחרוזת של אסימון OAuth 2.0.
get Project Triggers()
הפונקציה מקבלת את כל הגורמים המפעילים שניתן להתקין שמשויכים לפרויקט הנוכחי ולמשתמש הנוכחי.
Logger.log( `Current project has ${ScriptApp.getProjectTriggers().length} triggers.`, );
חזרה
Trigger[]
– מערך של הגורמים המפעילים של המשתמש הנוכחי שמשויכים לפרויקט הזה.
אישור
סקריפטים שמשתמשים בשיטה הזו דורשים הרשאה עם אחד או יותר מהיקפי הגישה הבאים:
-
https://www.googleapis.com/auth/script.scriptapp
get Script Id()
הפונקציה מקבלת את המזהה הייחודי של פרויקט הסקריפט. זוהי השיטה המועדפת לקבלת המזהה הייחודי של פרויקט הסקריפט, בניגוד ל-
. אפשר להשתמש במזהה הזה בכל המקומות שבהם מפתח הפרויקט סופק בעבר.get
חזרה
String
– המזהה של פרויקט הסקריפט.
get Service()
הפונקציה מקבלת אובייקט שמשמש לשליטה בפרסום הסקריפט כאפליקציית אינטרנט.
// Get the URL of the published web app. const url = ScriptApp.getService().getUrl();
חזרה
Service
– אובייקט המשמש למעקב אחרי פרסום הסקריפט כאפליקציית אינטרנט ולשליטה בו.
get User Triggers(document)
הפונקציה מקבלת את כל הטריגרים שניתן להתקין שבבעלות המשתמש הזה במסמך הנתון, עבור הסקריפט או התוסף האלה בלבד. אי אפשר להשתמש בשיטה הזו כדי לראות את הטריגרים שמצורפים לסקריפטים אחרים.
const doc = DocumentApp.getActiveDocument(); const triggers = ScriptApp.getUserTriggers(doc); // Log the handler function for the first trigger in the array. Logger.log(triggers[0].getHandlerFunction());
פרמטרים
שם | סוג | תיאור |
---|---|---|
document | Document | קובץ ב-Google Docs שעשוי להכיל טריגרים שניתן להתקין. |
חזרה
Trigger[]
– מערך של טריגרים שבבעלות המשתמש הזה במסמך הנתון.
אישור
סקריפטים שמשתמשים בשיטה הזו דורשים הרשאה עם אחד או יותר מהיקפי הגישה הבאים:
-
https://www.googleapis.com/auth/script.scriptapp
get User Triggers(form)
הפונקציה מקבלת את כל הטריגרים שניתן להתקין שבבעלות המשתמש הזה בטופס הנתון, עבור הסקריפט או התוסף האלה בלבד. אי אפשר להשתמש בשיטה הזו כדי לראות את הטריגרים שמצורפים לסקריפטים אחרים.
const form = FormApp.getActiveForm(); const triggers = ScriptApp.getUserTriggers(form); // Log the trigger source for the first trigger in the array. Logger.log(triggers[0].getTriggerSource());
פרמטרים
שם | סוג | תיאור |
---|---|---|
form | Form | קובץ ב-Google Forms שעשוי להכיל טריגרים שניתן להתקין. |
חזרה
Trigger[]
– מערך של טריגרים שבבעלות המשתמש הזה בטופס הנתון.
אישור
סקריפטים שמשתמשים בשיטה הזו דורשים הרשאה עם אחד או יותר מהיקפי הגישה הבאים:
-
https://www.googleapis.com/auth/script.scriptapp
get User Triggers(spreadsheet)
הפונקציה מקבלת את כל הטריגרים שניתן להתקין שבבעלות המשתמש הזה בגיליון האלקטרוני הנתון, עבור הסקריפט או התוסף האלה בלבד. אי אפשר להשתמש בשיטה הזו כדי לראות את הטריגרים שמצורפים לסקריפטים אחרים.
const ss = SpreadsheetApp.getActiveSpreadsheet(); const triggers = ScriptApp.getUserTriggers(ss); // Log the event type for the first trigger in the array. Logger.log(triggers[0].getEventType());
פרמטרים
שם | סוג | תיאור |
---|---|---|
spreadsheet | Spreadsheet | קובץ Google Sheets שעשוי להכיל טריגרים שניתן להתקין. |
חזרה
Trigger[]
– מערך של טריגרים שבבעלות המשתמש הזה בגיליון האלקטרוני הנתון.
אישור
סקריפטים שמשתמשים בשיטה הזו דורשים הרשאה עם אחד או יותר מהיקפי הגישה הבאים:
-
https://www.googleapis.com/auth/script.scriptapp
invalidate Auth()
מבטלת את ההרשאה של המשתמש בפועל להריץ את הסקריפט הנוכחי. משמש לביטול כל ההרשאות של הסקריפט הנוכחי. האפשרות הזו שימושית במיוחד לפונקציות שמתויגות כאישור לשימוש חד-פעמי. מאחר שאפשר להפעיל פונקציות של הרשאה לפעולה אחת רק בהפעלה הראשונה אחרי שהסקריפט קיבל הרשאה, אם רוצים לבצע פעולה לאחר מכן, צריך לבטל את כל ההרשאות שהסקריפט קיבל כדי שהמשתמש יוכל לראות שוב את תיבת הדו-שיח של ההרשאה.
ScriptApp .invalidateAuth();
זריקות
Error
– כשביטול התוקף נכשל
new State Token()
יצירת בונה לאסימון מצב שאפשר להשתמש בו ב-API של קריאה חוזרת (כמו תהליך OAuth).
// Generate a callback URL, given the name of a callback function. The script // does not need to be published as a web app; the /usercallback URL suffix // replaces /edit in any script's URL. function getCallbackURL(callbackFunction) { // IMPORTANT: Replace string below with the URL from your script, minus the // /edit at the end. const scriptUrl = 'https://script.google.com/macros/d/1234567890abcdefghijklmonpqrstuvwxyz'; const urlSuffix = '/usercallback?state='; const stateToken = ScriptApp.newStateToken() .withMethod(callbackFunction) .withTimeout(120) .createToken(); return scriptUrl + urlSuffix + stateToken; }
ברוב תהליכי OAuth2, האסימון state
מועבר ישירות לנקודת הקצה להרשאה (לא כחלק מכתובת ה-URL של הקריאה החוזרת), ולאחר מכן נקודת הקצה להרשאה מעבירה אותו כחלק מכתובת ה-URL של הקריאה החוזרת.
לדוגמה:
- הסקריפט מפנה את המשתמש לכתובת ה-URL לאישור ב-OAuth2:
https://accounts.google.com/o/oauth2/auth?state=token_generated_with_this_method&callback_uri=https://script.google.com/macros/d/1234567890abcdefghijklmonpqrstuvwxyz/usercallback&other_oauth2_parameters
- המשתמש לוחץ על 'אישור', ודף ההרשאה של OAuth2 מפנה אותו חזרה אל
https://script.google.com/macros/d/1234567890abcdefghijklmonpqrstuvwxyz/usercallback?state=token_generated_with_this_method&other_params_that_include_tokens_or_grants
- ההפניה האוטומטית שלמעלה (חזרה אל
http://script.google.com/...
) גורמת לדפדפן לשלוח בקשה אל/usercallback
, שמפעילה את השיטה שצוינה ב-State
.Token Builder.withMethod(method)
חזרה
State
– אובייקט המשמש להמשך תהליך היצירה של אסימון המצב.
new Trigger(functionName)
התחלת התהליך של יצירת טריגר שניתן להתקנה, שמפעיל פונקציה נתונה.
// Creates an edit trigger for a spreadsheet identified by ID. ScriptApp.newTrigger('myFunction') .forSpreadsheet('1234567890abcdefghijklmnopqrstuvwxyz_a1b2c3') .onEdit() .create();
פרמטרים
שם | סוג | תיאור |
---|---|---|
function | String | הפונקציה שתופעל כשהטריגר יופעל. אפשר להשתמש בפונקציות מספריות כלולות, כמו Library.libFunction1 . |
חזרה
Trigger
– אובייקט שמשמש להמשך תהליך היצירה של הטריגר.
אישור
סקריפטים שמשתמשים בשיטה הזו דורשים הרשאה עם אחד או יותר מהיקפי הגישה הבאים:
-
https://www.googleapis.com/auth/script.scriptapp
require All Scopes(authMode)
בדיקה אם המשתמש נתן הסכמה לכל ההיקפים שבהם ביקש הסקריפט להשתמש. משתמשים בשיטה הזו אם תהליך ההפעלה מסתמך על כל ההיקפים שהסקריפט מבקש. אם חסרות הסכמות, השיטה הזו מסיימת את הביצוע הנוכחי ומציגה הרשאה לבקש את ההסכמות החסרות.
השיטה הזו פועלת רק כשמשתמשים מריצים את הסקריפט מפנייה שתומכת בהסכמה מפורטת, למשל מתוך סביבת הפיתוח המשולבת (IDE) של Apps Script. כשהסקריפט מופעל בלי הסכמות חסרות משטח לא נתמך, כמו תוסף של Google Workspace, הוא מציג בקשה להרשאה בתחילת הביצוע כדי לבקש את כל ההיקפים.
ScriptApp .requireAllScopes(ScriptApp.AuthMode.FULL);
פרמטרים
שם | סוג | תיאור |
---|---|---|
auth | Auth | מצב ההרשאה שעבורו צריך להעריך את היקפי הסקריפטים. כמעט בכל המקרים, הערך של auth צריך להיות Script , כי בשום מצב הרשאה אחר המשתמשים לא נדרשים להעניק הרשאה. |
require Scopes(authMode, oAuthScopes)
בדיקה אם המשתמש נתן הסכמה להיקפי הגישה המבוקשים. משתמשים בשיטה הזו אם תהליך הביצוע מסתמך על שירות אחד או יותר. אם אחת מההסכמות שצוינו חסרה, השיטה הזו תסתיים את הביצוע הנוכחי ותציג הודעה על הרשאה כדי לבקש את ההסכמות החסרות. היקפים לא תקינים או היקפים שלא נדרשים על ידי הסקריפט יגרמו לשגיאה.
השיטה הזו פועלת רק כשמשתמשים מריצים את הסקריפט משטח שתומך בהסכמה מפורטת, למשל מתוך סביבת הפיתוח המשולבת (IDE) של Apps Script. כשהסקריפט מופעל בלי הסכמות חסרות משטח לא נתמך, כמו תוסף של Google Workspace, הוא מציג בקשה להרשאה בתחילת הביצוע כדי לבקש את כל ההיקפים.
ScriptApp .requireScopes(ScriptApp.AuthMode.FULL, [ 'https://www.googleapis.com/auth/documents', 'https://www.googleapis.com/auth/presentations', ]);
פרמטרים
שם | סוג | תיאור |
---|---|---|
auth | Auth | מצב ההרשאה שבו צריך להעריך את ההיקפים המבוקשים. ברוב המקרים, הערך של auth צריך להיות Script , כי בשום מצב הרשאה אחר המשתמשים לא צריכים להעניק הרשאה. |
oAuthScopes | String[] | היקפי ההרשאות של OAuth הנדרשים כדי להשלים את תהליך הביצוע. |