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,115 +0,0 @@
|
|
|
1
|
-
const Repository = require('../core/repository');
|
|
2
|
-
|
|
3
|
-
class SearchService extends Repository {
|
|
4
|
-
async search(query, options = {}) {
|
|
5
|
-
const {
|
|
6
|
-
searchType = 'blended',
|
|
7
|
-
count = 30,
|
|
8
|
-
rankToken = this.client.state.uuid
|
|
9
|
-
} = options;
|
|
10
|
-
|
|
11
|
-
const response = await this.client.request.send({
|
|
12
|
-
method: 'GET',
|
|
13
|
-
url: '/api/v1/fbsearch/topsearch/',
|
|
14
|
-
qs: {
|
|
15
|
-
query,
|
|
16
|
-
search_surface: 'top_search_page',
|
|
17
|
-
timezone_offset: this.client.state.timezoneOffset,
|
|
18
|
-
count,
|
|
19
|
-
rank_token: rankToken,
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
return response.body;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
async searchUsers(query, count = 30) {
|
|
27
|
-
const response = await this.client.request.send({
|
|
28
|
-
method: 'GET',
|
|
29
|
-
url: '/api/v1/users/search/',
|
|
30
|
-
qs: {
|
|
31
|
-
q: query,
|
|
32
|
-
count,
|
|
33
|
-
rank_token: this.client.state.uuid,
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
return response.body;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
async searchHashtags(query, count = 30) {
|
|
41
|
-
const response = await this.client.request.send({
|
|
42
|
-
method: 'GET',
|
|
43
|
-
url: '/api/v1/tags/search/',
|
|
44
|
-
qs: {
|
|
45
|
-
q: query,
|
|
46
|
-
count,
|
|
47
|
-
rank_token: this.client.state.uuid,
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
return response.body;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
async searchLocations(query, lat = null, lng = null, count = 30) {
|
|
55
|
-
const qs = {
|
|
56
|
-
search_query: query,
|
|
57
|
-
count,
|
|
58
|
-
rank_token: this.client.state.uuid,
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
if (lat && lng) {
|
|
62
|
-
qs.latitude = lat;
|
|
63
|
-
qs.longitude = lng;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
const response = await this.client.request.send({
|
|
67
|
-
method: 'GET',
|
|
68
|
-
url: '/api/v1/location_search/',
|
|
69
|
-
qs
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
return response.body;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
async getRecentSearches() {
|
|
76
|
-
const response = await this.client.request.send({
|
|
77
|
-
method: 'GET',
|
|
78
|
-
url: '/api/v1/fbsearch/recent_searches/',
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
return response.body;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
async clearRecentSearches() {
|
|
85
|
-
const response = await this.client.request.send({
|
|
86
|
-
method: 'POST',
|
|
87
|
-
url: '/api/v1/fbsearch/clear_search_history/',
|
|
88
|
-
form: this.client.request.sign({
|
|
89
|
-
_uuid: this.client.state.uuid,
|
|
90
|
-
}),
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
return response.body;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
async getSuggestedUsers() {
|
|
97
|
-
const response = await this.client.request.send({
|
|
98
|
-
method: 'GET',
|
|
99
|
-
url: '/api/v1/discover/ayml/',
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
return response.body;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
async getSuggestedHashtags() {
|
|
106
|
-
const response = await this.client.request.send({
|
|
107
|
-
method: 'GET',
|
|
108
|
-
url: '/api/v1/tags/suggested/',
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
return response.body;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
module.exports = SearchService;
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.prepareLogString = exports.listenOnce = exports.notUndefined = exports.debugChannel = exports.isJson = exports.tryUnzipAsync = exports.unzipAsync = exports.compressDeflate = exports.createFbnsUserAgent = void 0;
|
|
4
|
-
const zlib_1 = require("zlib");
|
|
5
|
-
const debug_1 = require("debug");
|
|
6
|
-
const util_1 = require("util");
|
|
7
|
-
const deflatePromise = (0, util_1.promisify)(zlib_1.deflate);
|
|
8
|
-
const unzipPromise = (0, util_1.promisify)(zlib_1.unzip);
|
|
9
|
-
// TODO: map
|
|
10
|
-
function createFbnsUserAgent(ig) {
|
|
11
|
-
const [androidVersion, , resolution, manufacturer, deviceName] = ig.state.deviceString.split('; ');
|
|
12
|
-
const [width, height] = resolution.split('x');
|
|
13
|
-
const params = {
|
|
14
|
-
FBAN: 'MQTT',
|
|
15
|
-
FBAV: ig.state.appVersion,
|
|
16
|
-
FBBV: ig.state.appVersionCode,
|
|
17
|
-
FBDM: `{density=4.0,width=${width},height=${height}`,
|
|
18
|
-
FBLC: ig.state.language,
|
|
19
|
-
FBCR: 'Android',
|
|
20
|
-
FBMF: manufacturer.trim(),
|
|
21
|
-
FBBD: 'Android',
|
|
22
|
-
FBPN: 'com.instagram.android',
|
|
23
|
-
FBDV: deviceName.trim(),
|
|
24
|
-
FBSV: androidVersion.split('/')[1],
|
|
25
|
-
FBLR: '0',
|
|
26
|
-
FBBK: '1',
|
|
27
|
-
FBCA: 'x86:armeabi-v7a',
|
|
28
|
-
};
|
|
29
|
-
return `[${Object.entries(params)
|
|
30
|
-
.map(p => p.join('/'))
|
|
31
|
-
.join(';')}]`;
|
|
32
|
-
}
|
|
33
|
-
exports.createFbnsUserAgent = createFbnsUserAgent;
|
|
34
|
-
function compressDeflate(data) {
|
|
35
|
-
return deflatePromise(data, { level: 9 });
|
|
36
|
-
}
|
|
37
|
-
exports.compressDeflate = compressDeflate;
|
|
38
|
-
function unzipAsync(data) {
|
|
39
|
-
return unzipPromise(data);
|
|
40
|
-
}
|
|
41
|
-
exports.unzipAsync = unzipAsync;
|
|
42
|
-
async function tryUnzipAsync(data) {
|
|
43
|
-
try {
|
|
44
|
-
if (data.readInt8(0) !== 0x78)
|
|
45
|
-
return data;
|
|
46
|
-
return unzipAsync(data);
|
|
47
|
-
}
|
|
48
|
-
catch (e) {
|
|
49
|
-
return data;
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
exports.tryUnzipAsync = tryUnzipAsync;
|
|
53
|
-
function isJson(buffer) {
|
|
54
|
-
return !!String.fromCharCode(buffer[0]).match(/[{[]/);
|
|
55
|
-
}
|
|
56
|
-
exports.isJson = isJson;
|
|
57
|
-
/**
|
|
58
|
-
* Returns a debug function with a path starting with ig:mqtt
|
|
59
|
-
* @param {string} path
|
|
60
|
-
* @returns {(msg: string, ...additionalData: any) => void}
|
|
61
|
-
*/
|
|
62
|
-
const debugChannel = (...path) => (0, debug_1.default)(['ig', 'mqtt', ...path].join(':'));
|
|
63
|
-
exports.debugChannel = debugChannel;
|
|
64
|
-
function notUndefined(a) {
|
|
65
|
-
return typeof a !== 'undefined';
|
|
66
|
-
}
|
|
67
|
-
exports.notUndefined = notUndefined;
|
|
68
|
-
function listenOnce(client, topic) {
|
|
69
|
-
return new Promise(resolve => {
|
|
70
|
-
const removeFn = client.listen(topic, msg => {
|
|
71
|
-
removeFn();
|
|
72
|
-
resolve(msg);
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
exports.listenOnce = listenOnce;
|
|
77
|
-
const MAX_STRING_LENGTH = 128;
|
|
78
|
-
const ACTUAL_MAX_LEN = MAX_STRING_LENGTH - `"[${MAX_STRING_LENGTH}...]"`.length;
|
|
79
|
-
function prepareLogString(value) {
|
|
80
|
-
if (value.length > ACTUAL_MAX_LEN) {
|
|
81
|
-
value = `${value.substring(0, ACTUAL_MAX_LEN)}[${MAX_STRING_LENGTH}...]`;
|
|
82
|
-
}
|
|
83
|
-
return `"${value}"`;
|
|
84
|
-
}
|
|
85
|
-
exports.prepareLogString = prepareLogString;
|
|
86
|
-
//# sourceMappingURL=shared.js.map
|
|
@@ -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("./thrift"), exports);
|
|
18
|
-
__exportStar(require("./thrift.reading"), exports);
|
|
19
|
-
__exportStar(require("./thrift.writing"), exports);
|
|
20
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1,368 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BufferReader = exports.thriftReadToObject = exports.thriftRead = void 0;
|
|
4
|
-
const thrift_1 = require("./thrift");
|
|
5
|
-
const errors_1 = require("../errors");
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Thrift Compact Protocol reader (subset) for MQTT-over-Thrift payloads.
|
|
9
|
-
* Fixes / improvements:
|
|
10
|
-
* - fixes infinite loop in thriftRead()
|
|
11
|
-
* - correct INT_64 list decoding (BigInt zigzag varint)
|
|
12
|
-
* - faster descriptor lookup via Map in thriftReadSingleLevel()
|
|
13
|
-
* - keeps existing INT_64 return shape: { int: BigInt, num: Number, safe?: boolean }
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
function thriftRead(message) {
|
|
17
|
-
const reader = new BufferReader(message);
|
|
18
|
-
const messages = [];
|
|
19
|
-
let context = "";
|
|
20
|
-
|
|
21
|
-
// FIX: iterate using reader.position, not a constant local var
|
|
22
|
-
while (reader.position < message.length) {
|
|
23
|
-
const type = reader.readField();
|
|
24
|
-
|
|
25
|
-
if (type === thrift_1.ThriftTypes.STOP) {
|
|
26
|
-
if (reader.stack.length === 0) return messages;
|
|
27
|
-
reader.popStack();
|
|
28
|
-
context = reader.stack.join("/");
|
|
29
|
-
continue;
|
|
30
|
-
} else if (type === thrift_1.ThriftTypes.STRUCT) {
|
|
31
|
-
reader.pushStack();
|
|
32
|
-
context = reader.stack.join("/");
|
|
33
|
-
continue;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
messages.push(getReadFunction(type)({ reader, context }));
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
return messages;
|
|
40
|
-
}
|
|
41
|
-
exports.thriftRead = thriftRead;
|
|
42
|
-
|
|
43
|
-
function getReadFunction(type) {
|
|
44
|
-
switch (type) {
|
|
45
|
-
case thrift_1.ThriftTypes.STRUCT:
|
|
46
|
-
case thrift_1.ThriftTypes.STOP: {
|
|
47
|
-
throw new errors_1.InvalidStateError(`Invalid state: got type ${type}`);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
case thrift_1.ThriftTypes.TRUE:
|
|
51
|
-
case thrift_1.ThriftTypes.FALSE:
|
|
52
|
-
return ({ reader, context }) => ({
|
|
53
|
-
context,
|
|
54
|
-
field: reader.field,
|
|
55
|
-
value: type === thrift_1.ThriftTypes.TRUE,
|
|
56
|
-
type,
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
case thrift_1.ThriftTypes.BYTE:
|
|
60
|
-
return ({ reader, context }) => ({
|
|
61
|
-
context,
|
|
62
|
-
field: reader.field,
|
|
63
|
-
value: reader.readSByte(),
|
|
64
|
-
type,
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
case thrift_1.ThriftTypes.INT_16:
|
|
68
|
-
case thrift_1.ThriftTypes.INT_32:
|
|
69
|
-
return ({ reader, context }) => ({
|
|
70
|
-
context,
|
|
71
|
-
field: reader.field,
|
|
72
|
-
value: reader.readSmallInt(),
|
|
73
|
-
type,
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
case thrift_1.ThriftTypes.INT_64:
|
|
77
|
-
return ({ reader, context }) => ({
|
|
78
|
-
context,
|
|
79
|
-
field: reader.field,
|
|
80
|
-
value: reader.readBigint(),
|
|
81
|
-
type,
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
case thrift_1.ThriftTypes.BINARY:
|
|
85
|
-
return ({ reader, context }) => ({
|
|
86
|
-
context,
|
|
87
|
-
field: reader.field,
|
|
88
|
-
value: reader.readString(reader.readVarInt()),
|
|
89
|
-
type,
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
case thrift_1.ThriftTypes.SET:
|
|
93
|
-
case thrift_1.ThriftTypes.LIST:
|
|
94
|
-
return ({ reader, context }) => {
|
|
95
|
-
const byte = reader.readByte();
|
|
96
|
-
let size = byte >> 4;
|
|
97
|
-
const listType = byte & 0x0f;
|
|
98
|
-
if (size === 0x0f) size = reader.readVarInt();
|
|
99
|
-
return {
|
|
100
|
-
context,
|
|
101
|
-
field: reader.field,
|
|
102
|
-
value: reader.readList(size, listType),
|
|
103
|
-
type: (listType << 8) | type,
|
|
104
|
-
};
|
|
105
|
-
};
|
|
106
|
-
|
|
107
|
-
case thrift_1.ThriftTypes.MAP:
|
|
108
|
-
return ({ reader, context }) => {
|
|
109
|
-
const size = reader.readVarInt();
|
|
110
|
-
const kvType = size ? reader.readByte() : 0;
|
|
111
|
-
const keyType = (kvType & 0xf0) >> 4;
|
|
112
|
-
const valueType = kvType & 0x0f;
|
|
113
|
-
|
|
114
|
-
if (size && keyType && valueType) {
|
|
115
|
-
const keyFunc = getReadFunction(keyType);
|
|
116
|
-
const valueFunc = getReadFunction(valueType);
|
|
117
|
-
const entries = [];
|
|
118
|
-
for (let i = 0; i < size; i++) {
|
|
119
|
-
entries.push({
|
|
120
|
-
key: keyFunc({ reader, context }),
|
|
121
|
-
value: valueFunc({ reader, context }),
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
return {
|
|
125
|
-
context,
|
|
126
|
-
field: reader.field,
|
|
127
|
-
value: entries,
|
|
128
|
-
type: (kvType << 8) | type,
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
return {
|
|
133
|
-
context,
|
|
134
|
-
field: reader.field,
|
|
135
|
-
value: [],
|
|
136
|
-
type: (kvType << 8) | type,
|
|
137
|
-
};
|
|
138
|
-
};
|
|
139
|
-
|
|
140
|
-
default: {
|
|
141
|
-
throw new errors_1.ThriftError(`Unknown type: ${type}`);
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
function thriftReadToObject(message, descriptors) {
|
|
147
|
-
const readResult = thriftRead(message);
|
|
148
|
-
|
|
149
|
-
const topLevel = readResult.filter((x) => x.context.length === 0);
|
|
150
|
-
const result = thriftReadSingleLevel(topLevel, descriptors);
|
|
151
|
-
|
|
152
|
-
const structs = [];
|
|
153
|
-
for (const readData of readResult) {
|
|
154
|
-
if (readData.context.length === 0) continue;
|
|
155
|
-
|
|
156
|
-
const fieldPath = readData.context.split("/").map((c) => Number(c));
|
|
157
|
-
const possible = structs.findIndex((s) => equalArrays(s.fieldPath, fieldPath));
|
|
158
|
-
if (possible !== -1) {
|
|
159
|
-
structs[possible].items.push(readData);
|
|
160
|
-
} else {
|
|
161
|
-
structs.push({ fieldPath, items: [readData] });
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
for (const struct of structs) {
|
|
166
|
-
let descriptor;
|
|
167
|
-
for (const level of struct.fieldPath) {
|
|
168
|
-
if (descriptor) descriptor = descriptor.structDescriptors?.find((x) => x.field === level);
|
|
169
|
-
else descriptor = descriptors.find((x) => x.field === level);
|
|
170
|
-
if (!descriptor) break;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
if (descriptor) {
|
|
174
|
-
defineEnumerableProperty(
|
|
175
|
-
result,
|
|
176
|
-
descriptor.fieldName,
|
|
177
|
-
thriftReadSingleLevel(struct.items, descriptor.structDescriptors ?? [])
|
|
178
|
-
);
|
|
179
|
-
} else {
|
|
180
|
-
if (result.otherFindings) result.otherFindings.push(struct);
|
|
181
|
-
else result.otherFindings = [struct];
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
return result;
|
|
186
|
-
}
|
|
187
|
-
exports.thriftReadToObject = thriftReadToObject;
|
|
188
|
-
|
|
189
|
-
function thriftReadSingleLevel(readResults, descriptors) {
|
|
190
|
-
const result = {};
|
|
191
|
-
const otherFindings = [];
|
|
192
|
-
|
|
193
|
-
// PERF: build lookup map once
|
|
194
|
-
const byField = new Map();
|
|
195
|
-
for (const d of descriptors) {
|
|
196
|
-
// multiple descriptors could share field? keep first
|
|
197
|
-
if (!byField.has(d.field)) byField.set(d.field, []);
|
|
198
|
-
byField.get(d.field).push(d);
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
for (const message of readResults) {
|
|
202
|
-
const candidates = byField.get(message.field) || [];
|
|
203
|
-
const descriptor = candidates.find(
|
|
204
|
-
(d) =>
|
|
205
|
-
d.type === message.type ||
|
|
206
|
-
((0, thrift_1.isThriftBoolean)(message.type) && (0, thrift_1.isThriftBoolean)(d.type))
|
|
207
|
-
);
|
|
208
|
-
|
|
209
|
-
if (descriptor) {
|
|
210
|
-
// special checks for maps
|
|
211
|
-
if (descriptor.type === thrift_1.ThriftTypes.MAP_BINARY_BINARY) {
|
|
212
|
-
const res = {};
|
|
213
|
-
for (const pair of message.value) {
|
|
214
|
-
defineEnumerableProperty(res, pair.key.value, pair.value.value);
|
|
215
|
-
}
|
|
216
|
-
defineEnumerableProperty(result, descriptor.fieldName, res);
|
|
217
|
-
continue;
|
|
218
|
-
}
|
|
219
|
-
defineEnumerableProperty(result, descriptor.fieldName, message.value);
|
|
220
|
-
} else {
|
|
221
|
-
otherFindings.push(message);
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
return otherFindings.length > 0 ? { ...result, otherFindings } : result;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
const defineEnumerableProperty = (object, name, value) =>
|
|
229
|
-
Object.defineProperty(object, name, { value, enumerable: true });
|
|
230
|
-
|
|
231
|
-
class BufferReader {
|
|
232
|
-
get stack() {
|
|
233
|
-
return this._stack;
|
|
234
|
-
}
|
|
235
|
-
get position() {
|
|
236
|
-
return this._position;
|
|
237
|
-
}
|
|
238
|
-
get length() {
|
|
239
|
-
return this.buffer.length;
|
|
240
|
-
}
|
|
241
|
-
get field() {
|
|
242
|
-
return this._field;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
constructor(buffer) {
|
|
246
|
-
this._stack = [];
|
|
247
|
-
this._position = 0;
|
|
248
|
-
this._field = 0;
|
|
249
|
-
|
|
250
|
-
this.readInt16 = this.readSmallInt;
|
|
251
|
-
this.readInt32 = this.readSmallInt;
|
|
252
|
-
|
|
253
|
-
this.readByte = () => this.buffer.readUInt8(this.move(1));
|
|
254
|
-
this.readSByte = () => this.buffer.readInt8(this.move(1));
|
|
255
|
-
this.readString = (len) => this.buffer.toString("utf8", this.move(len), this._position);
|
|
256
|
-
|
|
257
|
-
this.buffer = buffer;
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
move(bytes) {
|
|
261
|
-
this._position = Math.min(Math.max(this._position + bytes, 0), this.buffer.length);
|
|
262
|
-
return this._position - bytes;
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
readVarInt() {
|
|
266
|
-
let shift = 0;
|
|
267
|
-
let result = 0;
|
|
268
|
-
while (this._position < this.length) {
|
|
269
|
-
const byte = this.readByte();
|
|
270
|
-
result |= (byte & 0x7f) << shift;
|
|
271
|
-
if ((byte & 0x80) === 0) break;
|
|
272
|
-
shift += 7;
|
|
273
|
-
}
|
|
274
|
-
return result;
|
|
275
|
-
}
|
|
276
|
-
|
|
277
|
-
readVarBigint() {
|
|
278
|
-
let shift = BigInt(0);
|
|
279
|
-
let result = BigInt(0);
|
|
280
|
-
while (true) {
|
|
281
|
-
const byte = this.readByte();
|
|
282
|
-
result = result | ((BigInt(byte) & BigInt(0x7f)) << shift);
|
|
283
|
-
if ((byte & 0x80) !== 0x80) break;
|
|
284
|
-
shift += BigInt(7);
|
|
285
|
-
}
|
|
286
|
-
return result;
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
zigzagToBigint(n) {
|
|
290
|
-
return (n >> BigInt(1)) ^ -(n & BigInt(1));
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
readBigint() {
|
|
294
|
-
const int = this.zigzagToBigint(this.readVarBigint());
|
|
295
|
-
const num = Number(int);
|
|
296
|
-
// keep backward shape, add a hint without breaking callers
|
|
297
|
-
const safe = int <= BigInt(Number.MAX_SAFE_INTEGER) && int >= BigInt(Number.MIN_SAFE_INTEGER);
|
|
298
|
-
return safe ? { int, num } : { int, num, safe };
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
readSmallInt() {
|
|
302
|
-
return BufferReader.fromZigZag(this.readVarInt());
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
readField() {
|
|
306
|
-
const byte = this.readByte();
|
|
307
|
-
if (byte === 0) return thrift_1.ThriftTypes.STOP;
|
|
308
|
-
|
|
309
|
-
const delta = (byte & 0xf0) >> 4;
|
|
310
|
-
if (delta === 0) {
|
|
311
|
-
this._field = BufferReader.fromZigZag(this.readVarInt());
|
|
312
|
-
} else {
|
|
313
|
-
this._field += delta;
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
return byte & 0x0f;
|
|
317
|
-
}
|
|
318
|
-
|
|
319
|
-
readList(size, type) {
|
|
320
|
-
const arr = [];
|
|
321
|
-
switch (type) {
|
|
322
|
-
case thrift_1.ThriftTypes.TRUE:
|
|
323
|
-
case thrift_1.ThriftTypes.FALSE: {
|
|
324
|
-
for (let i = 0; i < size; i++) arr[i] = this.readSByte() === thrift_1.ThriftTypes.TRUE;
|
|
325
|
-
break;
|
|
326
|
-
}
|
|
327
|
-
case thrift_1.ThriftTypes.BYTE: {
|
|
328
|
-
for (let i = 0; i < size; i++) arr[i] = this.readSByte();
|
|
329
|
-
break;
|
|
330
|
-
}
|
|
331
|
-
case thrift_1.ThriftTypes.INT_16:
|
|
332
|
-
case thrift_1.ThriftTypes.INT_32: {
|
|
333
|
-
for (let i = 0; i < size; i++) arr[i] = BufferReader.fromZigZag(this.readVarInt());
|
|
334
|
-
break;
|
|
335
|
-
}
|
|
336
|
-
case thrift_1.ThriftTypes.INT_64: {
|
|
337
|
-
// FIX: proper bigint varint + zigzag
|
|
338
|
-
for (let i = 0; i < size; i++) arr[i] = this.readBigint();
|
|
339
|
-
break;
|
|
340
|
-
}
|
|
341
|
-
case thrift_1.ThriftTypes.BINARY: {
|
|
342
|
-
for (let i = 0; i < size; i++) arr[i] = this.readString(this.readVarInt());
|
|
343
|
-
break;
|
|
344
|
-
}
|
|
345
|
-
default: {
|
|
346
|
-
throw new errors_1.ThriftError(`Type ${type} not impl.`);
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
return arr;
|
|
350
|
-
}
|
|
351
|
-
|
|
352
|
-
pushStack() {
|
|
353
|
-
this._stack.push(this.field);
|
|
354
|
-
this._field = 0;
|
|
355
|
-
}
|
|
356
|
-
popStack() {
|
|
357
|
-
this._field = this._stack.pop() ?? -1;
|
|
358
|
-
}
|
|
359
|
-
}
|
|
360
|
-
exports.BufferReader = BufferReader;
|
|
361
|
-
|
|
362
|
-
BufferReader.fromZigZag = (n) => (n >> 1) ^ -(n & 1);
|
|
363
|
-
|
|
364
|
-
function equalArrays(left, right) {
|
|
365
|
-
if (!left || !right || left.length !== right.length) return false;
|
|
366
|
-
for (let i = 0; i < left.length; i++) if (left[i] !== right[i]) return false;
|
|
367
|
-
return true;
|
|
368
|
-
}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isSafeInt64 = exports.int64ToBigInt = exports.int64ToNumberSafe = exports.int64ToNumber = exports.ThriftDescriptors = exports.isThriftBoolean = exports.ThriftTypes = void 0;
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Thrift Compact Protocol (subset) helpers used by nodejs-insta-private-api-mqt.
|
|
7
|
-
* Notes:
|
|
8
|
-
* - Instagram's MQTT-over-Thrift payloads can contain INT_64 values that exceed JS Number safe range.
|
|
9
|
-
* - This module keeps backward compatibility (int64ToNumber) but also exposes safe helpers.
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
exports.ThriftTypes = {
|
|
13
|
-
STOP: 0x00,
|
|
14
|
-
TRUE: 0x01,
|
|
15
|
-
FALSE: 0x02,
|
|
16
|
-
BYTE: 0x03,
|
|
17
|
-
INT_16: 0x04,
|
|
18
|
-
INT_32: 0x05,
|
|
19
|
-
INT_64: 0x06,
|
|
20
|
-
DOUBLE: 0x07,
|
|
21
|
-
BINARY: 0x08,
|
|
22
|
-
LIST: 0x09,
|
|
23
|
-
SET: 0x0a,
|
|
24
|
-
MAP: 0x0b,
|
|
25
|
-
STRUCT: 0x0c,
|
|
26
|
-
|
|
27
|
-
// Common "packed" meta-types used by this project:
|
|
28
|
-
LIST_INT_16: (0x04 << 8) | 0x09,
|
|
29
|
-
LIST_INT_32: (0x05 << 8) | 0x09,
|
|
30
|
-
LIST_INT_64: (0x06 << 8) | 0x09,
|
|
31
|
-
LIST_BINARY: (0x08 << 8) | 0x09,
|
|
32
|
-
MAP_BINARY_BINARY: (0x88 << 8) | 0x0b,
|
|
33
|
-
|
|
34
|
-
// internal!
|
|
35
|
-
BOOLEAN: 0xa1,
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
function isThriftBoolean(type) {
|
|
39
|
-
type &= 0x0f;
|
|
40
|
-
return (
|
|
41
|
-
type === exports.ThriftTypes.TRUE ||
|
|
42
|
-
type === exports.ThriftTypes.FALSE ||
|
|
43
|
-
type === exports.ThriftTypes.BOOLEAN
|
|
44
|
-
);
|
|
45
|
-
}
|
|
46
|
-
exports.isThriftBoolean = isThriftBoolean;
|
|
47
|
-
|
|
48
|
-
exports.ThriftDescriptors = {
|
|
49
|
-
boolean: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.BOOLEAN }),
|
|
50
|
-
byte: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.BYTE }),
|
|
51
|
-
int16: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.INT_16 }),
|
|
52
|
-
int32: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.INT_32 }),
|
|
53
|
-
int64: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.INT_64 }),
|
|
54
|
-
double: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.DOUBLE }),
|
|
55
|
-
binary: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.BINARY }),
|
|
56
|
-
listOfInt16: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.LIST_INT_16 }),
|
|
57
|
-
listOfInt32: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.LIST_INT_32 }),
|
|
58
|
-
listOfInt64: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.LIST_INT_64 }),
|
|
59
|
-
listOfBinary: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.LIST_BINARY }),
|
|
60
|
-
mapBinaryBinary: (fieldName, field) => ({ field, fieldName, type: exports.ThriftTypes.MAP_BINARY_BINARY }),
|
|
61
|
-
struct: (fieldName, field, descriptors) => ({
|
|
62
|
-
field,
|
|
63
|
-
fieldName,
|
|
64
|
-
type: exports.ThriftTypes.STRUCT,
|
|
65
|
-
structDescriptors: descriptors,
|
|
66
|
-
}),
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
function int64ToBigInt(i64) {
|
|
70
|
-
if (typeof i64 === "bigint") return i64;
|
|
71
|
-
if (typeof i64 === "number") return BigInt(i64);
|
|
72
|
-
if (typeof i64 === "string") return BigInt(i64);
|
|
73
|
-
if (i64 && typeof i64 === "object") {
|
|
74
|
-
// Support patterns: { int: bigint } (our reader), Long-like, etc.
|
|
75
|
-
if (typeof i64.int === "bigint") return i64.int;
|
|
76
|
-
if (typeof i64.toString === "function") return BigInt(i64.toString());
|
|
77
|
-
}
|
|
78
|
-
// Fallback (may throw)
|
|
79
|
-
return BigInt(i64);
|
|
80
|
-
}
|
|
81
|
-
exports.int64ToBigInt = int64ToBigInt;
|
|
82
|
-
|
|
83
|
-
function isSafeInt64(i64) {
|
|
84
|
-
const bi = int64ToBigInt(i64);
|
|
85
|
-
const max = BigInt(Number.MAX_SAFE_INTEGER);
|
|
86
|
-
const min = BigInt(Number.MIN_SAFE_INTEGER);
|
|
87
|
-
return bi <= max && bi >= min;
|
|
88
|
-
}
|
|
89
|
-
exports.isSafeInt64 = isSafeInt64;
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* Backward compatible: converts to Number (may lose precision if out of range).
|
|
93
|
-
*/
|
|
94
|
-
function int64ToNumber(i64) {
|
|
95
|
-
if (typeof i64 === "number") return i64;
|
|
96
|
-
// Preserve previous behavior (Number(...) fallback)
|
|
97
|
-
return Number(i64 && typeof i64 === "object" && "int" in i64 ? i64.int : i64);
|
|
98
|
-
}
|
|
99
|
-
exports.int64ToNumber = int64ToNumber;
|
|
100
|
-
|
|
101
|
-
/**
|
|
102
|
-
* Safe conversion: throws if out of safe range.
|
|
103
|
-
*/
|
|
104
|
-
function int64ToNumberSafe(i64) {
|
|
105
|
-
const bi = int64ToBigInt(i64);
|
|
106
|
-
if (!isSafeInt64(bi)) {
|
|
107
|
-
throw new RangeError(`int64 out of safe Number range: ${bi.toString()}`);
|
|
108
|
-
}
|
|
109
|
-
return Number(bi);
|
|
110
|
-
}
|
|
111
|
-
exports.int64ToNumberSafe = int64ToNumberSafe;
|