如何从 Trello 看板获取超过 1000 个动作?

How to get more than 1000 actions from a Trello board?

我想运行一个简单的脚本,它从JSON中获取所有卡片等来自Trello的数据和URL看起来像这样:https://trello.com/b/Vqrkz3KO.json .我想自动化导出板的过程。

但是 Trello 不允许我这样做,所以我必须从 API 开始,像这样:

`/1/boards/${board.id}`, {fields: "all",actions: "all",action_fields: "all",activities_limit: 1000,cards: "all",card_fields: "all",card_attachments: true,labels: "all",lists: "all",list_fields: "all",members: "all",member_fields: "all",checklists: "all",checklist_fields: "all", organization: false

它做我想做的事,但我想从中获取卡片的看板有超过 1000 个活动。那么我如何获得所有活动呢?它只获取 1000 activities/cards。另外,我不能只获取上面的 URL,因为出于某种原因你不能使用 api 按照 this question 来获取它。这个问题没有回答我的问题,我想超过 1000 张卡片,但是如果你这样做,你会得到一个错误说你不能。

编辑 2:终于明白了,我为 HTTPS 请求使用了 API 和 ID 生成器,并使用了提供的 &before=范围。 &before= 参数使用日期作为参数,因此我必须从一个请求中获取最后一个操作,从中获取日期,并将其提供给 &before 参数。然后对于每个有 1000 个元素的数组元素,我弹出最后一个元素,因为我最终会重复操作。

现在,我完成了看起来像这样的操作:[[actions],[actions],[actions],[actions]] 等等,所以我使用 Merge/flatten an array of arrays 的答案使其全部 [actions]。然后我使用方括号 object["key"] = value 来设置/用我的 HTTPS 请求中的操作替换操作,结果是一个非常大的文件,生成这个文件花了很长时间,它出来大约 99.5 MB.

这是我的整个 index.js 测试文件:

const https = require('https');
const fs = require('fs');
var boardinfo = "";
https.get({
    hostname: 'trello.com',
    path: `/b/Vqrkz3KO.json`,
    headers: {'User-Agent': `${Math.random().toString(16).substring(2,16)}`}
}, (r) => {
    var data = "";
    r.on('data', (d) => {
        data+=d;
    })
    r.on('close', () => {
        boardinfo = JSON.parse(data);
    });
})

var actions = [];

(function untilDeath(beforeval) {
https.get({
    hostname: 'api.trello.com',
    path: `/1/boards/Vqrkz3KO/actions?limit=1000${beforeval ? `&before=${beforeval}` : ``}`,
    headers: {'User-Agent': `${Math.random().toString(16).substring(2,16)}`}
}, (r) => {
    var cmpdta = "";
    r.on('data', (d) => {
        cmpdta+=d;
    })
    r.on('close', () => {
        cmpdta = JSON.parse(cmpdta);
        if(cmpdta.length < 1000) {
            if(cmpdta.length) actions.push(cmpdta);
            return makeFile(info, [].concat.apply([], actions), fileName);
        } else
        untilDeath(cmpdta[999].date);
        cmpdta.pop();
        actions.push(cmpdta);
    });

    r.on('error', () => {
        throw new Error('-----HTTPS Error Occurred, Please retry :(');
    });
});
})();

function makeFile(trelloBoard, actions) {
    trelloBoard["actions"] = actions;
    fs.createWriteStream('./full-board.json');
    fs.writeFile(`./full-board.json`, JSON.stringify(trelloBoard, null, `\t`), (c) => {
        if(c) console.log(c);
    });
}

编辑:令人失望的是,这也只获取了 1000 个动作,即使手动保存了 JSON 文件,它仍然提供了 1000 个动作。

我使用 HTTPS User-Agent header.

轻松解决了这个问题
const https = require('https');
https.get({
    hostname: 'trello.com',
    path: '/b/Vqrkz3KO.json',
    headers: {'User-Agent': 'some-random-user-agent'}
}, (r) => {
    var str = "";
    r.on('data', (d) => {str+=d});
    r.on('close', () => {console.log(str)})
})