nodejs-insta-private-api-mqt 1.3.85 → 1.3.87
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/dist/constants/constants.d.ts +1 -0
- package/dist/dist/constants/index.d.ts +25 -0
- package/dist/dist/core/client.d.ts +106 -0
- package/dist/dist/core/nav-chain.d.ts +77 -0
- package/dist/dist/core/repository.d.ts +3 -0
- package/dist/dist/core/request.d.ts +76 -0
- package/dist/dist/core/state.d.ts +605 -0
- package/dist/dist/core/utils.d.ts +129 -0
- package/dist/dist/downloadMedia.d.ts +106 -0
- package/{dist-ts → dist}/dist/downloadMedia.js +19 -20
- package/dist/dist/errors/index.d.ts +18 -0
- package/dist/dist/extend.d.ts +20 -0
- package/dist/dist/fbns/fbns.client.d.ts +43 -0
- package/dist/dist/fbns/fbns.client.events.d.ts +0 -0
- package/{dist-ts → dist}/dist/fbns/fbns.client.js +4 -5
- package/dist/dist/fbns/fbns.device-auth.d.ts +9 -0
- package/{src-ts/dist/fbns/fbns.device-auth.ts → dist/dist/fbns/fbns.device-auth.js} +6 -3
- package/dist/dist/fbns/fbns.types.d.ts +0 -0
- package/dist/dist/fbns/fbns.utilities.d.ts +4 -0
- package/dist/dist/fbns/index.d.ts +2 -0
- package/dist/dist/index.d.ts +49 -0
- package/dist/dist/mqtt-shim.d.ts +1 -0
- package/dist/dist/mqttot/index.d.ts +2 -0
- package/dist/dist/mqttot/mqttot.client.d.ts +77 -0
- package/{dist-ts → dist}/dist/mqttot/mqttot.client.js +10 -10
- package/dist/dist/mqttot/mqttot.connect.request.packet.d.ts +1 -0
- package/dist/dist/mqttot/mqttot.connect.response.packet.d.ts +5 -0
- package/dist/dist/mqttot/mqttot.connection.d.ts +6 -0
- package/dist/dist/realtime/commands/commands.d.ts +19 -0
- package/dist/dist/realtime/commands/direct.commands.d.ts +142 -0
- package/dist/dist/realtime/commands/enhanced.direct.commands.d.ts +425 -0
- package/{dist-ts → dist}/dist/realtime/commands/enhanced.direct.commands.js +8 -10
- package/dist/dist/realtime/commands/index.d.ts +2 -0
- package/dist/dist/realtime/delta-sync.manager.d.ts +82 -0
- package/{dist-ts → dist}/dist/realtime/delta-sync.manager.js +7 -10
- package/dist/dist/realtime/features/dm-sender.d.ts +20 -0
- package/{src-ts/dist/realtime/features/dm-sender.ts → dist/dist/realtime/features/dm-sender.js} +6 -3
- package/dist/dist/realtime/features/error-handler.d.ts +33 -0
- package/{dist-ts → dist}/dist/realtime/features/error-handler.js +4 -4
- package/dist/dist/realtime/features/gap-handler.d.ts +19 -0
- package/dist/dist/realtime/features/persistent-logger.d.ts +28 -0
- package/{dist-ts → dist}/dist/realtime/features/persistent-logger.js +3 -3
- package/dist/dist/realtime/features/presence.manager.d.ts +24 -0
- package/{src-ts/dist/realtime/features/presence.manager.ts → dist/dist/realtime/features/presence.manager.js} +2 -1
- package/dist/dist/realtime/features/session-health-monitor.d.ts +93 -0
- package/{src-ts/dist/realtime/features/session-health-monitor.ts → dist/dist/realtime/features/session-health-monitor.js} +45 -65
- package/dist/dist/realtime/index.d.ts +9 -0
- package/dist/dist/realtime/messages/app-presence.event.d.ts +0 -0
- package/dist/dist/realtime/messages/index.d.ts +2 -0
- package/dist/dist/realtime/messages/message-sync.message.d.ts +1 -0
- package/dist/dist/realtime/messages/realtime-sub.direct.data.d.ts +0 -0
- package/dist/dist/realtime/messages/thread-update.message.d.ts +0 -0
- package/dist/dist/realtime/mixins/index.d.ts +2 -0
- package/dist/dist/realtime/mixins/message-sync.mixin.d.ts +38 -0
- package/{dist-ts → dist}/dist/realtime/mixins/message-sync.mixin.js +16 -18
- package/dist/dist/realtime/mixins/mixin.d.ts +4 -0
- package/dist/dist/realtime/mixins/presence-typing.mixin.d.ts +9 -0
- package/dist/dist/realtime/mixins/realtime-sub.mixin.d.ts +37 -0
- package/{dist-ts → dist}/dist/realtime/mixins/realtime-sub.mixin.js +4 -5
- package/dist/dist/realtime/parsers/graphql-parser.d.ts +18 -0
- package/dist/dist/realtime/parsers/graphql.parser.d.ts +10 -0
- package/{src-ts/dist/realtime/parsers/graphql.parser.ts → dist/dist/realtime/parsers/graphql.parser.js} +0 -1
- package/dist/dist/realtime/parsers/index.d.ts +2 -0
- package/dist/dist/realtime/parsers/iris-parser.d.ts +18 -0
- package/dist/dist/realtime/parsers/iris.parser.d.ts +3 -0
- package/dist/dist/realtime/parsers/json-parser.d.ts +18 -0
- package/dist/dist/realtime/parsers/json.parser.d.ts +6 -0
- package/dist/dist/realtime/parsers/parser.d.ts +0 -0
- package/dist/dist/realtime/parsers/region-hint-parser.d.ts +18 -0
- package/dist/dist/realtime/parsers/region-hint.parser.d.ts +4 -0
- package/dist/dist/realtime/parsers/skywalker-parser.d.ts +18 -0
- package/dist/dist/realtime/parsers/skywalker.parser.d.ts +7 -0
- package/dist/dist/realtime/parsers-advanced.d.ts +93 -0
- package/{dist-ts → dist}/dist/realtime/parsers-advanced.js +5 -8
- package/dist/dist/realtime/proto-parser.d.ts +27 -0
- package/{dist-ts → dist}/dist/realtime/proto-parser.js +1 -2
- package/dist/dist/realtime/protocols/iris.handshake.d.ts +41 -0
- package/dist/dist/realtime/protocols/proto-definitions.d.ts +0 -0
- package/dist/dist/realtime/protocols/skywalker.protocol.d.ts +20 -0
- package/{src-ts/dist/realtime/protocols/skywalker.protocol.ts → dist/dist/realtime/protocols/skywalker.protocol.js} +8 -5
- package/dist/dist/realtime/realtime.client.d.ts +169 -0
- package/dist/dist/realtime/realtime.client.events.d.ts +0 -0
- package/{dist-ts → dist}/dist/realtime/realtime.client.js +75 -86
- package/dist/dist/realtime/realtime.service.d.ts +109 -0
- package/dist/dist/realtime/reconnect.manager.d.ts +15 -0
- package/dist/dist/realtime/session.manager.d.ts +25 -0
- package/dist/dist/realtime/subscriptions/graphql.subscription.d.ts +4 -0
- package/dist/dist/realtime/subscriptions/index.d.ts +2 -0
- package/dist/dist/realtime/subscriptions/skywalker.subscription.d.ts +4 -0
- package/dist/dist/realtime/topic-map.d.ts +97 -0
- package/dist/dist/realtime/topic.d.ts +71 -0
- package/dist/dist/repositories/account.repository.d.ts +72 -0
- package/{dist-ts → dist}/dist/repositories/account.repository.js +828 -214
- package/dist/dist/repositories/bloks.repository.d.ts +6 -0
- package/dist/dist/repositories/captcha.repository.d.ts +6 -0
- package/dist/dist/repositories/challenge.repository.d.ts +12 -0
- package/{dist-ts → dist}/dist/repositories/challenge.repository.js +1 -2
- package/dist/dist/repositories/clip.repository.d.ts +10 -0
- package/dist/dist/repositories/close-friends.repository.d.ts +8 -0
- package/dist/dist/repositories/collection.repository.d.ts +8 -0
- package/dist/dist/repositories/direct-thread.repository.d.ts +88 -0
- package/{dist-ts → dist}/dist/repositories/direct-thread.repository.js +7 -9
- package/dist/dist/repositories/direct.repository.d.ts +22 -0
- package/{dist-ts → dist}/dist/repositories/direct.repository.js +4 -5
- package/dist/dist/repositories/explore.repository.d.ts +7 -0
- package/dist/dist/repositories/fbsearch.repository.d.ts +14 -0
- package/dist/dist/repositories/feed.repository.d.ts +19 -0
- package/dist/dist/repositories/friendship.repository.d.ts +26 -0
- package/dist/dist/repositories/fundraiser.repository.d.ts +6 -0
- package/dist/dist/repositories/hashtag.repository.d.ts +11 -0
- package/dist/dist/repositories/highlights.repository.d.ts +11 -0
- package/dist/dist/repositories/insights.repository.d.ts +8 -0
- package/dist/dist/repositories/location.repository.d.ts +9 -0
- package/dist/dist/repositories/media.repository.d.ts +41 -0
- package/{dist-ts → dist}/dist/repositories/media.repository.js +1 -2
- package/dist/dist/repositories/multiple-accounts.repository.d.ts +7 -0
- package/dist/dist/repositories/news.repository.d.ts +6 -0
- package/dist/dist/repositories/note.repository.d.ts +8 -0
- package/dist/dist/repositories/notification.repository.d.ts +33 -0
- package/{dist-ts → dist}/dist/repositories/notification.repository.js +1 -1
- package/dist/dist/repositories/share.repository.d.ts +12 -0
- package/dist/dist/repositories/signup.repository.d.ts +19 -0
- package/dist/dist/repositories/story.repository.d.ts +23 -0
- package/{dist-ts → dist}/dist/repositories/story.repository.js +1 -2
- package/dist/dist/repositories/timeline.repository.d.ts +7 -0
- package/dist/dist/repositories/totp.repository.d.ts +14 -0
- package/dist/dist/repositories/track.repository.d.ts +7 -0
- package/{dist-ts → dist}/dist/repositories/track.repository.js +1 -2
- package/dist/dist/repositories/upload.repository.d.ts +30 -0
- package/{dist-ts → dist}/dist/repositories/upload.repository.js +4 -5
- package/dist/dist/repositories/user.repository.d.ts +52 -0
- package/dist/dist/sendmedia/index.d.ts +12 -0
- package/dist/dist/sendmedia/sendFile.d.ts +8 -0
- package/dist/dist/sendmedia/sendPhoto.d.ts +26 -0
- package/dist/dist/sendmedia/sendRavenPhoto.d.ts +14 -0
- package/{dist-ts → dist}/dist/sendmedia/sendRavenPhoto.js +4 -5
- package/dist/dist/sendmedia/sendRavenVideo.d.ts +15 -0
- package/{dist-ts → dist}/dist/sendmedia/sendRavenVideo.js +4 -5
- package/dist/dist/sendmedia/uploadPhoto.d.ts +8 -0
- package/dist/dist/sendmedia/uploadfFile.d.ts +13 -0
- package/{dist-ts → dist}/dist/sendmedia/uploadfFile.js +3 -4
- package/dist/dist/services/live.service.d.ts +13 -0
- package/dist/dist/services/search.service.d.ts +11 -0
- package/dist/dist/shared/index.d.ts +4 -0
- package/{src-ts/dist/shared/index.ts → dist/dist/shared/index.js} +14 -13
- package/dist/dist/shared/shared.d.ts +15 -0
- package/dist/dist/thrift/index.d.ts +2 -0
- package/dist/dist/thrift/thrift.d.ts +11 -0
- package/dist/dist/thrift/thrift.reading.d.ts +49 -0
- package/{dist-ts → dist}/dist/thrift/thrift.reading.js +3 -5
- package/dist/dist/thrift/thrift.writing.d.ts +49 -0
- package/{dist-ts → dist}/dist/thrift/thrift.writing.js +2 -4
- package/dist/dist/types/index.d.ts +28 -0
- package/dist/dist/useMultiFileAuthState.d.ts +267 -0
- package/{dist-ts → dist}/dist/useMultiFileAuthState.js +47 -61
- package/dist/dist/utils/helper-1.d.ts +0 -0
- package/dist/dist/utils/helper-10.d.ts +0 -0
- package/dist/dist/utils/helper-11.d.ts +0 -0
- package/dist/dist/utils/helper-12.d.ts +0 -0
- package/dist/dist/utils/helper-13.d.ts +0 -0
- package/dist/dist/utils/helper-14.d.ts +0 -0
- package/dist/dist/utils/helper-15.d.ts +0 -0
- package/dist/dist/utils/helper-16.d.ts +0 -0
- package/dist/dist/utils/helper-17.d.ts +0 -0
- package/dist/dist/utils/helper-18.d.ts +0 -0
- package/dist/dist/utils/helper-19.d.ts +0 -0
- package/dist/dist/utils/helper-2.d.ts +0 -0
- package/dist/dist/utils/helper-20.d.ts +0 -0
- package/dist/dist/utils/helper-21.d.ts +0 -0
- package/dist/dist/utils/helper-22.d.ts +0 -0
- package/dist/dist/utils/helper-23.d.ts +0 -0
- package/dist/dist/utils/helper-24.d.ts +0 -0
- package/dist/dist/utils/helper-25.d.ts +0 -0
- package/dist/dist/utils/helper-26.d.ts +0 -0
- package/dist/dist/utils/helper-27.d.ts +0 -0
- package/dist/dist/utils/helper-28.d.ts +0 -0
- package/dist/dist/utils/helper-29.d.ts +0 -0
- package/dist/dist/utils/helper-3.d.ts +0 -0
- package/dist/dist/utils/helper-30.d.ts +0 -0
- package/dist/dist/utils/helper-4.d.ts +0 -0
- package/dist/dist/utils/helper-5.d.ts +0 -0
- package/dist/dist/utils/helper-6.d.ts +0 -0
- package/dist/dist/utils/helper-7.d.ts +0 -0
- package/dist/dist/utils/helper-8.d.ts +0 -0
- package/dist/dist/utils/helper-9.d.ts +0 -0
- package/dist/dist/utils/index.d.ts +56 -0
- package/{dist-ts → dist}/dist/utils/index.js +1 -2
- package/dist/dist/utils/insta-mqtt-helper.d.ts +30 -0
- package/dist/examples/listen-to-messages.d.ts +4 -0
- package/{dist-ts → dist}/examples/listen-to-messages.js +1 -2
- package/package.json +37 -42
- package/dist-ts/dist/fbns/fbns.device-auth.js +0 -59
- package/dist-ts/dist/realtime/features/dm-sender.js +0 -94
- package/dist-ts/dist/realtime/features/presence.manager.js +0 -68
- package/dist-ts/dist/realtime/features/session-health-monitor.js +0 -327
- package/dist-ts/dist/realtime/parsers/graphql.parser.js +0 -22
- package/dist-ts/dist/realtime/protocols/skywalker.protocol.js +0 -96
- package/dist-ts/dist/shared/index.js +0 -98
- package/examples/listen-to-messages.js +0 -86
- package/src-ts/dist/constants/constants.ts +0 -342
- package/src-ts/dist/constants/index.ts +0 -58
- package/src-ts/dist/core/client.ts +0 -419
- package/src-ts/dist/core/nav-chain.ts +0 -282
- package/src-ts/dist/core/repository.ts +0 -7
- package/src-ts/dist/core/request.ts +0 -395
- package/src-ts/dist/core/state.ts +0 -1484
- package/src-ts/dist/core/utils.ts +0 -786
- package/src-ts/dist/downloadMedia.ts +0 -381
- package/src-ts/dist/errors/index.ts +0 -38
- package/src-ts/dist/extend.ts +0 -167
- package/src-ts/dist/fbns/fbns.client.events.ts +0 -3
- package/src-ts/dist/fbns/fbns.client.ts +0 -252
- package/src-ts/dist/fbns/fbns.types.ts +0 -3
- package/src-ts/dist/fbns/fbns.utilities.ts +0 -79
- package/src-ts/dist/fbns/index.ts +0 -21
- package/src-ts/dist/index.ts +0 -139
- package/src-ts/dist/mqtt-shim.ts +0 -15
- package/src-ts/dist/mqttot/index.ts +0 -21
- package/src-ts/dist/mqttot/mqttot.client.ts +0 -318
- package/src-ts/dist/mqttot/mqttot.connect.request.packet.ts +0 -9
- package/src-ts/dist/mqttot/mqttot.connect.response.packet.ts +0 -24
- package/src-ts/dist/mqttot/mqttot.connection.ts +0 -77
- package/src-ts/dist/realtime/commands/commands.ts +0 -71
- package/src-ts/dist/realtime/commands/direct.commands.ts +0 -417
- package/src-ts/dist/realtime/commands/enhanced.direct.commands.ts +0 -1731
- package/src-ts/dist/realtime/commands/index.ts +0 -20
- package/src-ts/dist/realtime/delta-sync.manager.ts +0 -293
- package/src-ts/dist/realtime/features/error-handler.ts +0 -185
- package/src-ts/dist/realtime/features/gap-handler.ts +0 -61
- package/src-ts/dist/realtime/features/persistent-logger.ts +0 -186
- package/src-ts/dist/realtime/index.ts +0 -30
- package/src-ts/dist/realtime/messages/app-presence.event.ts +0 -3
- package/src-ts/dist/realtime/messages/index.ts +0 -20
- package/src-ts/dist/realtime/messages/message-sync.message.ts +0 -43
- package/src-ts/dist/realtime/messages/realtime-sub.direct.data.ts +0 -3
- package/src-ts/dist/realtime/messages/thread-update.message.ts +0 -3
- package/src-ts/dist/realtime/mixins/index.ts +0 -20
- package/src-ts/dist/realtime/mixins/message-sync.mixin.ts +0 -596
- package/src-ts/dist/realtime/mixins/mixin.ts +0 -41
- package/src-ts/dist/realtime/mixins/presence-typing.mixin.ts +0 -33
- package/src-ts/dist/realtime/mixins/realtime-sub.mixin.ts +0 -181
- package/src-ts/dist/realtime/parsers/graphql-parser.ts +0 -43
- package/src-ts/dist/realtime/parsers/index.ts +0 -23
- package/src-ts/dist/realtime/parsers/iris-parser.ts +0 -43
- package/src-ts/dist/realtime/parsers/iris.parser.ts +0 -10
- package/src-ts/dist/realtime/parsers/json-parser.ts +0 -43
- package/src-ts/dist/realtime/parsers/json.parser.ts +0 -10
- package/src-ts/dist/realtime/parsers/parser.ts +0 -3
- package/src-ts/dist/realtime/parsers/region-hint-parser.ts +0 -43
- package/src-ts/dist/realtime/parsers/region-hint.parser.ts +0 -15
- package/src-ts/dist/realtime/parsers/skywalker-parser.ts +0 -43
- package/src-ts/dist/realtime/parsers/skywalker.parser.ts +0 -15
- package/src-ts/dist/realtime/parsers-advanced.ts +0 -158
- package/src-ts/dist/realtime/proto-parser.ts +0 -195
- package/src-ts/dist/realtime/protocols/iris.handshake.ts +0 -74
- package/src-ts/dist/realtime/protocols/proto-definitions.ts +0 -80
- package/src-ts/dist/realtime/realtime.client.events.ts +0 -3
- package/src-ts/dist/realtime/realtime.client.ts +0 -1996
- package/src-ts/dist/realtime/realtime.service.ts +0 -462
- package/src-ts/dist/realtime/reconnect.manager.ts +0 -88
- package/src-ts/dist/realtime/session.manager.ts +0 -121
- package/src-ts/dist/realtime/subscriptions/graphql.subscription.ts +0 -99
- package/src-ts/dist/realtime/subscriptions/index.ts +0 -19
- package/src-ts/dist/realtime/subscriptions/skywalker.subscription.ts +0 -13
- package/src-ts/dist/realtime/topic-map.ts +0 -71
- package/src-ts/dist/realtime/topic.ts +0 -80
- package/src-ts/dist/repositories/account.repository.ts +0 -1384
- package/src-ts/dist/repositories/bloks.repository.ts +0 -70
- package/src-ts/dist/repositories/captcha.repository.ts +0 -44
- package/src-ts/dist/repositories/challenge.repository.ts +0 -120
- package/src-ts/dist/repositories/clip.repository.ts +0 -165
- package/src-ts/dist/repositories/close-friends.repository.ts +0 -46
- package/src-ts/dist/repositories/collection.repository.ts +0 -68
- package/src-ts/dist/repositories/direct-thread.repository.ts +0 -446
- package/src-ts/dist/repositories/direct.repository.ts +0 -266
- package/src-ts/dist/repositories/explore.repository.ts +0 -70
- package/src-ts/dist/repositories/fbsearch.repository.ts +0 -140
- package/src-ts/dist/repositories/feed.repository.ts +0 -245
- package/src-ts/dist/repositories/friendship.repository.ts +0 -296
- package/src-ts/dist/repositories/fundraiser.repository.ts +0 -49
- package/src-ts/dist/repositories/hashtag.repository.ts +0 -99
- package/src-ts/dist/repositories/highlights.repository.ts +0 -121
- package/src-ts/dist/repositories/insights.repository.ts +0 -82
- package/src-ts/dist/repositories/location.repository.ts +0 -84
- package/src-ts/dist/repositories/media.repository.ts +0 -395
- package/src-ts/dist/repositories/multiple-accounts.repository.ts +0 -41
- package/src-ts/dist/repositories/news.repository.ts +0 -35
- package/src-ts/dist/repositories/note.repository.ts +0 -57
- package/src-ts/dist/repositories/notification.repository.ts +0 -79
- package/src-ts/dist/repositories/share.repository.ts +0 -35
- package/src-ts/dist/repositories/signup.repository.ts +0 -218
- package/src-ts/dist/repositories/story.repository.ts +0 -290
- package/src-ts/dist/repositories/timeline.repository.ts +0 -60
- package/src-ts/dist/repositories/totp.repository.ts +0 -139
- package/src-ts/dist/repositories/track.repository.ts +0 -53
- package/src-ts/dist/repositories/upload.repository.ts +0 -204
- package/src-ts/dist/repositories/user.repository.ts +0 -360
- package/src-ts/dist/sendmedia/index.ts +0 -27
- package/src-ts/dist/sendmedia/sendFile.ts +0 -72
- package/src-ts/dist/sendmedia/sendPhoto.ts +0 -142
- package/src-ts/dist/sendmedia/sendRavenPhoto.ts +0 -153
- package/src-ts/dist/sendmedia/sendRavenVideo.ts +0 -158
- package/src-ts/dist/sendmedia/uploadPhoto.ts +0 -107
- package/src-ts/dist/sendmedia/uploadfFile.ts +0 -130
- package/src-ts/dist/services/live.service.ts +0 -139
- package/src-ts/dist/services/search.service.ts +0 -115
- package/src-ts/dist/shared/shared.ts +0 -86
- package/src-ts/dist/thrift/index.ts +0 -20
- package/src-ts/dist/thrift/thrift.reading.ts +0 -368
- package/src-ts/dist/thrift/thrift.ts +0 -111
- package/src-ts/dist/thrift/thrift.writing.ts +0 -396
- package/src-ts/dist/types/index.ts +0 -285
- package/src-ts/dist/useMultiFileAuthState.ts +0 -1800
- package/src-ts/dist/utils/helper-1.ts +0 -1
- package/src-ts/dist/utils/helper-10.ts +0 -1
- package/src-ts/dist/utils/helper-11.ts +0 -1
- package/src-ts/dist/utils/helper-12.ts +0 -1
- package/src-ts/dist/utils/helper-13.ts +0 -1
- package/src-ts/dist/utils/helper-14.ts +0 -1
- package/src-ts/dist/utils/helper-15.ts +0 -1
- package/src-ts/dist/utils/helper-16.ts +0 -1
- package/src-ts/dist/utils/helper-17.ts +0 -1
- package/src-ts/dist/utils/helper-18.ts +0 -1
- package/src-ts/dist/utils/helper-19.ts +0 -1
- package/src-ts/dist/utils/helper-2.ts +0 -1
- package/src-ts/dist/utils/helper-20.ts +0 -1
- package/src-ts/dist/utils/helper-21.ts +0 -1
- package/src-ts/dist/utils/helper-22.ts +0 -1
- package/src-ts/dist/utils/helper-23.ts +0 -1
- package/src-ts/dist/utils/helper-24.ts +0 -1
- package/src-ts/dist/utils/helper-25.ts +0 -1
- package/src-ts/dist/utils/helper-26.ts +0 -1
- package/src-ts/dist/utils/helper-27.ts +0 -1
- package/src-ts/dist/utils/helper-28.ts +0 -1
- package/src-ts/dist/utils/helper-29.ts +0 -1
- package/src-ts/dist/utils/helper-3.ts +0 -1
- package/src-ts/dist/utils/helper-30.ts +0 -1
- package/src-ts/dist/utils/helper-4.ts +0 -1
- package/src-ts/dist/utils/helper-5.ts +0 -1
- package/src-ts/dist/utils/helper-6.ts +0 -1
- package/src-ts/dist/utils/helper-7.ts +0 -1
- package/src-ts/dist/utils/helper-8.ts +0 -1
- package/src-ts/dist/utils/helper-9.ts +0 -1
- package/src-ts/dist/utils/index.ts +0 -280
- package/src-ts/dist/utils/insta-mqtt-helper.ts +0 -128
- package/src-ts/examples/listen-to-messages.ts +0 -86
- /package/{dist-ts → dist}/dist/constants/constants.js +0 -0
- /package/{dist-ts → dist}/dist/constants/index.js +0 -0
- /package/{dist-ts → dist}/dist/core/client.js +0 -0
- /package/{dist-ts → dist}/dist/core/nav-chain.js +0 -0
- /package/{dist-ts → dist}/dist/core/repository.js +0 -0
- /package/{dist-ts → dist}/dist/core/request.js +0 -0
- /package/{dist-ts → dist}/dist/core/state.js +0 -0
- /package/{dist-ts → dist}/dist/core/utils.js +0 -0
- /package/{dist-ts → dist}/dist/errors/index.js +0 -0
- /package/{dist-ts → dist}/dist/extend.js +0 -0
- /package/{dist-ts → dist}/dist/fbns/fbns.client.events.js +0 -0
- /package/{dist-ts → dist}/dist/fbns/fbns.types.js +0 -0
- /package/{dist-ts → dist}/dist/fbns/fbns.utilities.js +0 -0
- /package/{dist-ts → dist}/dist/fbns/index.js +0 -0
- /package/{dist-ts → dist}/dist/index.js +0 -0
- /package/{dist-ts → dist}/dist/mqtt-shim.js +0 -0
- /package/{dist-ts → dist}/dist/mqttot/index.js +0 -0
- /package/{dist-ts → dist}/dist/mqttot/mqttot.connect.request.packet.js +0 -0
- /package/{dist-ts → dist}/dist/mqttot/mqttot.connect.response.packet.js +0 -0
- /package/{dist-ts → dist}/dist/mqttot/mqttot.connection.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/commands/commands.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/commands/direct.commands.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/commands/index.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/features/gap-handler.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/index.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/messages/app-presence.event.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/messages/index.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/messages/message-sync.message.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/messages/realtime-sub.direct.data.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/messages/thread-update.message.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/mixins/index.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/mixins/mixin.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/mixins/presence-typing.mixin.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/graphql-parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/index.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/iris-parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/iris.parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/json-parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/json.parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/region-hint-parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/region-hint.parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/skywalker-parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/parsers/skywalker.parser.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/protocols/iris.handshake.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/protocols/proto-definitions.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/realtime.client.events.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/realtime.service.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/reconnect.manager.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/session.manager.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/subscriptions/graphql.subscription.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/subscriptions/index.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/subscriptions/skywalker.subscription.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/topic-map.js +0 -0
- /package/{dist-ts → dist}/dist/realtime/topic.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/bloks.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/captcha.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/clip.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/close-friends.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/collection.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/explore.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/fbsearch.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/feed.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/friendship.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/fundraiser.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/hashtag.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/highlights.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/insights.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/location.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/multiple-accounts.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/news.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/note.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/share.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/signup.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/timeline.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/totp.repository.js +0 -0
- /package/{dist-ts → dist}/dist/repositories/user.repository.js +0 -0
- /package/{dist-ts → dist}/dist/sendmedia/index.js +0 -0
- /package/{dist-ts → dist}/dist/sendmedia/sendFile.js +0 -0
- /package/{dist-ts → dist}/dist/sendmedia/sendPhoto.js +0 -0
- /package/{dist-ts → dist}/dist/sendmedia/uploadPhoto.js +0 -0
- /package/{dist-ts → dist}/dist/services/live.service.js +0 -0
- /package/{dist-ts → dist}/dist/services/search.service.js +0 -0
- /package/{dist-ts → dist}/dist/shared/shared.js +0 -0
- /package/{dist-ts → dist}/dist/thrift/index.js +0 -0
- /package/{dist-ts → dist}/dist/thrift/thrift.js +0 -0
- /package/{dist-ts → dist}/dist/types/index.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-1.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-10.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-11.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-12.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-13.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-14.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-15.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-16.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-17.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-18.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-19.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-2.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-20.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-21.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-22.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-23.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-24.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-25.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-26.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-27.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-28.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-29.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-3.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-30.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-4.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-5.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-6.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-7.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-8.js +0 -0
- /package/{dist-ts → dist}/dist/utils/helper-9.js +0 -0
- /package/{dist-ts → dist}/dist/utils/insta-mqtt-helper.js +0 -0
|
@@ -1,327 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
const EventEmitter = require('eventemitter3');
|
|
3
|
-
const SESSION_CHECK_INTERVAL = 30 * 60 * 1000;
|
|
4
|
-
const SESSION_CHECK_JITTER = 5 * 60 * 1000;
|
|
5
|
-
const MIN_CHECK_INTERVAL = 5 * 60 * 1000;
|
|
6
|
-
class SessionHealthMonitor extends EventEmitter {
|
|
7
|
-
constructor(realtimeClient, options = {}) {
|
|
8
|
-
super();
|
|
9
|
-
this.rt = realtimeClient;
|
|
10
|
-
this.ig = realtimeClient.ig;
|
|
11
|
-
this.options = {
|
|
12
|
-
checkIntervalMs: options.checkIntervalMs || SESSION_CHECK_INTERVAL,
|
|
13
|
-
jitterMs: options.jitterMs || SESSION_CHECK_JITTER,
|
|
14
|
-
autoRelogin: options.autoRelogin !== false,
|
|
15
|
-
credentials: options.credentials || null,
|
|
16
|
-
onSessionExpired: options.onSessionExpired || null,
|
|
17
|
-
maxConsecutiveFailures: options.maxConsecutiveFailures || 5,
|
|
18
|
-
...options,
|
|
19
|
-
};
|
|
20
|
-
this._checkTimer = null;
|
|
21
|
-
this._running = false;
|
|
22
|
-
this._consecutiveFailures = 0;
|
|
23
|
-
this._lastCheckAt = null;
|
|
24
|
-
this._lastCheckResult = null;
|
|
25
|
-
this._sessionValid = true;
|
|
26
|
-
this._reloginInProgress = false;
|
|
27
|
-
this._reloginCount = 0;
|
|
28
|
-
this._stats = {
|
|
29
|
-
startedAt: null,
|
|
30
|
-
totalChecks: 0,
|
|
31
|
-
successfulChecks: 0,
|
|
32
|
-
failedChecks: 0,
|
|
33
|
-
sessionExpiries: 0,
|
|
34
|
-
relogins: 0,
|
|
35
|
-
successfulRelogins: 0,
|
|
36
|
-
failedRelogins: 0,
|
|
37
|
-
totalUptimeMs: 0,
|
|
38
|
-
longestUptimeMs: 0,
|
|
39
|
-
reconnects: 0,
|
|
40
|
-
lastUptimeStart: null,
|
|
41
|
-
uptimeSegments: [],
|
|
42
|
-
};
|
|
43
|
-
}
|
|
44
|
-
start() {
|
|
45
|
-
if (this._running)
|
|
46
|
-
return;
|
|
47
|
-
this._running = true;
|
|
48
|
-
this._stats.startedAt = Date.now();
|
|
49
|
-
this._stats.lastUptimeStart = Date.now();
|
|
50
|
-
this._log('[HEALTH] Session health monitor started');
|
|
51
|
-
this._log(`[HEALTH] Check interval: ${Math.round(this.options.checkIntervalMs / 60000)}min + up to ${Math.round(this.options.jitterMs / 60000)}min jitter`);
|
|
52
|
-
this._log(`[HEALTH] Auto-relogin: ${this.options.autoRelogin ? 'enabled' : 'disabled'}`);
|
|
53
|
-
this._scheduleNextCheck();
|
|
54
|
-
if (this.rt) {
|
|
55
|
-
this.rt.on('reconnected', () => {
|
|
56
|
-
this._stats.reconnects++;
|
|
57
|
-
this._recordUptimeSegment();
|
|
58
|
-
this._stats.lastUptimeStart = Date.now();
|
|
59
|
-
this._log('[HEALTH] Reconnected - uptime segment recorded');
|
|
60
|
-
});
|
|
61
|
-
this.rt.on('disconnect', () => {
|
|
62
|
-
this._recordUptimeSegment();
|
|
63
|
-
});
|
|
64
|
-
this.rt.on('reconnect_failed', () => {
|
|
65
|
-
this._log('[HEALTH] All reconnect attempts exhausted - checking session validity');
|
|
66
|
-
this._performCheck().catch(() => { });
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
stop() {
|
|
71
|
-
this._running = false;
|
|
72
|
-
if (this._checkTimer) {
|
|
73
|
-
clearTimeout(this._checkTimer);
|
|
74
|
-
this._checkTimer = null;
|
|
75
|
-
}
|
|
76
|
-
this._recordUptimeSegment();
|
|
77
|
-
this._log('[HEALTH] Session health monitor stopped');
|
|
78
|
-
}
|
|
79
|
-
_scheduleNextCheck() {
|
|
80
|
-
if (!this._running)
|
|
81
|
-
return;
|
|
82
|
-
if (this._checkTimer)
|
|
83
|
-
clearTimeout(this._checkTimer);
|
|
84
|
-
const jitter = Math.floor(Math.random() * this.options.jitterMs);
|
|
85
|
-
const delay = Math.max(MIN_CHECK_INTERVAL, this.options.checkIntervalMs + jitter);
|
|
86
|
-
this._checkTimer = setTimeout(async () => {
|
|
87
|
-
try {
|
|
88
|
-
await this._performCheck();
|
|
89
|
-
}
|
|
90
|
-
catch (e) {
|
|
91
|
-
this._log('[HEALTH] Check error:', (e === null || e === void 0 ? void 0 : e.message) || e);
|
|
92
|
-
}
|
|
93
|
-
this._scheduleNextCheck();
|
|
94
|
-
}, delay);
|
|
95
|
-
}
|
|
96
|
-
async _performCheck() {
|
|
97
|
-
this._stats.totalChecks++;
|
|
98
|
-
this._lastCheckAt = Date.now();
|
|
99
|
-
try {
|
|
100
|
-
const result = await this._checkSessionValidity();
|
|
101
|
-
this._lastCheckResult = result;
|
|
102
|
-
if (result.valid) {
|
|
103
|
-
this._consecutiveFailures = 0;
|
|
104
|
-
this._sessionValid = true;
|
|
105
|
-
this._stats.successfulChecks++;
|
|
106
|
-
this._log(`[HEALTH] Session valid (userId: ${result.userId || 'unknown'}, check #${this._stats.totalChecks})`);
|
|
107
|
-
this.emit('health_check', { status: 'ok', result, stats: this.getStats() });
|
|
108
|
-
return true;
|
|
109
|
-
}
|
|
110
|
-
else {
|
|
111
|
-
this._consecutiveFailures++;
|
|
112
|
-
this._stats.failedChecks++;
|
|
113
|
-
this._log(`[HEALTH] Session check failed (${this._consecutiveFailures}/${this.options.maxConsecutiveFailures}): ${result.reason}`);
|
|
114
|
-
this.emit('health_check', { status: 'failed', result, consecutiveFailures: this._consecutiveFailures });
|
|
115
|
-
if (this._consecutiveFailures >= 2) {
|
|
116
|
-
this._sessionValid = false;
|
|
117
|
-
this._stats.sessionExpiries++;
|
|
118
|
-
this._log('[HEALTH] Session appears expired');
|
|
119
|
-
this.emit('session_expired', { result, consecutiveFailures: this._consecutiveFailures });
|
|
120
|
-
if (this.options.autoRelogin) {
|
|
121
|
-
return await this._attemptRelogin();
|
|
122
|
-
}
|
|
123
|
-
else if (typeof this.options.onSessionExpired === 'function') {
|
|
124
|
-
try {
|
|
125
|
-
await this.options.onSessionExpired(result);
|
|
126
|
-
}
|
|
127
|
-
catch (e) { }
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
return false;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
catch (e) {
|
|
134
|
-
this._consecutiveFailures++;
|
|
135
|
-
this._stats.failedChecks++;
|
|
136
|
-
this._log('[HEALTH] Session check threw:', (e === null || e === void 0 ? void 0 : e.message) || e);
|
|
137
|
-
this.emit('health_check', { status: 'error', error: e === null || e === void 0 ? void 0 : e.message, consecutiveFailures: this._consecutiveFailures });
|
|
138
|
-
if (this._consecutiveFailures >= this.options.maxConsecutiveFailures) {
|
|
139
|
-
this._log(`[HEALTH] Max consecutive failures (${this.options.maxConsecutiveFailures}) reached`);
|
|
140
|
-
if (this.options.autoRelogin) {
|
|
141
|
-
return await this._attemptRelogin();
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
return false;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
async _checkSessionValidity() {
|
|
148
|
-
var _a, _b, _c;
|
|
149
|
-
try {
|
|
150
|
-
const response = await this.ig.request.send({
|
|
151
|
-
url: '/api/v1/accounts/current_user/',
|
|
152
|
-
method: 'GET',
|
|
153
|
-
qs: { edit: true },
|
|
154
|
-
});
|
|
155
|
-
if ((_a = response === null || response === void 0 ? void 0 : response.body) === null || _a === void 0 ? void 0 : _a.user) {
|
|
156
|
-
return {
|
|
157
|
-
valid: true,
|
|
158
|
-
userId: response.body.user.pk || response.body.user.pk_id,
|
|
159
|
-
username: response.body.user.username,
|
|
160
|
-
fullName: response.body.user.full_name,
|
|
161
|
-
};
|
|
162
|
-
}
|
|
163
|
-
return { valid: false, reason: 'No user data in response', statusCode: response === null || response === void 0 ? void 0 : response.statusCode };
|
|
164
|
-
}
|
|
165
|
-
catch (e) {
|
|
166
|
-
const status = ((_b = e === null || e === void 0 ? void 0 : e.response) === null || _b === void 0 ? void 0 : _b.statusCode) || (e === null || e === void 0 ? void 0 : e.statusCode);
|
|
167
|
-
const body = (_c = e === null || e === void 0 ? void 0 : e.response) === null || _c === void 0 ? void 0 : _c.body;
|
|
168
|
-
if (status === 401 || status === 403) {
|
|
169
|
-
return { valid: false, reason: `Auth error (${status})`, statusCode: status, requiresRelogin: true };
|
|
170
|
-
}
|
|
171
|
-
if (status === 429) {
|
|
172
|
-
return { valid: false, reason: 'Rate limited (429) - session might still be valid', statusCode: status, rateLimited: true };
|
|
173
|
-
}
|
|
174
|
-
if ((body === null || body === void 0 ? void 0 : body.message) === 'login_required' || (body === null || body === void 0 ? void 0 : body.error_type) === 'inactive user') {
|
|
175
|
-
return { valid: false, reason: body.message || body.error_type, statusCode: status, requiresRelogin: true };
|
|
176
|
-
}
|
|
177
|
-
if (e.code === 'ENOTFOUND' || e.code === 'ECONNREFUSED' || e.code === 'ETIMEDOUT') {
|
|
178
|
-
return { valid: false, reason: `Network error: ${e.code}`, networkError: true };
|
|
179
|
-
}
|
|
180
|
-
return { valid: false, reason: (e === null || e === void 0 ? void 0 : e.message) || 'Unknown error', statusCode: status };
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
async _attemptRelogin() {
|
|
184
|
-
var _a, _b;
|
|
185
|
-
if (this._reloginInProgress) {
|
|
186
|
-
this._log('[HEALTH] Relogin already in progress, skipping');
|
|
187
|
-
return false;
|
|
188
|
-
}
|
|
189
|
-
this._reloginInProgress = true;
|
|
190
|
-
this._stats.relogins++;
|
|
191
|
-
try {
|
|
192
|
-
const creds = this.options.credentials;
|
|
193
|
-
if (!creds || !creds.username || !creds.password) {
|
|
194
|
-
this._log('[HEALTH] No credentials available for auto-relogin');
|
|
195
|
-
this.emit('relogin_needed', { reason: 'No credentials configured' });
|
|
196
|
-
return false;
|
|
197
|
-
}
|
|
198
|
-
this._log(`[HEALTH] Attempting auto-relogin as ${creds.username}...`);
|
|
199
|
-
this.emit('relogin_start', { username: creds.username });
|
|
200
|
-
try {
|
|
201
|
-
await this.ig.login({ username: creds.username, password: creds.password });
|
|
202
|
-
this._log('[HEALTH] Relogin successful!');
|
|
203
|
-
this._stats.successfulRelogins++;
|
|
204
|
-
this._reloginCount++;
|
|
205
|
-
this._consecutiveFailures = 0;
|
|
206
|
-
this._sessionValid = true;
|
|
207
|
-
if (this.rt._attachedAuthState && typeof this.rt._attachedAuthState.saveCreds === 'function') {
|
|
208
|
-
try {
|
|
209
|
-
await this.rt._attachedAuthState.saveCreds(this.ig);
|
|
210
|
-
this._log('[HEALTH] Credentials saved after relogin');
|
|
211
|
-
}
|
|
212
|
-
catch (e) {
|
|
213
|
-
this._log('[HEALTH] Failed to save credentials:', (e === null || e === void 0 ? void 0 : e.message) || e);
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
this.emit('relogin_success', { username: creds.username, reloginCount: this._reloginCount });
|
|
217
|
-
try {
|
|
218
|
-
this._log('[HEALTH] Triggering MQTT reconnect with fresh session...');
|
|
219
|
-
await this.rt._attemptReconnectSafely();
|
|
220
|
-
}
|
|
221
|
-
catch (e) {
|
|
222
|
-
this._log('[HEALTH] MQTT reconnect after relogin failed:', (e === null || e === void 0 ? void 0 : e.message) || e);
|
|
223
|
-
}
|
|
224
|
-
return true;
|
|
225
|
-
}
|
|
226
|
-
catch (e) {
|
|
227
|
-
this._stats.failedRelogins++;
|
|
228
|
-
const isChallenge = ((_a = e === null || e === void 0 ? void 0 : e.message) === null || _a === void 0 ? void 0 : _a.includes('challenge')) || ((_b = e === null || e === void 0 ? void 0 : e.message) === null || _b === void 0 ? void 0 : _b.includes('checkpoint'));
|
|
229
|
-
this._log(`[HEALTH] Relogin failed: ${(e === null || e === void 0 ? void 0 : e.message) || e}`);
|
|
230
|
-
if (isChallenge) {
|
|
231
|
-
this._log('[HEALTH] Account requires verification - cannot auto-relogin');
|
|
232
|
-
this.emit('relogin_challenge', { error: e === null || e === void 0 ? void 0 : e.message });
|
|
233
|
-
}
|
|
234
|
-
this.emit('relogin_failed', { error: e === null || e === void 0 ? void 0 : e.message, isChallenge });
|
|
235
|
-
return false;
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
finally {
|
|
239
|
-
this._reloginInProgress = false;
|
|
240
|
-
}
|
|
241
|
-
}
|
|
242
|
-
async forceCheck() {
|
|
243
|
-
return this._performCheck();
|
|
244
|
-
}
|
|
245
|
-
isSessionValid() {
|
|
246
|
-
return this._sessionValid;
|
|
247
|
-
}
|
|
248
|
-
getStats() {
|
|
249
|
-
const now = Date.now();
|
|
250
|
-
const currentSegmentMs = this._stats.lastUptimeStart ? (now - this._stats.lastUptimeStart) : 0;
|
|
251
|
-
const totalUptime = this._stats.totalUptimeMs + currentSegmentMs;
|
|
252
|
-
const totalRuntime = this._stats.startedAt ? (now - this._stats.startedAt) : 0;
|
|
253
|
-
return {
|
|
254
|
-
running: this._running,
|
|
255
|
-
sessionValid: this._sessionValid,
|
|
256
|
-
startedAt: this._stats.startedAt ? new Date(this._stats.startedAt).toISOString() : null,
|
|
257
|
-
totalRuntimeMs: totalRuntime,
|
|
258
|
-
totalRuntimeHuman: this._humanDuration(totalRuntime),
|
|
259
|
-
totalUptimeMs: totalUptime,
|
|
260
|
-
totalUptimeHuman: this._humanDuration(totalUptime),
|
|
261
|
-
uptimePercent: totalRuntime > 0 ? Math.round((totalUptime / totalRuntime) * 10000) / 100 : 100,
|
|
262
|
-
currentSessionMs: currentSegmentMs,
|
|
263
|
-
currentSessionHuman: this._humanDuration(currentSegmentMs),
|
|
264
|
-
longestSessionMs: Math.max(this._stats.longestUptimeMs, currentSegmentMs),
|
|
265
|
-
longestSessionHuman: this._humanDuration(Math.max(this._stats.longestUptimeMs, currentSegmentMs)),
|
|
266
|
-
totalChecks: this._stats.totalChecks,
|
|
267
|
-
successfulChecks: this._stats.successfulChecks,
|
|
268
|
-
failedChecks: this._stats.failedChecks,
|
|
269
|
-
sessionExpiries: this._stats.sessionExpiries,
|
|
270
|
-
reconnects: this._stats.reconnects,
|
|
271
|
-
relogins: this._stats.relogins,
|
|
272
|
-
successfulRelogins: this._stats.successfulRelogins,
|
|
273
|
-
failedRelogins: this._stats.failedRelogins,
|
|
274
|
-
consecutiveFailures: this._consecutiveFailures,
|
|
275
|
-
lastCheckAt: this._lastCheckAt ? new Date(this._lastCheckAt).toISOString() : null,
|
|
276
|
-
lastCheckResult: this._lastCheckResult,
|
|
277
|
-
};
|
|
278
|
-
}
|
|
279
|
-
_recordUptimeSegment() {
|
|
280
|
-
if (this._stats.lastUptimeStart) {
|
|
281
|
-
const segmentMs = Date.now() - this._stats.lastUptimeStart;
|
|
282
|
-
this._stats.totalUptimeMs += segmentMs;
|
|
283
|
-
if (segmentMs > this._stats.longestUptimeMs)
|
|
284
|
-
this._stats.longestUptimeMs = segmentMs;
|
|
285
|
-
this._stats.uptimeSegments.push({
|
|
286
|
-
start: new Date(this._stats.lastUptimeStart).toISOString(),
|
|
287
|
-
end: new Date().toISOString(),
|
|
288
|
-
durationMs: segmentMs,
|
|
289
|
-
});
|
|
290
|
-
if (this._stats.uptimeSegments.length > 100) {
|
|
291
|
-
this._stats.uptimeSegments = this._stats.uptimeSegments.slice(-50);
|
|
292
|
-
}
|
|
293
|
-
this._stats.lastUptimeStart = null;
|
|
294
|
-
}
|
|
295
|
-
}
|
|
296
|
-
_humanDuration(ms) {
|
|
297
|
-
if (!ms || ms <= 0)
|
|
298
|
-
return '0s';
|
|
299
|
-
const d = Math.floor(ms / 86400000);
|
|
300
|
-
const h = Math.floor((ms % 86400000) / 3600000);
|
|
301
|
-
const m = Math.floor((ms % 3600000) / 60000);
|
|
302
|
-
const s = Math.floor((ms % 60000) / 1000);
|
|
303
|
-
const parts = [];
|
|
304
|
-
if (d > 0)
|
|
305
|
-
parts.push(`${d}d`);
|
|
306
|
-
if (h > 0)
|
|
307
|
-
parts.push(`${h}h`);
|
|
308
|
-
if (m > 0)
|
|
309
|
-
parts.push(`${m}m`);
|
|
310
|
-
if (s > 0 || parts.length === 0)
|
|
311
|
-
parts.push(`${s}s`);
|
|
312
|
-
return parts.join(' ');
|
|
313
|
-
}
|
|
314
|
-
_log(...args) {
|
|
315
|
-
if (this.rt && typeof this.rt.realtimeDebug === 'function') {
|
|
316
|
-
this.rt.realtimeDebug(...args);
|
|
317
|
-
}
|
|
318
|
-
else {
|
|
319
|
-
console.log(...args);
|
|
320
|
-
}
|
|
321
|
-
try {
|
|
322
|
-
this.emit('log', args.join(' '));
|
|
323
|
-
}
|
|
324
|
-
catch (e) { }
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
module.exports = { SessionHealthMonitor };
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GraphqlParser = void 0;
|
|
4
|
-
const thrift_1 = require("../../thrift");
|
|
5
|
-
const shared_1 = require("../../shared");
|
|
6
|
-
class GraphqlParser {
|
|
7
|
-
parseMessage(topic, payload) {
|
|
8
|
-
var _a;
|
|
9
|
-
const message = (0, shared_1.isJson)(payload)
|
|
10
|
-
? payload.toString()
|
|
11
|
-
: (_a = (0, thrift_1.thriftReadToObject)(payload, GraphqlParser.descriptors)) !== null && _a !== void 0 ? _a : '';
|
|
12
|
-
if (message.payload) {
|
|
13
|
-
message.json = JSON.parse(message.payload);
|
|
14
|
-
}
|
|
15
|
-
return { topic, data: { message } };
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
exports.GraphqlParser = GraphqlParser;
|
|
19
|
-
GraphqlParser.descriptors = [
|
|
20
|
-
thrift_1.ThriftDescriptors.binary('topic', 1),
|
|
21
|
-
thrift_1.ThriftDescriptors.binary('payload', 2),
|
|
22
|
-
];
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SkywalkerProtocol = void 0;
|
|
4
|
-
const shared_1 = require("../../shared");
|
|
5
|
-
const uuid_1 = require("uuid");
|
|
6
|
-
/**
|
|
7
|
-
* Skywalker Protocol - Real-time presence, typing, and reactions
|
|
8
|
-
*/
|
|
9
|
-
class SkywalkerProtocol {
|
|
10
|
-
constructor(client) {
|
|
11
|
-
this.skyDebug = (0, shared_1.debugChannel)('realtime', 'skywalker');
|
|
12
|
-
this.client = client;
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Send typing indicator
|
|
16
|
-
*/
|
|
17
|
-
async sendTypingIndicator(threadId, isTyping = true) {
|
|
18
|
-
var _a;
|
|
19
|
-
this.skyDebug(`${isTyping ? 'Starting' : 'Stopping'} typing in thread ${threadId}`);
|
|
20
|
-
const command = {
|
|
21
|
-
action: isTyping ? 'typing_on' : 'typing_off',
|
|
22
|
-
thread_id: threadId,
|
|
23
|
-
timestamp: Date.now(),
|
|
24
|
-
client_context: (0, uuid_1.v4)(),
|
|
25
|
-
};
|
|
26
|
-
return (_a = this.client.directCommands) === null || _a === void 0 ? void 0 : _a.sendCommand({
|
|
27
|
-
action: 'send_typing',
|
|
28
|
-
data: command,
|
|
29
|
-
threadId,
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Send message reaction
|
|
34
|
-
*/
|
|
35
|
-
async sendReaction(messageId, threadId, reactionEmoji) {
|
|
36
|
-
var _a;
|
|
37
|
-
this.skyDebug(`Sending reaction ${reactionEmoji} to message ${messageId}`);
|
|
38
|
-
const command = {
|
|
39
|
-
action: 'reaction',
|
|
40
|
-
message_id: messageId,
|
|
41
|
-
thread_id: threadId,
|
|
42
|
-
emoji: reactionEmoji,
|
|
43
|
-
timestamp: Date.now(),
|
|
44
|
-
client_context: (0, uuid_1.v4)(),
|
|
45
|
-
};
|
|
46
|
-
return (_a = this.client.directCommands) === null || _a === void 0 ? void 0 : _a.sendCommand({
|
|
47
|
-
action: 'send_reaction',
|
|
48
|
-
data: command,
|
|
49
|
-
threadId,
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Handle Skywalker event
|
|
54
|
-
*/
|
|
55
|
-
handleSkywalkerEvent(data) {
|
|
56
|
-
try {
|
|
57
|
-
const event = typeof data === 'string' ? JSON.parse(data) : data;
|
|
58
|
-
this.skyDebug(`Skywalker Event: ${event.type || 'unknown'}`);
|
|
59
|
-
if (event.type === 'typing_on') {
|
|
60
|
-
this.client.emit('typing', {
|
|
61
|
-
user_id: event.from_user_id,
|
|
62
|
-
thread_id: event.thread_id,
|
|
63
|
-
is_typing: true,
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
else if (event.type === 'typing_off') {
|
|
67
|
-
this.client.emit('typing', {
|
|
68
|
-
user_id: event.from_user_id,
|
|
69
|
-
thread_id: event.thread_id,
|
|
70
|
-
is_typing: false,
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
else if (event.type === 'reaction') {
|
|
74
|
-
this.client.emit('reaction', {
|
|
75
|
-
message_id: event.message_id,
|
|
76
|
-
user_id: event.from_user_id,
|
|
77
|
-
emoji: event.emoji,
|
|
78
|
-
thread_id: event.thread_id,
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
else if (event.type === 'presence') {
|
|
82
|
-
this.client.emit('presence', {
|
|
83
|
-
user_id: event.user_id,
|
|
84
|
-
status: event.status, // online, offline, away
|
|
85
|
-
last_activity: event.last_activity,
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
return event;
|
|
89
|
-
}
|
|
90
|
-
catch (err) {
|
|
91
|
-
this.skyDebug(`Failed to parse Skywalker event: ${err.message}`);
|
|
92
|
-
return null;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
exports.SkywalkerProtocol = SkywalkerProtocol;
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.delay = exports.debugChannel = exports.tryUnzipAsync = exports.compressDeflate = exports.prepareLogString = void 0;
|
|
4
|
-
const pako = require('pako');
|
|
5
|
-
const debug = require('debug');
|
|
6
|
-
function prepareLogString(str) {
|
|
7
|
-
return str.length > 100 ? str.substring(0, 100) + '...' : str;
|
|
8
|
-
}
|
|
9
|
-
exports.prepareLogString = prepareLogString;
|
|
10
|
-
function compressDeflate(data) {
|
|
11
|
-
return Buffer.from(pako.deflate(data));
|
|
12
|
-
}
|
|
13
|
-
exports.compressDeflate = compressDeflate;
|
|
14
|
-
async function tryUnzipAsync(data) {
|
|
15
|
-
try {
|
|
16
|
-
return Buffer.from(pako.inflate(data));
|
|
17
|
-
}
|
|
18
|
-
catch (e) {
|
|
19
|
-
return data;
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
exports.tryUnzipAsync = tryUnzipAsync;
|
|
23
|
-
function debugChannel(channel) {
|
|
24
|
-
return debug(`ig:mqtt:${channel}`);
|
|
25
|
-
}
|
|
26
|
-
exports.debugChannel = debugChannel;
|
|
27
|
-
function delay(ms) {
|
|
28
|
-
return new Promise(resolve => setTimeout(resolve, ms));
|
|
29
|
-
}
|
|
30
|
-
exports.delay = delay;
|
|
31
|
-
function createFbnsUserAgent(ig) {
|
|
32
|
-
var _a, _b, _c, _d;
|
|
33
|
-
const deviceStr = ((_a = ig.state) === null || _a === void 0 ? void 0 : _a.deviceString) || '';
|
|
34
|
-
const parts = deviceStr.split('; ');
|
|
35
|
-
const androidVersion = (parts[0] || '').split('/')[1] || '15';
|
|
36
|
-
const resolution = parts[2] || '1440x3120';
|
|
37
|
-
const manufacturer = (parts[3] || 'samsung').trim();
|
|
38
|
-
const deviceName = (parts[4] || 'SM-S928B').trim();
|
|
39
|
-
const [width, height] = resolution.split('x');
|
|
40
|
-
const params = {
|
|
41
|
-
FBAN: 'MQTT',
|
|
42
|
-
FBAV: ((_b = ig.state) === null || _b === void 0 ? void 0 : _b.appVersion) || '415.0.0.36.76',
|
|
43
|
-
FBBV: ((_c = ig.state) === null || _c === void 0 ? void 0 : _c.appVersionCode) || '580610226',
|
|
44
|
-
FBDM: `{density=4.0,width=${width},height=${height}`,
|
|
45
|
-
FBLC: ((_d = ig.state) === null || _d === void 0 ? void 0 : _d.language) || 'en_US',
|
|
46
|
-
FBCR: 'Android',
|
|
47
|
-
FBMF: manufacturer,
|
|
48
|
-
FBBD: 'Android',
|
|
49
|
-
FBPN: 'com.instagram.android',
|
|
50
|
-
FBDV: deviceName,
|
|
51
|
-
FBSV: androidVersion,
|
|
52
|
-
FBLR: '0',
|
|
53
|
-
FBBK: '1',
|
|
54
|
-
FBCA: 'x86:armeabi-v7a',
|
|
55
|
-
};
|
|
56
|
-
return `[${Object.entries(params).map(p => p.join('/')).join(';')}]`;
|
|
57
|
-
}
|
|
58
|
-
exports.createFbnsUserAgent = createFbnsUserAgent;
|
|
59
|
-
function notUndefined(a) {
|
|
60
|
-
return typeof a !== 'undefined';
|
|
61
|
-
}
|
|
62
|
-
exports.notUndefined = notUndefined;
|
|
63
|
-
function listenOnce(client, topic) {
|
|
64
|
-
return new Promise((resolve, reject) => {
|
|
65
|
-
const timeout = setTimeout(() => {
|
|
66
|
-
if (typeof removeFn === 'function')
|
|
67
|
-
try {
|
|
68
|
-
removeFn();
|
|
69
|
-
}
|
|
70
|
-
catch (e) { }
|
|
71
|
-
reject(new Error('listenOnce timeout after 30s'));
|
|
72
|
-
}, 30000);
|
|
73
|
-
let removeFn;
|
|
74
|
-
if (typeof client.listen === 'function') {
|
|
75
|
-
removeFn = client.listen(topic, msg => {
|
|
76
|
-
clearTimeout(timeout);
|
|
77
|
-
if (typeof removeFn === 'function')
|
|
78
|
-
try {
|
|
79
|
-
removeFn();
|
|
80
|
-
}
|
|
81
|
-
catch (e) { }
|
|
82
|
-
resolve(msg);
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
const handler = (msg) => {
|
|
87
|
-
if (msg && (msg.topic === topic || String(msg.topic) === String(topic))) {
|
|
88
|
-
clearTimeout(timeout);
|
|
89
|
-
client.removeListener('message', handler);
|
|
90
|
-
resolve(msg);
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
client.on('message', handler);
|
|
94
|
-
removeFn = () => client.removeListener('message', handler);
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
exports.listenOnce = listenOnce;
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
const { IgApiClient, RealtimeClient } = require('../dist/index');
|
|
2
|
-
const fs = require('fs');
|
|
3
|
-
const path = require('path');
|
|
4
|
-
|
|
5
|
-
// Listen to Instagram Direct Messages in Real-Time
|
|
6
|
-
// Setup: export INSTAGRAM_USERNAME, INSTAGRAM_PASSWORD, INSTAGRAM_EMAIL
|
|
7
|
-
// Run: node examples/listen-to-messages.js
|
|
8
|
-
|
|
9
|
-
async function main() {
|
|
10
|
-
const username = process.env.INSTAGRAM_USERNAME;
|
|
11
|
-
const password = process.env.INSTAGRAM_PASSWORD;
|
|
12
|
-
const email = process.env.INSTAGRAM_EMAIL;
|
|
13
|
-
|
|
14
|
-
if (!username || !password || !email) {
|
|
15
|
-
console.error('Missing credentials!');
|
|
16
|
-
console.error('Set: INSTAGRAM_USERNAME, INSTAGRAM_PASSWORD, INSTAGRAM_EMAIL');
|
|
17
|
-
process.exit(1);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
try {
|
|
21
|
-
console.log('\n📱 Instagram Direct Messages Listener\n');
|
|
22
|
-
|
|
23
|
-
const ig = new IgApiClient();
|
|
24
|
-
|
|
25
|
-
// Try to load saved session
|
|
26
|
-
const sessionFile = path.join(__dirname, '../.session');
|
|
27
|
-
if (fs.existsSync(sessionFile)) {
|
|
28
|
-
console.log('Loading saved session...');
|
|
29
|
-
const session = JSON.parse(fs.readFileSync(sessionFile, 'utf8'));
|
|
30
|
-
await ig.loadSession(session);
|
|
31
|
-
} else {
|
|
32
|
-
console.log('Logging in...');
|
|
33
|
-
await ig.login({ username, password, email });
|
|
34
|
-
const session = await ig.saveSession();
|
|
35
|
-
fs.writeFileSync(sessionFile, JSON.stringify(session));
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
console.log(`✓ Logged in as @${username}\n`);
|
|
39
|
-
|
|
40
|
-
const realtime = new RealtimeClient(ig);
|
|
41
|
-
|
|
42
|
-
realtime.on('connected', () => {
|
|
43
|
-
console.log('✓ Connected to MQTT\n');
|
|
44
|
-
console.log('Waiting for messages... (send a DM to yourself)\n');
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
realtime.on('receive', (topic, messages) => {
|
|
48
|
-
if (Array.isArray(messages)) {
|
|
49
|
-
messages.forEach(msg => {
|
|
50
|
-
if (msg.body) {
|
|
51
|
-
console.log('━━━━━━━━━━━━━━━━━━━━━━━');
|
|
52
|
-
console.log(`From: ${msg.from_user_id}`);
|
|
53
|
-
console.log(`Message: ${msg.body}`);
|
|
54
|
-
console.log('━━━━━━━━━━━━━━━━━━━━━━━\n');
|
|
55
|
-
}
|
|
56
|
-
if (msg.message_data?.body) {
|
|
57
|
-
console.log('━━━━━━━━━━━━━━━━━━━━━━━');
|
|
58
|
-
console.log(`From: ${msg.from_user_id}`);
|
|
59
|
-
console.log(`Message: ${msg.message_data.body}`);
|
|
60
|
-
console.log('━━━━━━━━━━━━━━━━━━━━━━━\n');
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
realtime.on('error', (error) => {
|
|
67
|
-
console.error('✗ Error:', error.message);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
console.log('Connecting to Instagram MQTT...');
|
|
71
|
-
|
|
72
|
-
await realtime.connect({
|
|
73
|
-
graphQlSubs: ['ig_sub_direct'],
|
|
74
|
-
irisData: null
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
console.log('Press Ctrl+C to stop\n');
|
|
78
|
-
await new Promise(() => {});
|
|
79
|
-
|
|
80
|
-
} catch (error) {
|
|
81
|
-
console.error('Error:', error.message);
|
|
82
|
-
process.exit(1);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
main();
|