Как получить (не создавать) задачи из Asana с помощью скрипта приложений и токена личного доступа

Я пытаюсь получить, но не создавать задачи из Asana, используя Google Apps Script.

Используя Asana API Explore, я создал URL, который возвращает нужные мне данные: https://app.asana.com/api/1.0/tasks?opt_fields=name,assignee_status&assignee=987654321987654&completed_since=2018-02-22&limit=100&workspace=456789123456

Этот URL-адрес возвращает нужные данные в следующем формате:

{
  "data": [
    {
      "id": 147258369147258,
      "assignee_status": "inbox",
      "name": "An example task name"
    },
    {
      "id": 963852741963852,
      "assignee_status": "upcoming",
      "name": "And second example task name."
    },
    //etc...
  ]
}

Используя этот URL в качестве модели, я создал токен личного доступа и выполнил следующую функцию в скрипте приложений:

function getTasks5() {
  // Asana Personal Token
  var bearerToken = "Bearer " + "asdf123456789asdf456789456asdf";

  //Request
  var request = {
    data: {
      opt_fields: ["name", "assignee_status"],
      assignee: "987654321987654",
      completed_since: "2018-02-22",
      limit: "100",
      workspace: "456789123456"
    }
  };

  // Request options
  var options = {
    method: "GET",
    headers: {
      "Authorization": bearerToken
    },
    contentType: "application/json",
    payload: JSON.stringify(request)
  };

  var url = "https://app.asana.com/api/1.0/tasks";
  var result = UrlFetchApp.fetch(url, options);
  var reqReturn = result.getContentText();

  Logger.log(reqReturn);
}

Вместо того, чтобы возвращать нужные данные, как это делает вышеупомянутый URL, функция создает неназванную задачу в Asana, что нежелательно. Он также возвращает этот ответ, содержащий нежелательные данные:

{
  "data": {
    "id": 123456789123456,
    "created_at": "2018-02-22T20:59:49.642Z",
    "modified_at": "2018-02-22T20:59:49.642Z",
    "name": "",
    "notes": "",
    "assignee": {
      "id": 987654321987654,
      "name": "My Name Here"
    },
    "completed": false,
    "assignee_status": "inbox",
    "completed_at": null,
    "due_on": null,
    "due_at": null,
    "projects": [],
    "memberships": [],
    "tags": [],
    "workspace": {
      "id": 456789123456,
      "name": "Group Name Here"
    },
    "num_hearts": 0,
    "num_likes": 0,
    "parent": null,
    "hearted": false,
    "hearts": [],
    "followers": [
      {
        "id": 987654321987654,
        "name": "My Name Here"
      }
    ],
    "liked": false,
    "likes": []
  }
}

Можно ли просто ПОЛУЧИТЬ список задач, как показано в моем первом примере JSON выше, не создавая задачу и не прибегая к использованию OAuth? Если да, какие изменения необходимо внести в функцию "Сценарий приложений"?

1 ответ

Решение

Хорошо, проблема была в подходе, который я использовал. Вместо того, чтобы отформатировать запрос с payload (что выводит запрос POST), мне нужно было структурировать его более традиционно как запрос GET, например так:

var requestUrl = "https://app.asana.com/api/1.0/tasks?opt_fields=name,assignee_status&assignee=123456789123&completed_since=2018-02-22&limit=100&workspace=987654321987";

var headers = {
  "Authorization" : "Bearer " + AUTH_TOKEN
};

var reqParams = {
  method : "GET",
  headers : headers,
  muteHttpExceptions: true
};

Тогда я смог выполнить:

UrlFetchApp.fetch(requestUrl, reqParams);

И получить данные, которые я был после.

Другие вопросы по тегам