-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathaccount-followers.feed.example.ts
30 lines (29 loc) · 1.42 KB
/
account-followers.feed.example.ts
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
/* tslint:disable:no-console */
import 'dotenv/config';
import { IgApiClient } from '../src';
(async () => {
const ig = new IgApiClient();
ig.state.generateDevice(process.env.IG_USERNAME);
ig.state.proxyUrl = process.env.IG_PROXY;
const auth = await ig.account.login(process.env.IG_USERNAME, process.env.IG_PASSWORD);
const followersFeed = ig.feed.accountFollowers(auth.pk);
const wholeResponse = await followersFeed.request();
console.log(wholeResponse); // You can reach any properties in instagram response
const items = await followersFeed.items();
console.log(items); // Here you can reach items. It's array.
const thirdPageItems = await followersFeed.items();
// Feed is stateful and auto-paginated. Every subsequent request returns results from next page
console.log(thirdPageItems); // Here you can reach items. It's array.
const feedState = followersFeed.serialize(); // You can serialize feed state to have an ability to continue get next pages.
console.log(feedState);
followersFeed.deserialize(feedState);
const fourthPageItems = await followersFeed.items();
console.log(fourthPageItems);
// You can use RxJS stream to subscribe to all results in this feed.
// All the RxJS powerful is beyond this example - you should learn it by yourself.
followersFeed.items$.subscribe(
followers => console.log(followers),
error => console.error(error),
() => console.log('Complete!'),
);
})();