Google日历授权应用脚本-独立的网络应用

时间:2019-05-21 22:09:09

标签: google-apps-script web-applications google-calendar-api

我是Apps脚本和Web开发的新手。我认为最好制作一个简单的应用程序来开始使用。

目标:显示用户的未来事件。

问题:我一直在争取用户授权。目前,脚本正在显示我的事件。相反,我希望脚本显示用户(正在访问Web应用程序的)事件。

我从文档中找到了此样本。此函数获取用户的事件列表。 https://developers.google.com/calendar/quickstart/apps-script

然后,我编写了一个基本的index.html文件,以向用户显示此函数填充的字符串。

index.html

<!DOCTYPE html>
<html>

<head>
    <base target="_top">
</head>

<body>
    <script>
        function getEventsOnClick() {
            google.script.run.withSuccessHandler(changeDisplay).listAllEvents();
        }

        function changeDisplay(display) {
            var div = document.getElementById('output');
            div.innerHTML = display;
        }
    </script>

    <div id="output"> Hello! </div>
    <button onclick="getEventsOnClick()">Run Function</button>

</body>

</html>

code.gs

function doGet() {
  return HtmlService.createHtmlOutputFromFile('Index');
}


function listAllEvents() {
  var calendarId = 'primary';
  var now = new Date();
  var display = ""
  var events = Calendar.Events.list(calendarId, {
    timeMin: now.toISOString(),
    maxResults: 2500,
  });
  if (events.items && events.items.length > 0) {
    for (var i = 0; i < events.items.length; i++) {
      var event = events.items[i];

      if (event.start.date) {
        // All-day event.
        var start = new Date(event.start.date);
        var end = new Date(event.end.date);
        display = display + 'Start: ' + start.toLocaleDateString() + '; End: ' + end.toLocaleDateString() + ". ";
      } else {
        var start = new Date(event.start.dateTime);
        var end = new Date(event.end.dateTime);
        display = display + 'Start: ' + start.toLocaleString() + '; End: ' + end.toLocaleString() + ". ";
      }
    }
  } else {
    display = 'No events found.';
  }
  Logger.log("%s", display)
  return display

}

同样,以上代码没有什么错。它确实按预期显示事件。问题在于它是在显示我的事件而不是用户。因此,如果我为该应用程序提供了用户URL,则希望该应用程序请求授权并显示其事件。我该怎么办?

谢谢!

1 个答案:

答案 0 :(得分:0)

在部署应用程序时,请确保选择以用户而不是您自己的身份执行。 (因为您是默认用户)。