Class Sesi memberikan akses ke informasi sesi, seperti alamat email pengguna (dalam beberapa situasi) dan setelan bahasa.
Metode
Metode | Jenis hasil yang ditampilkan | Deskripsi singkat |
---|---|---|
getActiveUser() | User | Mendapatkan informasi tentang pengguna saat ini. |
getActiveUserLocale() | String | Mendapatkan setelan bahasa pengguna saat ini sebagai string—misalnya, en untuk bahasa Inggris. |
getEffectiveUser() | User | Mendapatkan informasi tentang pengguna yang otoritasnya menjalankan skrip. |
getScriptTimeZone() | String | Mendapatkan zona waktu skrip. |
getTemporaryActiveUserKey() | String | Mendapatkan kunci sementara yang unik untuk pengguna aktif, tetapi tidak mengungkapkan identitas pengguna. |
Dokumentasi mendetail
getActiveUser()
Mendapatkan informasi tentang pengguna saat ini. Jika kebijakan keamanan tidak mengizinkan akses ke identitas pengguna, User.getEmail()
akan menampilkan string kosong. Keadaan saat alamat email tersedia dapat bervariasi: misalnya, alamat email pengguna tidak tersedia dalam konteks apa pun yang memungkinkan skrip berjalan tanpa otorisasi pengguna tersebut, seperti pemicu onOpen(e)
atau onEdit(e)
sederhana, fungsi kustom di Google Spreadsheet, atau aplikasi web yang di-deploy untuk "eksekusi sebagai saya" (yaitu, diotorisasi oleh developer, bukan pengguna).
Namun, pembatasan ini umumnya tidak berlaku jika developer menjalankan skripnya sendiri
atau berada dalam domain Google Workspace yang sama dengan pengguna.
// Log the email address of the person running the script. var email = Session.getActiveUser().getEmail(); Logger.log(email);
Return
User
— pengguna saat ini
Otorisasi
Skrip yang menggunakan metode ini memerlukan otorisasi dengan satu atau beberapa cakupan berikut:
-
https://www.googleapis.com/auth/userinfo.email
getActiveUserLocale()
Mendapatkan setelan bahasa pengguna saat ini sebagai string—misalnya, en
untuk bahasa Inggris.
// Log the language setting of the person running the script. Logger.log(Session.getActiveUserLocale());
Return
String
— string yang mewakili setelan bahasa pengguna
getEffectiveUser()
Mendapatkan informasi tentang pengguna yang otoritasnya menjalankan skrip. Jika skrip adalah
aplikasi web yang ditetapkan ke "eksekusi sebagai saya" (developer), skrip ini akan menampilkan akun pengguna developer. Jika skrip berjalan berdasarkan pemicu yang dapat diinstal, akun pengguna yang membuat pemicu akan ditampilkan. Dalam sebagian besar skenario
lainnya, metode ini akan menampilkan akun yang sama dengan getActiveUser()
.
// Log the email address of the user under whose authority the script is running. var email = Session.getEffectiveUser().getEmail(); Logger.log(email);
Return
User
— pengguna yang otoritasnya menjalankan skrip
Otorisasi
Skrip yang menggunakan metode ini memerlukan otorisasi dengan satu atau beberapa cakupan berikut:
-
https://www.googleapis.com/auth/userinfo.email
getScriptTimeZone()
Mendapatkan zona waktu skrip. Skrip baru ditetapkan secara default ke zona waktu pemilik, tetapi zona waktu skrip dapat diubah dengan mengklik File > Properti project di editor skrip. Perhatikan bahwa spreadsheet memiliki zona waktu terpisah, yang dapat diubah dengan mengklik File > Setelan spreadsheet di Google Spreadsheet. Zona waktu spreadsheet yang berbeda dari zona waktu skrip sering kali menjadi sumber bug skrip.
// Log the time zone of the script. var timeZone = Session.getScriptTimeZone(); Logger.log(timeZone);
Return
String
— zona waktu skrip
getTemporaryActiveUserKey()
Mendapatkan kunci sementara yang unik untuk pengguna aktif, tetapi tidak mengungkapkan identitas pengguna. Kunci sementara dirotasi setiap 30 hari dan bersifat unik untuk skrip.
// Log the temporary key of the person running the script. Logger.log(Session.getTemporaryActiveUserKey());
Return
String
— kunci pengguna aktif sementara