사용자는 데이터에 액세스하거나 사용자를 대신하여 작동하는 스크립트 프로젝트를 승인해야 합니다. 사용자가 승인이 필요한 스크립트를 처음 실행하면 UI에 승인 흐름을 시작하라는 메시지가 표시됩니다.
이 흐름에서 UI는 스크립트에서 수행할 권한을 사용자에게 알려줍니다. 예를 들어 스크립트에 사용자의 이메일 메시지를 읽거나 캘린더에 일정을 만들 수 있는 권한이 필요할 수 있습니다. 스크립트 프로젝트에서는 이러한 개별 권한을 OAuth 범위로 정의합니다.
대부분의 스크립트에서 Apps Script는 필요한 범위를 자동으로 감지합니다. 사용자는 언제든지 스크립트에서 사용하는 범위를 확인할 수 있습니다. 매니페스트에서 URL 문자열을 사용하여 범위를 명시적으로 설정할 수도 있습니다. 부가기능과 같은 특정 애플리케이션에는 범위를 명시적으로 설정해야 하는 경우가 있습니다. 게시된 애플리케이션은 항상 가능한 가장 좁은 범위를 사용해야 하기 때문입니다.
승인 과정 중에 Apps Script는 필요한 범위에 관해 사람이 읽을 수 있는 설명을 사용자에게 제공합니다. 예를 들어 스크립트에 스프레드시트에 대한 읽기 전용 액세스 권한이 필요한 경우 매니페스트의 범위는 https://www.googleapis.com/auth/spreadsheets.readonly
일 수 있습니다. 승인 흐름 중에 이 범위의 스크립트가 사용자에게 이 애플리케이션이 'Google 스프레드시트 보기'를 허용하도록 요청합니다.
일부 범위는 다른 범위를 포함합니다. 예를 들어 승인된 경우 https://www.googleapis.com/auth/spreadsheets
범위는 스프레드시트 읽기 및 쓰기 액세스를 허용합니다.
보기 범위
다음을 실행하여 스크립트 프로젝트에 현재 필요한 범위를 확인할 수 있습니다.
- 스크립트 프로젝트를 엽니다.
- 왼쪽에서 Overview(개요) 를 클릭합니다.
- 프로젝트 OAuth 범위에서 범위를 확인합니다.
명시적 범위 설정
Apps Script는 코드에서 필요한 함수 호출을 검색하여 스크립트에 필요한 범위를 자동으로 결정합니다. 대부분의 스크립트에서는 이것으로 충분하며 시간을 절약할 수 있지만 게시된 부가기능과 웹 앱의 경우 범위를 보다 직접적으로 제어해야 합니다.
Apps Script에서 프로젝트에 매우 허용되는 범위를 자동으로 할당하는 경우가 있습니다. 이는 스크립트가 사용자에게 필요한 것보다 더 많은 것을 요구한다는 의미일 수 있는데, 이는 바람직하지 않은 행위입니다. 게시된 스크립트의 경우 광범위한 범위를 스크립트의 요구사항을 충족하는 보다 제한된 집합으로 대체해야 합니다.
매니페스트 파일을 수정하여 스크립트 프로젝트에서 사용하는 범위를 명시적으로 설정할 수 있습니다. 매니페스트 필드 oauthScopes
는 프로젝트에서 사용하는 모든 범위의 배열입니다. 프로젝트 범위를 설정하려면 다음 안내를 따르세요.
- 스크립트 프로젝트를 엽니다.
- 왼쪽에서 프로젝트 설정 을 클릭합니다.
- 편집기에 'appsscript.json' 매니페스트 파일 표시 체크박스를 선택합니다.
- 왼쪽에서 편집기 를 클릭합니다.
- 왼쪽에서
appsscript.json
파일을 클릭합니다. oauthScopes
로 라벨이 지정된 최상위 필드를 찾습니다. 없으면 추가할 수 있습니다.oauthScopes
필드는 문자열 배열을 지정합니다. 프로젝트에서 사용하는 범위를 설정하려면 이 배열의 콘텐츠를 사용하려는 범위로 바꿉니다. 예를 들면{ ... "oauthScopes": [ "https://www.googleapis.com/auth/spreadsheets.readonly", "https://www.googleapis.com/auth/userinfo.email" ], ... }
입니다.- 상단에서 저장 을 클릭합니다.
OAuth 확인
일부 OAuth 범위는 Google 사용자 데이터에 대한 액세스를 허용하므로 민감합니다. 스크립트 프로젝트에서 사용자 데이터에 대한 액세스를 허용하는 범위를 사용하는 경우 프로젝트를 웹 앱 또는 부가기능으로 공개적으로 게시하려면 먼저 OAuth 클라이언트 확인을 거쳐야 합니다. 자세한 내용은 다음 가이드를 참조하세요.
제한된 범위
민감한 범위 외에도 특정 범위에는 제한됨으로 분류되며 사용자 데이터를 보호하는 데 도움이 되는 추가 규칙이 적용됩니다. 하나 이상의 제한된 범위를 사용하는 웹 앱 또는 부가기능을 게시하려는 경우 앱이 게시되기 전에 지정된 모든 제한사항을 준수해야 합니다.
게시하기 전에 제한된 범위의 전체 목록을 검토하세요. 앱에서 이를 사용하는 경우 게시하기 전에 특정 API 범위에 관한 추가 요구사항을 준수해야 합니다.