3

我正在尝试使用谷歌应用程序脚本和松弛来自动化我的工作。我希望在 Slack 对话框中输入一些文本,以使用谷歌应用脚​​本修改我的谷歌电子表格。但是,使用下面的代码,我无法通过Slack-API's Slash command. 我的代码有问题吗?

function doPost(e){
var params = e.parameter;
var token = params.token;
var text = params.text;
var trigger_id = params.trigger_id;
var slackUrl = ["https://slack.com/api/dialog.open"];
if (token == "[token from slack]"){
    var dialog = {
  "token": "[OAuth Token]",
  "trigger_id":trigger_id,
  "dialog":{
  "callback_id": "ryde-46e2b0",
    "title": "Request a Ride",
      "submit_label": "Request",
        "elements": [
          {
            "type": "text",
            "label": "Pickup Location",
            "name": "loc_origin"
          },
          {
            "type": "text",
            "label": "Dropoff Location",
            "name": "loc_destination"
          }
        ]
}
};
var options = {
  'method' : 'POST',
  'contentType': 'application/json',
  'payload' : dialog}; 
UrlFetchApp.fetch(slackUrl, options);
}  
else{
 var res = {"text":"failed token verification!"} 
return          ContentService.createTextOutput(JSON.stringify(res)).setMimeType(ContentService.MimeType.JSON);
 }}
4

1 回答 1

2

这个改装怎么样?

修改点:

  • 对“UrlFetchApp.fetch(url, params)”的“url”使用字符串。
  • 用于对象JSON.stringify()的。dialogdialog
  • 'contentType': 'application/json',不需要。

修改后的脚本:

function doPost(e) {
  var params = e.parameter;
  var token = params.token;
  var text = params.text;
  var trigger_id = params.trigger_id;
  var slackUrl = "https://slack.com/api/dialog.open";
  if (token == "[token from slack]"){ // Please input this.
    var dialog = {
      "token": "[OAuth Token]", // Please input this.
      "trigger_id": trigger_id,
      "dialog": JSON.stringify({
        "callback_id": "ryde-46e2b0",
        "title": "Request a Ride",
        "submit_label": "Request",
        "elements": [
          {
            "type": "text",
            "label": "Pickup Location",
            "name": "loc_origin"
          },
          {
            "type": "text",
            "label": "Dropoff Location",
            "name": "loc_destination"
          }
        ]
      })
    }
    var options = {
      'method' : 'post',
      'payload' : dialog,
    }; 
    UrlFetchApp.fetch(slackUrl, options);
  }  
  else{
    var res = {"text":"failed token verification!"} 
    return ContentService.createTextOutput(JSON.stringify(res)).setMimeType(ContentService.MimeType.JSON);
  }
  return ContentService.createTextOutput(); // Important
}

笔记 :

当对话框提交中没有异常时,您的应用程序必须以空正文响应 200 OK。这将完成对话框。

  • 当它使用对话框时,它返回上面使用 for 的空正文ContentService.createTextOutput(),因为 Google Apps 脚本无法自定义状态代码。当没有返回空体时,就会发生错误。
  • 此修改后的脚本假定您已完成使用 Slack 对话框的设置。
  • 如果您修改了脚本,请将 Web 应用程序重新部署为新版本。这样,最新版本的脚本就会反映到 Web Apps。

参考 :

在我的环境中,我确认这个修改后的脚本有效。但如果这不起作用,我很抱歉。

于 2018-06-29T01:26:29.900 回答