-
Notifications
You must be signed in to change notification settings - Fork 493
/
Copy pathscript.js
66 lines (48 loc) · 1.45 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
// all requires
const fetch = require("node-fetch");
const ObjectsToCsv = require("objects-to-csv");
let page = 0;
let postCount = process.argv[2];
// Working Function
fetchPosts = async (postCount) => {
let postsData = []; // stores posts
let count = 0;
let currentPostCount = 0;
while (currentPostCount < postCount) {
const query = `{
storiesFeed(type:BEST
page:${page}){
title
brief
author{
name
}
}
}`;
const response = await fetch("https://api.hashnode.com", {
method: "POST",
headers: {
"Content-type": "application/json",
},
body: JSON.stringify({
query
}),
});
const apiResponse = await response.json();
let posts = apiResponse.data.storiesFeed;
currentPostCount += posts.length;
page++;
for (let post of posts) {
count++;
let postObject = {};
postObject["title"] = post["title"];
postObject["brief"] = post["brief"].split("\n").join(" ");
postObject["author"] = post.author["name"];
postsData.push(postObject);
if (count >= postCount) break;
}
}
const csv = new ObjectsToCsv(postsData);
await csv.toDisk("./output.csv");
};
fetchPosts(postCount);