사용자는 자신의 데이터에 액세스하거나 사용자를 대신하여 작업하는 부가기능 및 기타 애플리케이션을 승인해야 합니다. 사용자가 부가기능을 처음 실행하면 부가기능 UI에 승인 절차를 시작하기 위한 승인 메시지가 표시됩니다.
이 흐름 중에 프롬프트는 사용자에게 애플리케이션이 원하는 것을 알려줍니다. 할 수 있습니다. 예를 들어 부가기능에 콘텐츠를 읽을 수 있는 권한이 필요할 수 있습니다. 사용자의 이메일 메시지를 보내거나 캘린더에 일정을 만들 수 있습니다. 부가기능 스크립트 프로젝트에서 이러한 개별 권한을 OAuth 범위로 정의합니다.
매니페스트에서 범위 선언
URL 문자열을 사용합니다. 승인 흐름 중에 Apps Script는
인간이 읽을 수 있는 사용자 범위 설명입니다. 예를 들어 Google Workspace 부가기능은 매니페스트에 https://www.googleapis.com/auth/gmail.addons.current.message.readonly
로 작성된 '현재 메시지 읽기' 범위를 사용할 수 있습니다. 기간 중
승인 흐름에서 이 범위의 부가기능이 사용자에게
부가기능: 부가기능이 실행 중일 때 이메일 메시지 보기
보기 범위
다음을 실행하여 스크립트 프로젝트에 현재 필요한 범위를 확인할 수 있습니다.
- 스크립트 프로젝트를 엽니다.
- 왼쪽에서 개요 를 클릭합니다.
- '프로젝트 OAuth 범위'에서 범위를 확인합니다.
프로젝트 매니페스트에서 스크립트 프로젝트의 현재 범위를 볼 수도 있습니다.
oauthScopes
아래
필드에 해당 범위를 명시적으로 설정한 경우에만 볼 수 있습니다.
명시적 범위 설정
Apps Script는 코드에서 필요한 함수 호출을 검사하여 스크립트에 필요한 범위를 자동으로 결정합니다. 대부분의 스크립트의 경우 다음과 같습니다. 시간을 절약해 주지만 게시된 부가기능의 경우 범위를 더 직접적으로 제어할 수 있습니다
예를 들어 Apps Script는 부가기능 스크립트 프로젝트에
기본적으로 https://mail.google.com
범위를 지정합니다. 사용자가 이 범위로 스크립트 프로젝트를 승인하면 프로젝트에 사용자의 Gmail 계정에 대한 전체 액세스 권한이 부여됩니다. 게시된 부가기능의 경우 이 범위를 부가기능의 요구사항만 충족하는 더 제한적인 세트로 대체해야 합니다.
다음을 수정하여 스크립트 프로젝트가 사용하는 범위를 명시적으로 설정할 수 있습니다.
매니페스트 파일에 있습니다. 매니페스트 필드 oauthScopes
는 부가기능에서 사용하는 모든 범위의 배열입니다. 프로젝트의 범위를 설정하려면 다음 안내를 따르세요.
있습니다.
- 부가기능에서 현재 사용하는 범위를 확인합니다. 더 좁은 범위 사용과 같이 어떤 변경사항을 적용해야 하는지 결정합니다.
- 부가기능의 매니페스트 파일을 엽니다.
oauthScopes
이라는 최상위 필드를 찾습니다. 이 태그가 없는 경우 추가할 수 있습니다.oauthScopes
필드는 문자열의 배열을 지정합니다. 프로젝트에 사용되는 범위를 설정하려면 이 배열의 콘텐츠를 사용하려는 범위로 바꿉니다. 예를 들어 Gmail을 확장하는 Google Workspace 부가기능의 경우 다음이 있을 수 있습니다.{ ... "oauthScopes": [ "https://www.googleapis.com/auth/gmail.addons.current.message.metadata", "https://www.googleapis.com/auth/userinfo.email" ], ... }
매니페스트 파일 변경사항을 저장합니다.
OAuth 확인
특정 민감한 OAuth 범위를 사용하려면 부가기능이 OAuth 클라이언트 확인 해야 합니다. 자세한 내용은 다음 가이드를 참조하세요.
제한된 범위
특정 범위는 제한되며 도움이 되는 추가 규칙이 적용됩니다. 사용자 데이터 보호 다음을 사용하는 Gmail 또는 편집기 부가기능을 게시하려는 경우 하나 이상의 제한된 범위를 사용하는 경우 부가기능은 지정된 모든 게시되기 전에 제한사항을 확인해야 합니다
제한된 범위의 전체 목록 검토 300x250의 값으로 이루어져야 합니다. 부가기능에 이러한 콘텐츠가 사용되는 경우 다음 정책을 준수해야 합니다. 다음 코드로 교체합니다. 특정 API 범위의 추가 요구사항 게시할 수 있습니다.
Calendar 범위
다음은 Google Calendar를 확장하는 Google Workspace 부가기능에 자주 사용되는 범위입니다.
범위 | |
---|---|
이벤트 메타데이터 액세스 |
https://www.googleapis.com/auth/calendar.addons.execute
부가기능이 Calendar 일정 메타데이터에 액세스하는 경우 필요합니다. 부가기능이 이벤트 메타데이터에 액세스하도록 허용합니다. |
사용자 생성 이벤트 데이터 읽기 |
https://www.googleapis.com/auth/calendar.addons.current.event.read
부가기능에서 사용자 생성 이벤트 데이터를 읽어야 하는 경우 필요합니다.
부가기능에서 사용자 생성 이벤트 데이터에 액세스하도록 허용합니다. 이 데이터는 |
사용자 생성 이벤트 데이터 작성 |
https://www.googleapis.com/auth/calendar.addons.current.event.write
부가기능에서 사용자 생성 이벤트 데이터를 작성해야 하는 경우 필요합니다.
부가기능에서 사용자 생성 이벤트 데이터를 수정하도록 허용합니다. 이 데이터는 |
Drive 범위
다음은 Google Drive를 확장하는 Google Workspace 부가기능에 자주 사용되는 범위입니다.
범위 | |
---|---|
선택한 항목 메타데이터를 읽습니다. |
https://www.googleapis.com/auth/drive.addons.metadata.readonly
부가기능이 트리거된 컨텍스트 인터페이스를 구현하는 경우 필요합니다. 사용자가 Drive에서 항목을 선택할 때. 부가기능이 사용자가 Google Drive에서 선택한 항목에 관한 제한된 메타데이터를 읽을 수 있습니다. 메타데이터는 항목 ID, 제목, MIME 유형, 아이콘 URL, 부가기능에 액세스할 수 있습니다. |
파일별 액세스 |
https://www.googleapis.com/auth/drive.file
개별 Drive 파일에 액세스해야 하는 부가기능의 경우 권장됩니다.
다음을 사용하여 앱에서 만들거나 여는 파일에 대한 파일별 액세스 권한을 부여합니다.
Apps Script 고급 드라이브
서비스를 제공합니다. 하지만 기본 Drive 서비스를 사용하여 유사한 작업을 사용할 수는 없습니다. 파일 승인은 파일별로 부여되며
사용자가 앱을 승인 취소하면 취소됩니다. |
Gmail 부가기능 범위
Cloud Functions를 사용하기 위해 특별히 생성된 몇 가지 범위가 있습니다. 사용자 Gmail을 보호하는 데 도움이 되는 Google Workspace 부가기능 데이터입니다. 다음을 수행해야 합니다. 이 범위를 명시적으로 추가 부가기능 매니페스트에 있는 다른 사용자 이름 및 Vertex AI Feature Store에서 제공되는
다음은 Gmail을 확장하는 Google Workspace 부가기능에 자주 사용되는 범위입니다. 필수라고 표시된 라벨과 함께 부가기능이 확장되는 경우 Google Workspace 부가기능 매니페스트 Gmail.
또한 부가기능의 매우 광범위한 https://mail.google.com
범위를 부가기능에 필요한 상호작용만 허용하는 더 좁은 범위로 대체해야 합니다.
범위 | |
---|---|
새 초안 만들기 |
https://www.googleapis.com/auth/gmail.addons.current.action.compose
부가기능이 <ph type="x-smartling-placeholder"></ph> 작성 작업 트리거 부가기능을 사용하여 새 임시보관 메일을 임시로 만들고 답글 를 참조하세요. 임시보관 메일 작성하기 참조하세요. 이 범위는 종종 <ph type="x-smartling-placeholder"></ph> 작성 작업을 참고하세요. 액세스 토큰이 필요합니다. |
열려 있는 메일 메타데이터 읽기 |
https://www.googleapis.com/auth/gmail.addons.current.message.metadata
열려 있는 메일의 메타데이터(예: 제목 또는 수신자)에 대한 임시 액세스 권한을 부여합니다. 메시지 콘텐츠 읽기를 허용하지 않으며 액세스 토큰이 필요합니다. 부가기능이 Compose 작업 트리거에서 메타데이터를 사용하는 경우 필요합니다. 구성 작업의 경우 구성 트리거에 메타데이터에 대한 액세스가 필요한 경우 이 범위가 필요합니다. 실제로 이 범위를 사용하면 작성 트리거가 답장 이메일 초안의 수신자 목록(to:, cc:, bcc:)에 액세스할 수 있습니다. |
열려 있는 메시지 콘텐츠 읽기 |
https://www.googleapis.com/auth/gmail.addons.current.message.action
사용자 상호작용 시 열린 메일의 콘텐츠에 대한 액세스 권한을 부여합니다. 예를 들어 부가기능 메뉴 항목을 선택한 경우처럼 말이죠 액세스 권한 필요 토큰입니다. |
열린 대화목록 콘텐츠 읽기 |
https://www.googleapis.com/auth/gmail.addons.current.message.readonly
열린 메시지의 메타데이터 및 콘텐츠에 대한 임시 액세스 권한을 부여합니다. 또한 열려 있는 대화목록의 다른 메시지 콘텐츠에 대한 액세스 권한도 부여합니다. 액세스 토큰이 필요합니다. |
메시지 콘텐츠 및 메타데이터 읽기 |
https://www.googleapis.com/auth/gmail.readonly
열린 메시지를 포함한 모든 이메일 메타데이터 및 콘텐츠를 읽습니다. 검색 쿼리를 실행하거나 전체 메일 대화목록을 읽을 때와 같이 다른 메일에 관한 정보를 읽어야 하는 경우 필요합니다. |
액세스 토큰
사용자 데이터를 보호하기 위해
Google Workspace 부가기능은
사용자 데이터에 대한 임시 액세스 권한이 있습니다. 임시 액세스를 사용 설정하려면
함수 GmailApp.setCurrentMessageAccessToken(accessToken)
액세스 토큰을 인수로 사용합니다. 작업 이벤트 객체에서 액세스 토큰을 가져와야 합니다.
다음은
메시지의 메타데이터입니다. 이 예에 필요한 유일한 범위는 https://www.googleapis.com/auth/gmail.addons.current.message.metadata
입니다.
function readSender(e) {
var accessToken = e.gmail.accessToken;
var messageId = e.gmail.messageId;
// The following function enables short-lived access to the current
// message in Gmail. Access to other Gmail messages or data isn't
// permitted.
GmailApp.setCurrentMessageAccessToken(accessToken);
var mailMessage = GmailApp.getMessageById(messageId);
return mailMessage.getFrom();
}
편집자 범위
다음은 Docs, Sheets, Google Slides
범위 | |
---|---|
현재 Docs 파일 액세스 권한 |
https://www.googleapis.com/auth/documents.currentonly
부가기능이 Apps Script Docs API에 액세스하는 경우 필수 항목입니다. 열려 있는 문서의 콘텐츠에 대한 임시 액세스 권한을 부여합니다. |
현재 Sheets 파일 액세스 |
https://www.googleapis.com/auth/spreadsheets.currentonly
부가기능이 Apps Script Sheets API에 액세스하는 경우 필수 항목입니다. 열려 있는 스프레드시트의 콘텐츠에 대한 임시 액세스 권한을 부여합니다. |
현재 Slides 파일 액세스 |
https://www.googleapis.com/auth/presentations.currentonly
부가기능이 Apps Script Slides API에 액세스하는 경우에 필요합니다. 공개 프레젠테이션의 콘텐츠에 대한 임시 액세스 권한을 부여합니다. |
파일별 액세스 |
https://www.googleapis.com/auth/drive.file
부가기능에서 |
기타 범위
부가기능에서 다른 Apps Script 서비스를 사용하는 경우 추가 범위가 필요할 수 있습니다. 대부분의 경우 Apps Script가 이러한 범위를 감지하고 매니페스트를 자동으로 업데이트하도록 할 수 있습니다. 매니페스트의 범위 목록을 수정할 때는 더 적절한 대안(예: 더 좁은 범위)으로 대체하는 것이 아니라면 범위를 삭제하지 마세요.
다음은 Google Workspace 부가기능과 함께 자주 사용되는 Apps Script 범위 목록입니다.
범위 | |
---|---|
사용자의 이메일 주소 읽기 |
https://www.googleapis.com/auth/userinfo.email
프로젝트가 현재 사용자의 이메일 주소를 읽을 수 있도록 허용합니다. |
외부 서비스에 대한 통화 허용 |
https://www.googleapis.com/auth/script.external_request
프로젝트가 |
사용자의 언어 및 시간대 읽기 |
https://www.googleapis.com/auth/script.locale
프로젝트가 현재 사용자의 언어와 시간대를 학습할 수 있도록 허용합니다. 자세한 내용은 사용자 언어 및 시간대에 액세스를 참고하세요. |
트리거 만들기 |
https://www.googleapis.com/auth/script.scriptapp
프로젝트에서 다음 항목을 만들 수 있도록 허용합니다. <ph type="x-smartling-placeholder"></ph> 트리거를 사용합니다. |
서드 파티 링크 미리보기 |
https://www.googleapis.com/auth/workspace.linkpreview
부가기능이 서드 파티 서비스의 링크를 미리 보는 경우 필수 항목입니다. 사용자가 Google Workspace 애플리케이션과 상호작용하는 동안 프로젝트가 Google Workspace 애플리케이션 내의 링크를 볼 수 있도록 허용합니다. 자세한 내용은 페이지를 참조하세요. 스마트 칩으로 링크 미리보기 |
서드 파티 리소스 만들기 |
https://www.googleapis.com/auth/workspace.linkcreate
부가기능이 서드 파티 서비스에서 리소스를 생성하는 경우 필수 항목입니다. 프로젝트가 사용자가 리소스 생성 양식에 제출한 정보를 읽고 Google Workspace 애플리케이션 내에 리소스 링크를 삽입할 수 있도록 허용합니다. 자세한 내용은 @ 메뉴에서 서드 파티 리소스 만들기를 참고하세요. |