nodejs-insta-private-api-mqt 1.3.84 → 1.3.86
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 +4 -6
- 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 +41 -38
- 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,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./commands"), exports);
|
|
18
|
-
__exportStar(require("./direct.commands"), exports);
|
|
19
|
-
__exportStar(require("./enhanced.direct.commands"), exports);
|
|
20
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,293 +0,0 @@
|
|
|
1
|
-
const debug = require('debug')('ig:delta');
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Delta Sync Manager - Apply real Instagram delta updates to local state
|
|
5
|
-
* Based on MessageSync format from reverse-engineered instagram_mqtt
|
|
6
|
-
*/
|
|
7
|
-
class DeltaSyncManager {
|
|
8
|
-
constructor() {
|
|
9
|
-
this.state = {
|
|
10
|
-
threads: {}, // thread_id → ThreadUpdate
|
|
11
|
-
messages: {}, // item_id → MessageSyncMessage
|
|
12
|
-
typing: {}, // thread_id → TypingIndicator
|
|
13
|
-
presence: {} // user_id → PresenceIndicator
|
|
14
|
-
};
|
|
15
|
-
this.listeners = [];
|
|
16
|
-
this.operations = { add: 0, update: 0, delete: 0 };
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Apply delta operations (add/update/delete) to local state
|
|
21
|
-
*/
|
|
22
|
-
applyDelta(delta) {
|
|
23
|
-
if (!delta || !delta.items || delta.items.length === 0) {
|
|
24
|
-
return { applied: 0, errors: [], stats: this.operations };
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
let applied = 0;
|
|
28
|
-
const errors = [];
|
|
29
|
-
|
|
30
|
-
delta.items.forEach(item => {
|
|
31
|
-
try {
|
|
32
|
-
const result = this.applyItem(item);
|
|
33
|
-
if (result) applied++;
|
|
34
|
-
} catch (e) {
|
|
35
|
-
errors.push({
|
|
36
|
-
itemId: item.id || item.item_id,
|
|
37
|
-
error: e.message,
|
|
38
|
-
operation: item.op || item.type
|
|
39
|
-
});
|
|
40
|
-
debug(`❌ Error applying item:`, e.message);
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
// Notify listeners
|
|
45
|
-
if (applied > 0) {
|
|
46
|
-
this.notifyListeners(delta);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return {
|
|
50
|
-
applied,
|
|
51
|
-
errors,
|
|
52
|
-
total: delta.items.length,
|
|
53
|
-
stats: this.operations
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* Apply single item (message, thread, typing, presence)
|
|
59
|
-
*/
|
|
60
|
-
applyItem(item) {
|
|
61
|
-
if (!item) return false;
|
|
62
|
-
|
|
63
|
-
// Get operation type from IrisItem
|
|
64
|
-
const operation = item.op || item.type || 'add'; // add, replace, delete
|
|
65
|
-
|
|
66
|
-
// Extract data from 'data' oneof field
|
|
67
|
-
if (item.data?.message) {
|
|
68
|
-
return this.applyMessage(operation, item.data.message);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
if (item.data?.thread) {
|
|
72
|
-
return this.applyThread(operation, item.data.thread);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
if (item.data?.typing) {
|
|
76
|
-
return this.applyTyping(operation, item.data.typing);
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
if (item.data?.presence) {
|
|
80
|
-
return this.applyPresence(operation, item.data.presence);
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// Fallback for direct objects
|
|
84
|
-
if (item.message) {
|
|
85
|
-
return this.applyMessage(operation, item.message);
|
|
86
|
-
}
|
|
87
|
-
if (item.thread) {
|
|
88
|
-
return this.applyThread(operation, item.thread);
|
|
89
|
-
}
|
|
90
|
-
if (item.typing) {
|
|
91
|
-
return this.applyTyping(operation, item.typing);
|
|
92
|
-
}
|
|
93
|
-
if (item.presence) {
|
|
94
|
-
return this.applyPresence(operation, item.presence);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
return false;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* Apply message delta (real Instagram MessageSyncMessage format)
|
|
102
|
-
*/
|
|
103
|
-
applyMessage(operation, message) {
|
|
104
|
-
const msgId = message.item_id;
|
|
105
|
-
|
|
106
|
-
if (operation === 'delete' || operation === 'deletion') {
|
|
107
|
-
delete this.state.messages[msgId];
|
|
108
|
-
this.operations.delete++;
|
|
109
|
-
debug(`🗑️ Deleted message ${msgId}`);
|
|
110
|
-
return true;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
if (operation === 'replace' || operation === 'update') {
|
|
114
|
-
if (!this.state.messages[msgId]) {
|
|
115
|
-
debug(`⚠️ Message ${msgId} not found for update`);
|
|
116
|
-
return false;
|
|
117
|
-
}
|
|
118
|
-
Object.assign(this.state.messages[msgId], message);
|
|
119
|
-
this.operations.update++;
|
|
120
|
-
debug(`✏️ Updated message ${msgId}: "${message.text?.substring(0, 30)}"`);
|
|
121
|
-
return true;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
// add/default
|
|
125
|
-
this.state.messages[msgId] = message;
|
|
126
|
-
this.operations.add++;
|
|
127
|
-
debug(`➕ Added message ${msgId}: "${message.text?.substring(0, 30) || 'media'}"`);
|
|
128
|
-
return true;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* Apply thread delta (real Instagram ThreadUpdate format)
|
|
133
|
-
*/
|
|
134
|
-
applyThread(operation, thread) {
|
|
135
|
-
const threadId = thread.thread_id || thread.thread_v2_id;
|
|
136
|
-
|
|
137
|
-
if (operation === 'delete') {
|
|
138
|
-
delete this.state.threads[threadId];
|
|
139
|
-
this.operations.delete++;
|
|
140
|
-
debug(`🗑️ Deleted thread ${threadId}`);
|
|
141
|
-
return true;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if (operation === 'replace' || operation === 'update') {
|
|
145
|
-
if (!this.state.threads[threadId]) {
|
|
146
|
-
// Create new thread on update if doesn't exist
|
|
147
|
-
this.state.threads[threadId] = thread;
|
|
148
|
-
this.operations.add++;
|
|
149
|
-
debug(`➕ Created thread from update: ${thread.thread_title}`);
|
|
150
|
-
return true;
|
|
151
|
-
}
|
|
152
|
-
Object.assign(this.state.threads[threadId], thread);
|
|
153
|
-
this.operations.update++;
|
|
154
|
-
debug(`✏️ Updated thread ${threadId}: "${thread.thread_title}"`);
|
|
155
|
-
return true;
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
// add/default
|
|
159
|
-
this.state.threads[threadId] = thread;
|
|
160
|
-
this.operations.add++;
|
|
161
|
-
debug(`➕ Added thread: "${thread.thread_title}" (${thread.user_ids?.length || 1} members)`);
|
|
162
|
-
return true;
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
/**
|
|
166
|
-
* Apply typing indicator delta
|
|
167
|
-
*/
|
|
168
|
-
applyTyping(operation, typing) {
|
|
169
|
-
const threadId = typing.thread_id;
|
|
170
|
-
|
|
171
|
-
if (operation === 'delete' || typing.state === 'stopped') {
|
|
172
|
-
delete this.state.typing[threadId];
|
|
173
|
-
this.operations.delete++;
|
|
174
|
-
debug(`⌨️ User ${typing.from_user_id} stopped typing in ${threadId}`);
|
|
175
|
-
return true;
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
this.state.typing[threadId] = typing;
|
|
179
|
-
this.operations.add++;
|
|
180
|
-
debug(`⌨️ User ${typing.from_user_id} typing in ${threadId}`);
|
|
181
|
-
return true;
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
/**
|
|
185
|
-
* Apply presence indicator delta
|
|
186
|
-
*/
|
|
187
|
-
applyPresence(operation, presence) {
|
|
188
|
-
const userId = presence.user_id;
|
|
189
|
-
|
|
190
|
-
if (operation === 'delete' || presence.status === 'inactive') {
|
|
191
|
-
delete this.state.presence[userId];
|
|
192
|
-
this.operations.delete++;
|
|
193
|
-
debug(`🔴 User ${userId} offline`);
|
|
194
|
-
return true;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
this.state.presence[userId] = presence;
|
|
198
|
-
this.operations.add++;
|
|
199
|
-
debug(`🟢 User ${userId} ${presence.status}`);
|
|
200
|
-
return true;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
/**
|
|
204
|
-
* Subscribe to state changes
|
|
205
|
-
*/
|
|
206
|
-
subscribe(callback) {
|
|
207
|
-
this.listeners.push(callback);
|
|
208
|
-
return () => {
|
|
209
|
-
this.listeners = this.listeners.filter(l => l !== callback);
|
|
210
|
-
};
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
/**
|
|
214
|
-
* Notify listeners of changes
|
|
215
|
-
*/
|
|
216
|
-
notifyListeners(delta) {
|
|
217
|
-
this.listeners.forEach(callback => {
|
|
218
|
-
try {
|
|
219
|
-
callback(delta, this.getState());
|
|
220
|
-
} catch (e) {
|
|
221
|
-
debug('Listener error:', e.message);
|
|
222
|
-
}
|
|
223
|
-
});
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
/**
|
|
227
|
-
* Get current synchronized state
|
|
228
|
-
*/
|
|
229
|
-
getState() {
|
|
230
|
-
return {
|
|
231
|
-
threads: JSON.parse(JSON.stringify(this.state.threads)),
|
|
232
|
-
messages: JSON.parse(JSON.stringify(this.state.messages)),
|
|
233
|
-
typing: JSON.parse(JSON.stringify(this.state.typing)),
|
|
234
|
-
presence: JSON.parse(JSON.stringify(this.state.presence))
|
|
235
|
-
};
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
/**
|
|
239
|
-
* Query methods
|
|
240
|
-
*/
|
|
241
|
-
getThread(threadId) {
|
|
242
|
-
return this.state.threads[threadId] || null;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
getThreadMessages(threadId) {
|
|
246
|
-
return Object.values(this.state.messages).filter(m => m.thread_id === threadId || m.thread_v2_id === threadId);
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
getThreads() {
|
|
250
|
-
return Object.values(this.state.threads);
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
getAllMessages() {
|
|
254
|
-
return Object.values(this.state.messages);
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
getTypingInThread(threadId) {
|
|
258
|
-
return this.state.typing[threadId] || null;
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
getUserPresence(userId) {
|
|
262
|
-
return this.state.presence[userId] || null;
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
/**
|
|
266
|
-
* Stats
|
|
267
|
-
*/
|
|
268
|
-
getStats() {
|
|
269
|
-
return {
|
|
270
|
-
threads: Object.keys(this.state.threads).length,
|
|
271
|
-
messages: Object.keys(this.state.messages).length,
|
|
272
|
-
typing: Object.keys(this.state.typing).length,
|
|
273
|
-
presence: Object.keys(this.state.presence).length,
|
|
274
|
-
operations: this.operations
|
|
275
|
-
};
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
/**
|
|
279
|
-
* Clear all state
|
|
280
|
-
*/
|
|
281
|
-
clear() {
|
|
282
|
-
this.state = {
|
|
283
|
-
threads: {},
|
|
284
|
-
messages: {},
|
|
285
|
-
typing: {},
|
|
286
|
-
presence: {}
|
|
287
|
-
};
|
|
288
|
-
this.operations = { add: 0, update: 0, delete: 0 };
|
|
289
|
-
debug('✓ State cleared');
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
module.exports = DeltaSyncManager;
|
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ErrorHandler = void 0;
|
|
4
|
-
const shared_1 = require("../../shared");
|
|
5
|
-
|
|
6
|
-
const ERROR_TYPES = {
|
|
7
|
-
RATE_LIMIT: 'rate_limit',
|
|
8
|
-
AUTH_FAILURE: 'auth_failure',
|
|
9
|
-
NETWORK: 'network',
|
|
10
|
-
PROTOCOL: 'protocol',
|
|
11
|
-
SERVER: 'server',
|
|
12
|
-
UNKNOWN: 'unknown',
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
const RATE_LIMIT_PATTERNS = [
|
|
16
|
-
'rate limit', 'too many', 'throttl', 'spam', 'please wait',
|
|
17
|
-
'action blocked', 'try again later', 'temporarily blocked',
|
|
18
|
-
'429', 'flood',
|
|
19
|
-
];
|
|
20
|
-
|
|
21
|
-
const AUTH_PATTERNS = [
|
|
22
|
-
'auth', 'login', 'session', 'credential', 'token', 'expired',
|
|
23
|
-
'unauthorized', '401', 'forbidden', '403', 'password',
|
|
24
|
-
'challenge_required', 'checkpoint', 'checkpoint_required',
|
|
25
|
-
'login_required', 'consent_required', 'two_factor',
|
|
26
|
-
];
|
|
27
|
-
|
|
28
|
-
const NETWORK_PATTERNS = [
|
|
29
|
-
'ECONNRESET', 'ECONNREFUSED', 'ETIMEDOUT', 'ENOTFOUND',
|
|
30
|
-
'ENETUNREACH', 'socket hang up', 'network', 'dns',
|
|
31
|
-
'getaddrinfo', 'connect EHOSTUNREACH', 'EPIPE', 'EAI_AGAIN',
|
|
32
|
-
];
|
|
33
|
-
|
|
34
|
-
class ErrorHandler {
|
|
35
|
-
constructor(client) {
|
|
36
|
-
this.errorDebug = (0, shared_1.debugChannel)('realtime', 'errors');
|
|
37
|
-
this.errorCount = 0;
|
|
38
|
-
this.maxRetries = 15;
|
|
39
|
-
this.client = client;
|
|
40
|
-
this.errorHistory = [];
|
|
41
|
-
this.rateLimitUntil = 0;
|
|
42
|
-
this.consecutiveAuthFailures = 0;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
classifyError(error) {
|
|
46
|
-
const msg = (error?.message || String(error)).toLowerCase();
|
|
47
|
-
|
|
48
|
-
for (const pattern of RATE_LIMIT_PATTERNS) {
|
|
49
|
-
if (msg.includes(pattern)) return ERROR_TYPES.RATE_LIMIT;
|
|
50
|
-
}
|
|
51
|
-
for (const pattern of AUTH_PATTERNS) {
|
|
52
|
-
if (msg.includes(pattern)) return ERROR_TYPES.AUTH_FAILURE;
|
|
53
|
-
}
|
|
54
|
-
for (const pattern of NETWORK_PATTERNS) {
|
|
55
|
-
if (msg.includes(pattern.toLowerCase())) return ERROR_TYPES.NETWORK;
|
|
56
|
-
}
|
|
57
|
-
if (msg.includes('connack') || msg.includes('protocol') || msg.includes('thrift') || msg.includes('parse')) {
|
|
58
|
-
return ERROR_TYPES.PROTOCOL;
|
|
59
|
-
}
|
|
60
|
-
if (msg.includes('500') || msg.includes('502') || msg.includes('503') || msg.includes('server')) {
|
|
61
|
-
return ERROR_TYPES.SERVER;
|
|
62
|
-
}
|
|
63
|
-
return ERROR_TYPES.UNKNOWN;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
getBackoffForType(errorType, attemptNumber) {
|
|
67
|
-
const jitter = Math.floor(Math.random() * 2000);
|
|
68
|
-
switch (errorType) {
|
|
69
|
-
case ERROR_TYPES.RATE_LIMIT:
|
|
70
|
-
return Math.min(60000 * Math.pow(1.5, attemptNumber - 1), 600000) + jitter;
|
|
71
|
-
case ERROR_TYPES.AUTH_FAILURE:
|
|
72
|
-
return Math.min(10000 * Math.pow(2, attemptNumber - 1), 120000) + jitter;
|
|
73
|
-
case ERROR_TYPES.NETWORK:
|
|
74
|
-
return Math.min(2000 * Math.pow(2, attemptNumber - 1), 60000) + jitter;
|
|
75
|
-
case ERROR_TYPES.SERVER:
|
|
76
|
-
return Math.min(5000 * Math.pow(2, attemptNumber - 1), 120000) + jitter;
|
|
77
|
-
case ERROR_TYPES.PROTOCOL:
|
|
78
|
-
return Math.min(5000 * Math.pow(2, attemptNumber - 1), 60000) + jitter;
|
|
79
|
-
default:
|
|
80
|
-
return Math.min(3000 * Math.pow(2, attemptNumber - 1), 90000) + jitter;
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
handleConnectionError(error) {
|
|
85
|
-
this.errorCount++;
|
|
86
|
-
const errorType = this.classifyError(error);
|
|
87
|
-
const delay = this.getBackoffForType(errorType, this.errorCount);
|
|
88
|
-
|
|
89
|
-
this.errorHistory.push({
|
|
90
|
-
type: errorType,
|
|
91
|
-
message: error?.message || String(error),
|
|
92
|
-
timestamp: Date.now(),
|
|
93
|
-
attempt: this.errorCount,
|
|
94
|
-
});
|
|
95
|
-
if (this.errorHistory.length > 50) this.errorHistory.shift();
|
|
96
|
-
|
|
97
|
-
this.errorDebug(`[${errorType.toUpperCase()}] Error (${this.errorCount}/${this.maxRetries}): ${error?.message || error}`);
|
|
98
|
-
|
|
99
|
-
if (errorType === ERROR_TYPES.RATE_LIMIT) {
|
|
100
|
-
this.rateLimitUntil = Date.now() + delay;
|
|
101
|
-
this.errorDebug(`Rate limited. Waiting ${Math.round(delay/1000)}s before retry.`);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
if (errorType === ERROR_TYPES.AUTH_FAILURE) {
|
|
105
|
-
this.consecutiveAuthFailures++;
|
|
106
|
-
if (this.consecutiveAuthFailures >= 3) {
|
|
107
|
-
this.errorDebug('Multiple auth failures. Credentials may need refresh.');
|
|
108
|
-
this.client.emit('auth_failure', {
|
|
109
|
-
count: this.consecutiveAuthFailures,
|
|
110
|
-
error: error?.message || String(error),
|
|
111
|
-
});
|
|
112
|
-
return false;
|
|
113
|
-
}
|
|
114
|
-
} else {
|
|
115
|
-
this.consecutiveAuthFailures = 0;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
if (this.errorCount >= this.maxRetries) {
|
|
119
|
-
this.client.emit('error', new Error(`Max retries (${this.maxRetries}) exceeded. Last error type: ${errorType}`));
|
|
120
|
-
return false;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
this.errorDebug(`Scheduling retry in ${Math.round(delay/1000)}s (type: ${errorType})`);
|
|
124
|
-
|
|
125
|
-
setTimeout(() => {
|
|
126
|
-
if (typeof this.client.reconnect === 'function') {
|
|
127
|
-
this.client.reconnect();
|
|
128
|
-
} else if (typeof this.client._attemptReconnectSafely === 'function') {
|
|
129
|
-
this.client._attemptReconnectSafely().catch(() => {});
|
|
130
|
-
}
|
|
131
|
-
}, delay);
|
|
132
|
-
|
|
133
|
-
return true;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
isRateLimited() {
|
|
137
|
-
return Date.now() < this.rateLimitUntil;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
getRateLimitRemainingMs() {
|
|
141
|
-
return Math.max(0, this.rateLimitUntil - Date.now());
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
handlePayloadError(error, topic) {
|
|
145
|
-
this.errorDebug(`Payload Error on topic ${topic}: ${error.message}`);
|
|
146
|
-
this.client.emit('warning', {
|
|
147
|
-
type: 'payload_error',
|
|
148
|
-
topic,
|
|
149
|
-
error: error.message,
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
handleProtocolError(error) {
|
|
154
|
-
this.errorDebug(`Protocol Error: ${error.message}`);
|
|
155
|
-
this.client.emit('error', new Error(`MQTT Protocol Error: ${error.message}`));
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
resetErrorCounter() {
|
|
159
|
-
this.errorCount = 0;
|
|
160
|
-
this.consecutiveAuthFailures = 0;
|
|
161
|
-
this.errorDebug('Error counter reset');
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
getErrorStats() {
|
|
165
|
-
const recentErrors = this.errorHistory.filter(e => Date.now() - e.timestamp < 3600000);
|
|
166
|
-
const typeBreakdown = {};
|
|
167
|
-
for (const e of recentErrors) {
|
|
168
|
-
typeBreakdown[e.type] = (typeBreakdown[e.type] || 0) + 1;
|
|
169
|
-
}
|
|
170
|
-
return {
|
|
171
|
-
errorCount: this.errorCount,
|
|
172
|
-
maxRetries: this.maxRetries,
|
|
173
|
-
canRetry: this.errorCount < this.maxRetries,
|
|
174
|
-
isRateLimited: this.isRateLimited(),
|
|
175
|
-
rateLimitRemainingMs: this.getRateLimitRemainingMs(),
|
|
176
|
-
consecutiveAuthFailures: this.consecutiveAuthFailures,
|
|
177
|
-
recentErrorCount: recentErrors.length,
|
|
178
|
-
typeBreakdown,
|
|
179
|
-
};
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
ErrorHandler.ERROR_TYPES = ERROR_TYPES;
|
|
184
|
-
exports.ErrorHandler = ErrorHandler;
|
|
185
|
-
exports.ERROR_TYPES = ERROR_TYPES;
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.GapHandler = void 0;
|
|
4
|
-
const shared_1 = require("../../shared");
|
|
5
|
-
/**
|
|
6
|
-
* Gap Handler - Handle message gaps and synchronization
|
|
7
|
-
*/
|
|
8
|
-
class GapHandler {
|
|
9
|
-
constructor(client) {
|
|
10
|
-
this.gapDebug = (0, shared_1.debugChannel)('realtime', 'gap');
|
|
11
|
-
this.threadGaps = new Map();
|
|
12
|
-
this.client = client;
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Detect message gap in thread
|
|
16
|
-
*/
|
|
17
|
-
detectGap(threadId, lastMessageId, newMessageId) {
|
|
18
|
-
const lastId = parseInt(lastMessageId, 10);
|
|
19
|
-
const newId = parseInt(newMessageId, 10);
|
|
20
|
-
const gap = Math.abs(newId - lastId) > 1;
|
|
21
|
-
|
|
22
|
-
if (gap) {
|
|
23
|
-
this.gapDebug(`Gap detected in thread ${threadId}: ${lastMessageId} -> ${newMessageId}`);
|
|
24
|
-
this.threadGaps.set(threadId, { from: lastMessageId, to: newMessageId });
|
|
25
|
-
this.client.emit('gap', {
|
|
26
|
-
thread_id: threadId,
|
|
27
|
-
gap_from: lastMessageId,
|
|
28
|
-
gap_to: newMessageId,
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
return gap;
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Handle gap by requesting missing messages
|
|
35
|
-
*/
|
|
36
|
-
async handleGap(threadId, gapFrom, gapTo) {
|
|
37
|
-
this.gapDebug(`Handling gap in ${threadId}: fetching messages ${gapFrom}-${gapTo}`);
|
|
38
|
-
try {
|
|
39
|
-
// Request missing messages from REST API
|
|
40
|
-
const thread = await this.client.ig.direct.getThread(threadId);
|
|
41
|
-
const messages = await thread.getMessages({ limit: 50 });
|
|
42
|
-
|
|
43
|
-
this.client.emit('gap_filled', {
|
|
44
|
-
thread_id: threadId,
|
|
45
|
-
messages_count: messages.length,
|
|
46
|
-
});
|
|
47
|
-
return messages;
|
|
48
|
-
} catch (err) {
|
|
49
|
-
this.gapDebug(`Failed to handle gap: ${err.message}`);
|
|
50
|
-
this.client.emit('error', new Error(`Gap handling failed for thread ${threadId}`));
|
|
51
|
-
return [];
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Clear gap tracking for thread
|
|
56
|
-
*/
|
|
57
|
-
clearGap(threadId) {
|
|
58
|
-
this.threadGaps.delete(threadId);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
exports.GapHandler = GapHandler;
|