forked from dilame/instagram-private-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
upload-story.example.ts
129 lines (119 loc) · 3.46 KB
/
upload-story.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
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
import { IgApiClient } from '../src';
import { readFile } from 'fs';
import { DateTime, Duration } from 'luxon';
import { StickerBuilder } from '../src/sticker-builder';
import { promisify } from 'util';
const readFileAsync = promisify(readFile);
const ig = new IgApiClient();
async function login() {
ig.state.generateDevice(process.env.IG_USERNAME);
ig.state.proxyUrl = process.env.IG_PROXY;
await ig.account.login(process.env.IG_USERNAME, process.env.IG_PASSWORD);
}
(async () => {
await login();
const path = './myStory.jpg';
const file = await readFileAsync(path);
/**
* You can move and rotate stickers by using one of these methods:
* center()
* rotateDeg(180) rotates 180°
* scale(0.5) scales the sticker to 1/2 of it's size
* moveForward() moves the sticker in front
* moveBackwards() moves the sticker in the background
* right() aligns the sticker to the right
* left() aligns the sticker to the left
* top() aligns the sticker to the top
* bottom() aligns the sticker to the bottom
*
* All of these are chainable e.g.:
* StickerBuilder.hashtag({ tagName: 'tag' }).scale(0.5).rotateDeg(90).center().left()
* You can also set the position and size like this:
* StickerBuilder.hashtag({
* tagName: 'insta',
* width: 0.5,
* height: 0.5,
* x: 0.5,
* y: 0.5,
* })
*/
// these stickers are 'invisible' and not 're-rendered' in the app
await ig.publish.story({
file,
// this creates a new config
stickerConfig: new StickerBuilder()
// these are all supported stickers
.add(
StickerBuilder.hashtag({
tagName: 'insta',
}).center(),
)
.add(
StickerBuilder.mention({
userId: ig.state.cookieUserId,
}).center(),
)
.add(
StickerBuilder.question({
question: 'My Question',
}).scale(0.5),
)
.add(
StickerBuilder.question({
question: 'Music?',
questionType: 'music',
}),
)
.add(
StickerBuilder.countdown({
text: 'My Countdown',
// @ts-ignore
endTs: DateTime.local().plus(Duration.fromObject({ hours: 1 })), // countdown finishes in 1h
}),
)
.add(
StickerBuilder.chat({
text: 'Chat name',
}),
)
.add(
StickerBuilder.location({
locationId: (await ig.locationSearch.index(13, 37)).venues[0].external_id,
}),
)
.add(
StickerBuilder.poll({
question: 'Question',
tallies: [{ text: 'Left' }, { text: 'Right' }],
}),
)
.add(
StickerBuilder.quiz({
question: 'Question',
options: ['0', '1', '2', '3'],
correctAnswer: 1,
}),
)
.add(
StickerBuilder.slider({
question: 'Question',
emoji: '❤',
}),
)
// mention the first story item
.add(StickerBuilder.mentionReel((await ig.feed.userStory('username').items())[0]).center())
// mention the first media on your timeline
.add(StickerBuilder.attachmentFromMedia((await ig.feed.timeline().items())[0]).center())
// you can also set different values for the position and dimensions
.add(
StickerBuilder.hashtag({
tagName: 'insta',
width: 0.5,
height: 0.5,
x: 0.5,
y: 0.5,
}),
)
.build(),
});
})();