fca-shadow 0.0.1-security → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of fca-shadow might be problematic. Click here for more details.
- package/.1obgge4cxlazf1346921747~ +0 -0
- package/CHANGELOG.md +2 -0
- package/DOCS.md +1738 -0
- package/GetThreads/GetThreadInfo.js +128 -0
- package/GetThreads/Last-Run.js +65 -0
- package/LICENSE-MIT +21 -0
- package/README.md +132 -3
- package/StateCrypt.js +96 -0
- package/broadcast.js +22 -0
- package/index.html +1200 -0
- package/index.js +684 -0
- package/languages/index.json +150 -0
- package/lib/getInfoNew.js +34 -0
- package/lib/getToken.js +44 -0
- package/logger.js +23 -0
- package/package/database/SyntheticDatabase.sqlite +0 -0
- package/package/database/index.js +358 -0
- package/package/database/node_modules/lodash/_baseGet/README.md +20 -0
- package/package/database/node_modules/lodash/_baseGet/index.js +74 -0
- package/package/database/node_modules/lodash/_baseGet/package.json +18 -0
- package/package/database/node_modules/lodash/add.js +22 -0
- package/package/database/node_modules/lodash/after.js +42 -0
- package/package/database/node_modules/lodash/array.js +67 -0
- package/package/database/node_modules/lodash/ary.js +29 -0
- package/package/database/node_modules/lodash/assign.js +58 -0
- package/package/database/node_modules/lodash/assignIn.js +40 -0
- package/package/database/node_modules/lodash/assignInWith.js +38 -0
- package/package/database/node_modules/lodash/assignWith.js +37 -0
- package/package/database/node_modules/lodash/at.js +23 -0
- package/package/database/node_modules/lodash/attempt.js +35 -0
- package/package/database/node_modules/lodash/before.js +40 -0
- package/package/database/node_modules/lodash/bind.js +57 -0
- package/package/database/node_modules/lodash/bindAll.js +41 -0
- package/package/database/node_modules/lodash/bindKey.js +68 -0
- package/package/database/node_modules/lodash/camelCase.js +29 -0
- package/package/database/node_modules/lodash/capitalize.js +23 -0
- package/package/database/node_modules/lodash/castArray.js +44 -0
- package/package/database/node_modules/lodash/ceil.js +26 -0
- package/package/database/node_modules/lodash/chain.js +38 -0
- package/package/database/node_modules/lodash/chunk.js +50 -0
- package/package/database/node_modules/lodash/clamp.js +39 -0
- package/package/database/node_modules/lodash/clone.js +36 -0
- package/package/database/node_modules/lodash/cloneDeep.js +29 -0
- package/package/database/node_modules/lodash/cloneDeepWith.js +40 -0
- package/package/database/node_modules/lodash/cloneWith.js +42 -0
- package/package/database/node_modules/lodash/collection.js +30 -0
- package/package/database/node_modules/lodash/commit.js +33 -0
- package/package/database/node_modules/lodash/compact.js +31 -0
- package/package/database/node_modules/lodash/concat.js +43 -0
- package/package/database/node_modules/lodash/cond.js +60 -0
- package/package/database/node_modules/lodash/conforms.js +35 -0
- package/package/database/node_modules/lodash/conformsTo.js +32 -0
- package/package/database/node_modules/lodash/constant.js +26 -0
- package/package/database/node_modules/lodash/core.js +3877 -0
- package/package/database/node_modules/lodash/core.min.js +29 -0
- package/package/database/node_modules/lodash/countBy.js +40 -0
- package/package/database/node_modules/lodash/create.js +43 -0
- package/package/database/node_modules/lodash/curry.js +57 -0
- package/package/database/node_modules/lodash/curryRight.js +54 -0
- package/package/database/node_modules/lodash/date.js +3 -0
- package/package/database/node_modules/lodash/debounce.js +191 -0
- package/package/database/node_modules/lodash/deburr.js +45 -0
- package/package/database/node_modules/lodash/defaultTo.js +25 -0
- package/package/database/node_modules/lodash/defaults.js +64 -0
- package/package/database/node_modules/lodash/defaultsDeep.js +30 -0
- package/package/database/node_modules/lodash/defer.js +26 -0
- package/package/database/node_modules/lodash/delay.js +28 -0
- package/package/database/node_modules/lodash/difference.js +33 -0
- package/package/database/node_modules/lodash/differenceBy.js +44 -0
- package/package/database/node_modules/lodash/differenceWith.js +40 -0
- package/package/database/node_modules/lodash/divide.js +22 -0
- package/package/database/node_modules/lodash/drop.js +38 -0
- package/package/database/node_modules/lodash/dropRight.js +39 -0
- package/package/database/node_modules/lodash/dropRightWhile.js +45 -0
- package/package/database/node_modules/lodash/dropWhile.js +45 -0
- package/package/database/node_modules/lodash/each.js +1 -0
- package/package/database/node_modules/lodash/eachRight.js +1 -0
- package/package/database/node_modules/lodash/endsWith.js +43 -0
- package/package/database/node_modules/lodash/entries.js +1 -0
- package/package/database/node_modules/lodash/entriesIn.js +1 -0
- package/package/database/node_modules/lodash/eq.js +37 -0
- package/package/database/node_modules/lodash/escape.js +43 -0
- package/package/database/node_modules/lodash/escapeRegExp.js +32 -0
- package/package/database/node_modules/lodash/every.js +56 -0
- package/package/database/node_modules/lodash/extend.js +1 -0
- package/package/database/node_modules/lodash/extendWith.js +1 -0
- package/package/database/node_modules/lodash/fill.js +45 -0
- package/package/database/node_modules/lodash/filter.js +52 -0
- package/package/database/node_modules/lodash/find.js +42 -0
- package/package/database/node_modules/lodash/findIndex.js +55 -0
- package/package/database/node_modules/lodash/findKey.js +44 -0
- package/package/database/node_modules/lodash/findLast.js +25 -0
- package/package/database/node_modules/lodash/findLastIndex.js +59 -0
- package/package/database/node_modules/lodash/findLastKey.js +44 -0
- package/package/database/node_modules/lodash/first.js +1 -0
- package/package/database/node_modules/lodash/flake.lock +40 -0
- package/package/database/node_modules/lodash/flake.nix +20 -0
- package/package/database/node_modules/lodash/flatMap.js +29 -0
- package/package/database/node_modules/lodash/flatMapDeep.js +31 -0
- package/package/database/node_modules/lodash/flatMapDepth.js +31 -0
- package/package/database/node_modules/lodash/flatten.js +22 -0
- package/package/database/node_modules/lodash/flattenDeep.js +25 -0
- package/package/database/node_modules/lodash/flattenDepth.js +33 -0
- package/package/database/node_modules/lodash/flip.js +28 -0
- package/package/database/node_modules/lodash/floor.js +26 -0
- package/package/database/node_modules/lodash/flow.js +27 -0
- package/package/database/node_modules/lodash/flowRight.js +26 -0
- package/package/database/node_modules/lodash/forEach.js +41 -0
- package/package/database/node_modules/lodash/forEachRight.js +31 -0
- package/package/database/node_modules/lodash/forIn.js +39 -0
- package/package/database/node_modules/lodash/forInRight.js +37 -0
- package/package/database/node_modules/lodash/forOwn.js +36 -0
- package/package/database/node_modules/lodash/forOwnRight.js +34 -0
- package/package/database/node_modules/lodash/fp/F.js +1 -0
- package/package/database/node_modules/lodash/fp/add.js +5 -0
- package/package/database/node_modules/lodash/fp/after.js +5 -0
- package/package/database/node_modules/lodash/fp/all.js +1 -0
- package/package/database/node_modules/lodash/fp/allPass.js +1 -0
- package/package/database/node_modules/lodash/fp/always.js +1 -0
- package/package/database/node_modules/lodash/fp/any.js +1 -0
- package/package/database/node_modules/lodash/fp/anyPass.js +1 -0
- package/package/database/node_modules/lodash/fp/apply.js +1 -0
- package/package/database/node_modules/lodash/fp/array.js +2 -0
- package/package/database/node_modules/lodash/fp/ary.js +5 -0
- package/package/database/node_modules/lodash/fp/assign.js +5 -0
- package/package/database/node_modules/lodash/fp/assignAll.js +5 -0
- package/package/database/node_modules/lodash/fp/assignAllWith.js +5 -0
- package/package/database/node_modules/lodash/fp/assignIn.js +5 -0
- package/package/database/node_modules/lodash/fp/assignInAll.js +5 -0
- package/package/database/node_modules/lodash/fp/assignInAllWith.js +5 -0
- package/package/database/node_modules/lodash/fp/assignInWith.js +5 -0
- package/package/database/node_modules/lodash/fp/assignWith.js +5 -0
- package/package/database/node_modules/lodash/fp/assoc.js +1 -0
- package/package/database/node_modules/lodash/fp/assocPath.js +1 -0
- package/package/database/node_modules/lodash/fp/at.js +5 -0
- package/package/database/node_modules/lodash/fp/attempt.js +5 -0
- package/package/database/node_modules/lodash/fp/before.js +5 -0
- package/package/database/node_modules/lodash/fp/bind.js +5 -0
- package/package/database/node_modules/lodash/fp/bindAll.js +5 -0
- package/package/database/node_modules/lodash/fp/bindKey.js +5 -0
- package/package/database/node_modules/lodash/fp/camelCase.js +5 -0
- package/package/database/node_modules/lodash/fp/capitalize.js +5 -0
- package/package/database/node_modules/lodash/fp/castArray.js +5 -0
- package/package/database/node_modules/lodash/fp/ceil.js +5 -0
- package/package/database/node_modules/lodash/fp/chain.js +5 -0
- package/package/database/node_modules/lodash/fp/chunk.js +5 -0
- package/package/database/node_modules/lodash/fp/clamp.js +5 -0
- package/package/database/node_modules/lodash/fp/clone.js +5 -0
- package/package/database/node_modules/lodash/fp/cloneDeep.js +5 -0
- package/package/database/node_modules/lodash/fp/cloneDeepWith.js +5 -0
- package/package/database/node_modules/lodash/fp/cloneWith.js +5 -0
- package/package/database/node_modules/lodash/fp/collection.js +2 -0
- package/package/database/node_modules/lodash/fp/commit.js +5 -0
- package/package/database/node_modules/lodash/fp/compact.js +5 -0
- package/package/database/node_modules/lodash/fp/complement.js +1 -0
- package/package/database/node_modules/lodash/fp/compose.js +1 -0
- package/package/database/node_modules/lodash/fp/concat.js +5 -0
- package/package/database/node_modules/lodash/fp/cond.js +5 -0
- package/package/database/node_modules/lodash/fp/conforms.js +1 -0
- package/package/database/node_modules/lodash/fp/conformsTo.js +5 -0
- package/package/database/node_modules/lodash/fp/constant.js +5 -0
- package/package/database/node_modules/lodash/fp/contains.js +1 -0
- package/package/database/node_modules/lodash/fp/convert.js +18 -0
- package/package/database/node_modules/lodash/fp/countBy.js +5 -0
- package/package/database/node_modules/lodash/fp/create.js +5 -0
- package/package/database/node_modules/lodash/fp/curry.js +5 -0
- package/package/database/node_modules/lodash/fp/curryN.js +5 -0
- package/package/database/node_modules/lodash/fp/curryRight.js +5 -0
- package/package/database/node_modules/lodash/fp/curryRightN.js +5 -0
- package/package/database/node_modules/lodash/fp/date.js +2 -0
- package/package/database/node_modules/lodash/fp/debounce.js +5 -0
- package/package/database/node_modules/lodash/fp/deburr.js +5 -0
- package/package/database/node_modules/lodash/fp/defaultTo.js +5 -0
- package/package/database/node_modules/lodash/fp/defaults.js +5 -0
- package/package/database/node_modules/lodash/fp/defaultsAll.js +5 -0
- package/package/database/node_modules/lodash/fp/defaultsDeep.js +5 -0
- package/package/database/node_modules/lodash/fp/defaultsDeepAll.js +5 -0
- package/package/database/node_modules/lodash/fp/defer.js +5 -0
- package/package/database/node_modules/lodash/fp/delay.js +5 -0
- package/package/database/node_modules/lodash/fp/difference.js +5 -0
- package/package/database/node_modules/lodash/fp/differenceBy.js +5 -0
- package/package/database/node_modules/lodash/fp/differenceWith.js +5 -0
- package/package/database/node_modules/lodash/fp/dissoc.js +1 -0
- package/package/database/node_modules/lodash/fp/dissocPath.js +1 -0
- package/package/database/node_modules/lodash/fp/divide.js +5 -0
- package/package/database/node_modules/lodash/fp/drop.js +5 -0
- package/package/database/node_modules/lodash/fp/dropLast.js +1 -0
- package/package/database/node_modules/lodash/fp/dropLastWhile.js +1 -0
- package/package/database/node_modules/lodash/fp/dropRight.js +5 -0
- package/package/database/node_modules/lodash/fp/dropRightWhile.js +5 -0
- package/package/database/node_modules/lodash/fp/dropWhile.js +5 -0
- package/package/database/node_modules/lodash/fp/each.js +1 -0
- package/package/database/node_modules/lodash/fp/eachRight.js +1 -0
- package/package/database/node_modules/lodash/fp/endsWith.js +5 -0
- package/package/database/node_modules/lodash/fp/entries.js +1 -0
- package/package/database/node_modules/lodash/fp/entriesIn.js +1 -0
- package/package/database/node_modules/lodash/fp/eq.js +5 -0
- package/package/database/node_modules/lodash/fp/equals.js +1 -0
- package/package/database/node_modules/lodash/fp/escape.js +5 -0
- package/package/database/node_modules/lodash/fp/escapeRegExp.js +5 -0
- package/package/database/node_modules/lodash/fp/every.js +5 -0
- package/package/database/node_modules/lodash/fp/extend.js +1 -0
- package/package/database/node_modules/lodash/fp/extendAll.js +1 -0
- package/package/database/node_modules/lodash/fp/extendAllWith.js +1 -0
- package/package/database/node_modules/lodash/fp/extendWith.js +1 -0
- package/package/database/node_modules/lodash/fp/fill.js +5 -0
- package/package/database/node_modules/lodash/fp/filter.js +5 -0
- package/package/database/node_modules/lodash/fp/find.js +5 -0
- package/package/database/node_modules/lodash/fp/findFrom.js +5 -0
- package/package/database/node_modules/lodash/fp/findIndex.js +5 -0
- package/package/database/node_modules/lodash/fp/findIndexFrom.js +5 -0
- package/package/database/node_modules/lodash/fp/findKey.js +5 -0
- package/package/database/node_modules/lodash/fp/findLast.js +5 -0
- package/package/database/node_modules/lodash/fp.js +2 -0
- package/package/database/node_modules/lodash/fromPairs.js +28 -0
- package/package/database/node_modules/lodash/function.js +25 -0
- package/package/database/node_modules/lodash/functions.js +31 -0
- package/package/database/node_modules/lodash/functionsIn.js +31 -0
- package/package/database/node_modules/lodash/get.js +33 -0
- package/package/database/node_modules/node-fetch/CHANGELOG.md +266 -0
- package/package/database/node_modules/node-fetch/LICENSE.md +22 -0
- package/package/database/node_modules/node-fetch/README.md +583 -0
- package/package/database/node_modules/node-fetch/browser.js +23 -0
- package/package/database/node_modules/node-fetch/lib/index.es.js +1633 -0
- package/package/database/node_modules/node-fetch/lib/index.js +1642 -0
- package/package/database/node_modules/node-fetch/lib/index.mjs +1631 -0
- package/package/database/node_modules/node-fetch/package.json +70 -0
- package/package/database/node_modules/sqlite3/CHANGELOG.md +313 -0
- package/package/database/node_modules/sqlite3/CONTRIBUTING.md +57 -0
- package/package/database/node_modules/sqlite3/LICENSE +25 -0
- package/package/database/node_modules/sqlite3/README.md +259 -0
- package/package/database/node_modules/sqlite3/binding.gyp +66 -0
- package/package/database/node_modules/sqlite3/deps/common-sqlite.gypi +60 -0
- package/package/database/node_modules/sqlite3/deps/extract.js +10 -0
- package/package/database/node_modules/sqlite3/deps/sqlite-autoconf-3380200.tar.gz +0 -0
- package/package/database/node_modules/sqlite3/deps/sqlite3.gyp +121 -0
- package/package/database/node_modules/sqlite3/lib/binding/napi-v6-linux-x64/node_sqlite3.node +0 -0
- package/package/database/node_modules/sqlite3/lib/index.js +1 -0
- package/package/database/node_modules/sqlite3/lib/sqlite3-binding.js +5 -0
- package/package/database/node_modules/sqlite3/lib/sqlite3.js +205 -0
- package/package/database/node_modules/sqlite3/lib/trace.js +38 -0
- package/package/database/node_modules/sqlite3/package.json +82 -0
- package/package/database/node_modules/sqlite3/sqlite3.js +1 -0
- package/package/database/node_modules/sqlite3/src/async.h +82 -0
- package/package/database/node_modules/sqlite3/src/backup.cc +420 -0
- package/package/database/node_modules/sqlite3/src/backup.h +221 -0
- package/package/database/node_modules/sqlite3/src/database.cc +738 -0
- package/package/database/node_modules/sqlite3/src/database.h +206 -0
- package/package/database/node_modules/sqlite3/src/gcc-preinclude.h +6 -0
- package/package/database/node_modules/sqlite3/src/macros.h +212 -0
- package/package/database/node_modules/sqlite3/src/node_sqlite3.cc +115 -0
- package/package/database/node_modules/sqlite3/src/statement.cc +947 -0
- package/package/database/node_modules/sqlite3/src/statement.h +249 -0
- package/package/database/node_modules/sqlite3/src/threading.h +48 -0
- package/package/database/package.json +31 -0
- package/package/database/readme.md +8 -0
- package/package/database/test.js +3 -0
- package/package/horizon-sp/README.md +11 -0
- package/package/horizon-sp/index.js +41 -0
- package/package/horizon-sp/logger.js +16 -0
- package/package/horizon-sp/node_modules/.package-lock.json +140 -0
- package/package/horizon-sp/node_modules/asynckit/LICENSE +21 -0
- package/package/horizon-sp/node_modules/asynckit/README.md +233 -0
- package/package/horizon-sp/node_modules/asynckit/bench.js +76 -0
- package/package/horizon-sp/node_modules/asynckit/index.js +6 -0
- package/package/horizon-sp/node_modules/asynckit/lib/abort.js +29 -0
- package/package/horizon-sp/node_modules/asynckit/lib/async.js +34 -0
- package/package/horizon-sp/node_modules/asynckit/lib/defer.js +26 -0
- package/package/horizon-sp/node_modules/asynckit/lib/iterate.js +75 -0
- package/package/horizon-sp/node_modules/asynckit/lib/readable_asynckit.js +91 -0
- package/package/horizon-sp/node_modules/asynckit/lib/readable_parallel.js +25 -0
- package/package/horizon-sp/node_modules/asynckit/lib/readable_serial.js +25 -0
- package/package/horizon-sp/node_modules/asynckit/lib/readable_serial_ordered.js +29 -0
- package/package/horizon-sp/node_modules/asynckit/lib/state.js +37 -0
- package/package/horizon-sp/node_modules/asynckit/lib/streamify.js +141 -0
- package/package/horizon-sp/node_modules/asynckit/lib/terminator.js +29 -0
- package/package/horizon-sp/node_modules/asynckit/package.json +63 -0
- package/package/horizon-sp/node_modules/asynckit/parallel.js +43 -0
- package/package/horizon-sp/node_modules/asynckit/serial.js +17 -0
- package/package/horizon-sp/node_modules/asynckit/serialOrdered.js +75 -0
- package/package/horizon-sp/node_modules/asynckit/stream.js +21 -0
- package/package/horizon-sp/node_modules/axios/CHANGELOG.md +410 -0
- package/package/horizon-sp/node_modules/axios/LICENSE +7 -0
- package/package/horizon-sp/node_modules/axios/MIGRATION_GUIDE.md +3 -0
- package/package/horizon-sp/node_modules/axios/README.md +1310 -0
- package/package/horizon-sp/node_modules/axios/SECURITY.md +6 -0
- package/package/horizon-sp/node_modules/axios/index.d.cts +524 -0
- package/package/horizon-sp/node_modules/axios/index.d.ts +539 -0
- package/package/horizon-sp/node_modules/axios/index.js +41 -0
- package/package/horizon-sp/node_modules/axios/lib/adapters/README.md +37 -0
- package/package/horizon-sp/node_modules/axios/lib/adapters/adapters.js +59 -0
- package/package/horizon-sp/node_modules/axios/lib/adapters/http.js +608 -0
- package/package/horizon-sp/node_modules/axios/lib/adapters/xhr.js +249 -0
- package/package/horizon-sp/node_modules/axios/lib/axios.js +86 -0
- package/package/horizon-sp/node_modules/axios/lib/cancel/CancelToken.js +121 -0
- package/package/horizon-sp/node_modules/axios/lib/cancel/CanceledError.js +25 -0
- package/package/horizon-sp/node_modules/axios/lib/cancel/isCancel.js +5 -0
- package/package/horizon-sp/node_modules/axios/lib/core/Axios.js +197 -0
- package/package/horizon-sp/node_modules/axios/lib/core/AxiosError.js +100 -0
- package/package/horizon-sp/node_modules/axios/lib/core/AxiosHeaders.js +274 -0
- package/package/horizon-sp/node_modules/axios/lib/core/InterceptorManager.js +71 -0
- package/package/horizon-sp/node_modules/axios/lib/core/README.md +8 -0
- package/package/horizon-sp/node_modules/axios/lib/core/buildFullPath.js +21 -0
- package/package/horizon-sp/node_modules/axios/lib/core/dispatchRequest.js +81 -0
- package/package/horizon-sp/node_modules/axios/lib/core/mergeConfig.js +105 -0
- package/package/horizon-sp/node_modules/axios/lib/core/settle.js +27 -0
- package/package/horizon-sp/node_modules/axios/lib/core/transformData.js +28 -0
- package/package/horizon-sp/node_modules/axios/lib/defaults/index.js +166 -0
- package/package/horizon-sp/node_modules/axios/lib/defaults/transitional.js +7 -0
- package/package/horizon-sp/node_modules/axios/lib/env/README.md +3 -0
- package/package/horizon-sp/node_modules/axios/lib/env/classes/FormData.js +2 -0
- package/package/horizon-sp/node_modules/axios/lib/env/data.js +1 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/AxiosTransformStream.js +191 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/AxiosURLSearchParams.js +58 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/HttpStatusCode.js +71 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/README.md +7 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/bind.js +7 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/buildURL.js +63 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/combineURLs.js +15 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/cookies.js +52 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/deprecatedMethod.js +26 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/formDataToJSON.js +92 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/fromDataURI.js +53 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/isAbsoluteURL.js +15 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/isAxiosError.js +14 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/isURLSameOrigin.js +67 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/null.js +2 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/parseHeaders.js +55 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/parseProtocol.js +6 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/speedometer.js +55 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/spread.js +28 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/throttle.js +33 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/toFormData.js +229 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/toURLEncodedForm.js +18 -0
- package/package/horizon-sp/node_modules/axios/lib/helpers/validator.js +91 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/browser/classes/FormData.js +3 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/browser/classes/URLSearchParams.js +4 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/browser/index.js +63 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/index.js +3 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/node/classes/FormData.js +3 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/node/classes/URLSearchParams.js +4 -0
- package/package/horizon-sp/node_modules/axios/lib/platform/node/index.js +12 -0
- package/package/horizon-sp/node_modules/axios/lib/utils.js +677 -0
- package/package/horizon-sp/node_modules/axios/package.json +197 -0
- package/package/horizon-sp/node_modules/child_process/README.md +9 -0
- package/package/horizon-sp/node_modules/child_process/package.json +20 -0
- package/package/horizon-sp/node_modules/combined-stream/License +19 -0
- package/package/horizon-sp/node_modules/combined-stream/Readme.md +138 -0
- package/package/horizon-sp/node_modules/combined-stream/lib/combined_stream.js +208 -0
- package/package/horizon-sp/node_modules/combined-stream/package.json +25 -0
- package/package/horizon-sp/node_modules/delayed-stream/License +19 -0
- package/package/horizon-sp/node_modules/delayed-stream/Makefile +7 -0
- package/package/horizon-sp/node_modules/delayed-stream/Readme.md +141 -0
- package/package/horizon-sp/node_modules/delayed-stream/lib/delayed_stream.js +107 -0
- package/package/horizon-sp/node_modules/delayed-stream/package.json +27 -0
- package/package/horizon-sp/node_modules/follow-redirects/LICENSE +18 -0
- package/package/horizon-sp/node_modules/follow-redirects/README.md +155 -0
- package/package/horizon-sp/node_modules/follow-redirects/debug.js +15 -0
- package/package/horizon-sp/node_modules/follow-redirects/http.js +1 -0
- package/package/horizon-sp/node_modules/follow-redirects/https.js +1 -0
- package/package/horizon-sp/node_modules/follow-redirects/index.js +621 -0
- package/package/horizon-sp/node_modules/follow-redirects/package.json +59 -0
- package/package/horizon-sp/node_modules/form-data/License +19 -0
- package/package/horizon-sp/node_modules/form-data/README.md.bak +358 -0
- package/package/horizon-sp/node_modules/form-data/Readme.md +358 -0
- package/package/horizon-sp/node_modules/form-data/index.d.ts +62 -0
- package/package/horizon-sp/node_modules/form-data/lib/browser.js +2 -0
- package/package/horizon-sp/node_modules/form-data/lib/form_data.js +501 -0
- package/package/horizon-sp/node_modules/form-data/lib/populate.js +10 -0
- package/package/horizon-sp/node_modules/form-data/package.json +68 -0
- package/package/horizon-sp/node_modules/fs-extra/LICENSE +15 -0
- package/package/horizon-sp/node_modules/fs-extra/README.md +290 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/copy/copy-sync.js +161 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/copy/copy.js +238 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/copy/index.js +7 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/empty/index.js +39 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/ensure/file.js +69 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/ensure/index.js +23 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/ensure/link.js +64 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/ensure/symlink-paths.js +99 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/ensure/symlink-type.js +31 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/ensure/symlink.js +82 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/esm.mjs +68 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/fs/index.js +140 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/index.js +16 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/json/index.js +16 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/json/jsonfile.js +11 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/json/output-json-sync.js +12 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/json/output-json.js +12 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/mkdirs/index.js +14 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/mkdirs/make-dir.js +27 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/mkdirs/utils.js +21 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/move/index.js +7 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/move/move-sync.js +54 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/move/move.js +75 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/output-file/index.js +40 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/path-exists/index.js +12 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/remove/index.js +17 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/util/stat.js +154 -0
- package/package/horizon-sp/node_modules/fs-extra/lib/util/utimes.js +26 -0
- package/package/horizon-sp/node_modules/fs-extra/package.json +71 -0
- package/package/horizon-sp/node_modules/graceful-fs/LICENSE +15 -0
- package/package/horizon-sp/node_modules/graceful-fs/README.md +143 -0
- package/package/horizon-sp/node_modules/graceful-fs/clone.js +23 -0
- package/package/horizon-sp/node_modules/graceful-fs/graceful-fs.js +448 -0
- package/package/horizon-sp/node_modules/graceful-fs/legacy-streams.js +118 -0
- package/package/horizon-sp/node_modules/graceful-fs/package.json +50 -0
- package/package/horizon-sp/node_modules/graceful-fs/polyfills.js +355 -0
- package/package/horizon-sp/node_modules/jsonfile/CHANGELOG.md +171 -0
- package/package/horizon-sp/node_modules/jsonfile/LICENSE +15 -0
- package/package/horizon-sp/node_modules/jsonfile/README.md +230 -0
- package/package/horizon-sp/node_modules/jsonfile/index.js +88 -0
- package/package/horizon-sp/node_modules/jsonfile/package.json +40 -0
- package/package/horizon-sp/node_modules/jsonfile/utils.js +14 -0
- package/package/horizon-sp/node_modules/mime-db/HISTORY.md +507 -0
- package/package/horizon-sp/node_modules/mime-db/LICENSE +23 -0
- package/package/horizon-sp/node_modules/mime-db/README.md +100 -0
- package/package/horizon-sp/node_modules/mime-db/db.json +8519 -0
- package/package/horizon-sp/node_modules/mime-db/index.js +12 -0
- package/package/horizon-sp/node_modules/mime-db/package.json +60 -0
- package/package/horizon-sp/node_modules/mime-types/HISTORY.md +397 -0
- package/package/horizon-sp/node_modules/mime-types/LICENSE +23 -0
- package/package/horizon-sp/node_modules/mime-types/README.md +113 -0
- package/package/horizon-sp/node_modules/mime-types/index.js +188 -0
- package/package/horizon-sp/node_modules/mime-types/package.json +44 -0
- package/package/horizon-sp/node_modules/proxy-from-env/LICENSE +20 -0
- package/package/horizon-sp/node_modules/proxy-from-env/README.md +131 -0
- package/package/horizon-sp/node_modules/proxy-from-env/index.js +108 -0
- package/package/horizon-sp/node_modules/proxy-from-env/package.json +34 -0
- package/package/horizon-sp/node_modules/proxy-from-env/test.js +483 -0
- package/package/horizon-sp/node_modules/universalify/LICENSE +20 -0
- package/package/horizon-sp/node_modules/universalify/README.md +76 -0
- package/package/horizon-sp/node_modules/universalify/index.js +24 -0
- package/package/horizon-sp/node_modules/universalify/package.json +34 -0
- package/package/horizon-sp/package-lock.json +150 -0
- package/package/horizon-sp/package.json +20 -0
- package/package.json +134 -3
- package/src/ReportV1.js +55 -0
- package/src/addExternalModule.js +16 -0
- package/src/addUserToGroup.js +78 -0
- package/src/changeAdminStatus.js +79 -0
- package/src/changeArchivedStatus.js +41 -0
- package/src/changeAvt.js +86 -0
- package/src/changeBio.js +65 -0
- package/src/changeBlockedStatus.js +36 -0
- package/src/changeGroupImage.js +106 -0
- package/src/changeNickname.js +45 -0
- package/src/changeThreadColor.js +62 -0
- package/src/changeThreadEmoji.js +42 -0
- package/src/createNewGroup.js +70 -0
- package/src/createPoll.js +60 -0
- package/src/data/getThreadInfo.json +31985 -0
- package/src/deleteMessage.js +45 -0
- package/src/deleteThread.js +43 -0
- package/src/forwardAttachment.js +48 -0
- package/src/getAccessToken.js +33 -0
- package/src/getCurrentUserID.js +7 -0
- package/src/getEmojiUrl.js +27 -0
- package/src/getFriendsList.js +73 -0
- package/src/getMessage.js +80 -0
- package/src/getThreadHistory.js +537 -0
- package/src/getThreadHistoryDeprecated.js +71 -0
- package/src/getThreadInfo.js +193 -0
- package/src/getThreadInfoDeprecated.js +56 -0
- package/src/getThreadList.js +213 -0
- package/src/getThreadListDeprecated.js +46 -0
- package/src/getThreadMain.js +219 -0
- package/src/getThreadPictures.js +59 -0
- package/src/getUserID.js +62 -0
- package/src/getUserInfo.js +66 -0
- package/src/getUserInfoMain.js +65 -0
- package/src/getUserInfoV2.js +36 -0
- package/src/getUserInfoV3.js +63 -0
- package/src/getUserInfoV4.js +55 -0
- package/src/getUserInfoV5.js +61 -0
- package/src/handleFriendRequest.js +46 -0
- package/src/handleMessageRequest.js +49 -0
- package/src/httpGet.js +49 -0
- package/src/httpPost.js +48 -0
- package/src/httpPostFormData.js +41 -0
- package/src/listenMqtt.js +629 -0
- package/src/logout.js +68 -0
- package/src/markAsDelivered.js +48 -0
- package/src/markAsRead.js +70 -0
- package/src/markAsReadAll.js +43 -0
- package/src/markAsSeen.js +51 -0
- package/src/muteThread.js +47 -0
- package/src/removeUserFromGroup.js +49 -0
- package/src/resolvePhotoUrl.js +37 -0
- package/src/searchForThread.js +43 -0
- package/src/sendMessage.js +321 -0
- package/src/sendTypingIndicator.js +80 -0
- package/src/setMessageReaction.js +109 -0
- package/src/setPostReaction.js +102 -0
- package/src/setTitle.js +74 -0
- package/src/threadColors.js +39 -0
- package/src/unfriend.js +43 -0
- package/src/unsendMessage.js +40 -0
- package/test/example-config.json +18 -0
- package/test/test-page.js +140 -0
- package/test/test.js +385 -0
- package/utils.js +1246 -0
@@ -0,0 +1,321 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var utils = require("../utils");
|
4
|
+
var log = require("npmlog");
|
5
|
+
var bluebird = require("bluebird");
|
6
|
+
|
7
|
+
var allowedProperties = {
|
8
|
+
attachment: true,
|
9
|
+
url: true,
|
10
|
+
sticker: true,
|
11
|
+
emoji: true,
|
12
|
+
emojiSize: true,
|
13
|
+
body: true,
|
14
|
+
mentions: true,
|
15
|
+
location: true,
|
16
|
+
};
|
17
|
+
|
18
|
+
module.exports = function (defaultFuncs, api, ctx) {
|
19
|
+
function uploadAttachment(attachments, callback) {
|
20
|
+
var uploads = [];
|
21
|
+
|
22
|
+
// create an array of promises
|
23
|
+
for (var i = 0; i < attachments.length; i++) {
|
24
|
+
if (!utils.isReadableStream(attachments[i])) throw { error: "Attachment should be a readable stream and not " + utils.getType(attachments[i]) + "." };
|
25
|
+
var form = {
|
26
|
+
upload_1024: attachments[i],
|
27
|
+
voice_clip: "true"
|
28
|
+
};
|
29
|
+
|
30
|
+
uploads.push(
|
31
|
+
defaultFuncs
|
32
|
+
.postFormData("https://upload.facebook.com/ajax/mercury/upload.php", ctx.jar, form, {})
|
33
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
34
|
+
.then(function (resData) {
|
35
|
+
if (resData.error) throw resData;
|
36
|
+
// We have to return the data unformatted unless we want to change it
|
37
|
+
// back in sendMessage.
|
38
|
+
return resData.payload.metadata[0];
|
39
|
+
})
|
40
|
+
);
|
41
|
+
}
|
42
|
+
|
43
|
+
// resolve all promises
|
44
|
+
bluebird
|
45
|
+
.all(uploads)
|
46
|
+
.then(resData => callback(null, resData)
|
47
|
+
)
|
48
|
+
.catch(function (err) {
|
49
|
+
log.error("uploadAttachment", err);
|
50
|
+
return callback(err);
|
51
|
+
});
|
52
|
+
}
|
53
|
+
|
54
|
+
function getUrl(url, callback) {
|
55
|
+
var form = {
|
56
|
+
image_height: 960,
|
57
|
+
image_width: 960,
|
58
|
+
uri: url
|
59
|
+
};
|
60
|
+
|
61
|
+
defaultFuncs
|
62
|
+
.post("https://www.facebook.com/message_share_attachment/fromURI/", ctx.jar, form)
|
63
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
64
|
+
.then(function (resData) {
|
65
|
+
if (resData.error) return callback(resData);
|
66
|
+
if (!resData.payload) return callback({ error: "Invalid url" });
|
67
|
+
callback(null, resData.payload.share_data.share_params);
|
68
|
+
})
|
69
|
+
.catch(function (err) {
|
70
|
+
log.error("getUrl", err);
|
71
|
+
return callback(err);
|
72
|
+
});
|
73
|
+
}
|
74
|
+
|
75
|
+
function sendContent(form, threadID, isSingleUser, messageAndOTID, callback) {
|
76
|
+
// There are three cases here:
|
77
|
+
// 1. threadID is of type array, where we're starting a new group chat with users
|
78
|
+
// specified in the array.
|
79
|
+
// 2. User is sending a message to a specific user.
|
80
|
+
// 3. No additional form params and the message goes to an existing group chat.
|
81
|
+
if (utils.getType(threadID) === "Array") {
|
82
|
+
for (var i = 0; i < threadID.length; i++) form["specific_to_list[" + i + "]"] = "fbid:" + threadID[i];
|
83
|
+
form["specific_to_list[" + threadID.length + "]"] = "fbid:" + ctx.userID;
|
84
|
+
form["client_thread_id"] = "root:" + messageAndOTID;
|
85
|
+
log.info("sendMessage", "Sending message to multiple users: " + threadID);
|
86
|
+
}
|
87
|
+
else {
|
88
|
+
// This means that threadID is the id of a user, and the chat
|
89
|
+
// is a single person chat
|
90
|
+
if (isSingleUser) {
|
91
|
+
form["specific_to_list[0]"] = "fbid:" + threadID;
|
92
|
+
form["specific_to_list[1]"] = "fbid:" + ctx.userID;
|
93
|
+
form["other_user_fbid"] = threadID;
|
94
|
+
}
|
95
|
+
else form["thread_fbid"] = threadID;
|
96
|
+
}
|
97
|
+
|
98
|
+
if (ctx.globalOptions.pageID) {
|
99
|
+
form["author"] = "fbid:" + ctx.globalOptions.pageID;
|
100
|
+
form["specific_to_list[1]"] = "fbid:" + ctx.globalOptions.pageID;
|
101
|
+
form["creator_info[creatorID]"] = ctx.userID;
|
102
|
+
form["creator_info[creatorType]"] = "direct_admin";
|
103
|
+
form["creator_info[labelType]"] = "sent_message";
|
104
|
+
form["creator_info[pageID]"] = ctx.globalOptions.pageID;
|
105
|
+
form["request_user_id"] = ctx.globalOptions.pageID;
|
106
|
+
form["creator_info[profileURI]"] = "https://www.facebook.com/profile.php?id=" + ctx.userID;
|
107
|
+
}
|
108
|
+
|
109
|
+
defaultFuncs
|
110
|
+
.post("https://www.facebook.com/messaging/send/", ctx.jar, form)
|
111
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
112
|
+
.then(function (resData) {
|
113
|
+
if (!resData) return callback({ error: "Send message failed." });
|
114
|
+
if (resData.error) {
|
115
|
+
if (resData.error === 1545012) log.warn("sendMessage", "Got error 1545012. This might mean that you're not part of the conversation " + threadID);
|
116
|
+
return callback(resData);
|
117
|
+
}
|
118
|
+
|
119
|
+
var messageInfo = resData.payload.actions.reduce(function (p, v) {
|
120
|
+
return (
|
121
|
+
{
|
122
|
+
threadID: v.thread_fbid,
|
123
|
+
messageID: v.message_id,
|
124
|
+
timestamp: v.timestamp
|
125
|
+
} || p
|
126
|
+
);
|
127
|
+
}, null);
|
128
|
+
|
129
|
+
return callback(null, messageInfo);
|
130
|
+
})
|
131
|
+
.catch(function (err) {
|
132
|
+
log.error("sendMessage", err);
|
133
|
+
if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
|
134
|
+
return callback(err);
|
135
|
+
});
|
136
|
+
}
|
137
|
+
|
138
|
+
function send(form, threadID, messageAndOTID, callback, isGroup) {
|
139
|
+
// We're doing a query to this to check if the given id is the id of
|
140
|
+
// a user or of a group chat. The form will be different depending
|
141
|
+
// on that.
|
142
|
+
if (utils.getType(threadID) === "Array") sendContent(form, threadID, false, messageAndOTID, callback);
|
143
|
+
else {
|
144
|
+
if (utils.getType(isGroup) != "Boolean") sendContent(form, threadID, threadID.length === 15, messageAndOTID, callback);
|
145
|
+
else sendContent(form, threadID, !isGroup, messageAndOTID, callback);
|
146
|
+
}
|
147
|
+
}
|
148
|
+
|
149
|
+
function handleUrl(msg, form, callback, cb) {
|
150
|
+
if (msg.url) {
|
151
|
+
form["shareable_attachment[share_type]"] = "100";
|
152
|
+
getUrl(msg.url, function (err, params) {
|
153
|
+
if (err) return callback(err);
|
154
|
+
form["shareable_attachment[share_params]"] = params;
|
155
|
+
cb();
|
156
|
+
});
|
157
|
+
}
|
158
|
+
else cb();
|
159
|
+
}
|
160
|
+
|
161
|
+
function handleLocation(msg, form, callback, cb) {
|
162
|
+
if (msg.location) {
|
163
|
+
if (msg.location.latitude == null || msg.location.longitude == null) return callback({ error: "location property needs both latitude and longitude" });
|
164
|
+
form["location_attachment[coordinates][latitude]"] = msg.location.latitude;
|
165
|
+
form["location_attachment[coordinates][longitude]"] = msg.location.longitude;
|
166
|
+
form["location_attachment[is_current_location]"] = !!msg.location.current;
|
167
|
+
}
|
168
|
+
cb();
|
169
|
+
}
|
170
|
+
|
171
|
+
function handleSticker(msg, form, callback, cb) {
|
172
|
+
if (msg.sticker) form["sticker_id"] = msg.sticker;
|
173
|
+
cb();
|
174
|
+
}
|
175
|
+
|
176
|
+
function handleEmoji(msg, form, callback, cb) {
|
177
|
+
if (msg.emojiSize != null && msg.emoji == null) return callback({ error: "emoji property is empty" });
|
178
|
+
if (msg.emoji) {
|
179
|
+
if (msg.emojiSize == null) msg.emojiSize = "medium";
|
180
|
+
if (msg.emojiSize != "small" && msg.emojiSize != "medium" && msg.emojiSize != "large") return callback({ error: "emojiSize property is invalid" });
|
181
|
+
if (form["body"] != null && form["body"] != "") return callback({ error: "body is not empty" });
|
182
|
+
form["body"] = msg.emoji;
|
183
|
+
form["tags[0]"] = "hot_emoji_size:" + msg.emojiSize;
|
184
|
+
}
|
185
|
+
cb();
|
186
|
+
}
|
187
|
+
|
188
|
+
function handleAttachment(msg, form, callback, cb) {
|
189
|
+
if (msg.attachment) {
|
190
|
+
form["image_ids"] = [];
|
191
|
+
form["gif_ids"] = [];
|
192
|
+
form["file_ids"] = [];
|
193
|
+
form["video_ids"] = [];
|
194
|
+
form["audio_ids"] = [];
|
195
|
+
|
196
|
+
if (utils.getType(msg.attachment) !== "Array") msg.attachment = [msg.attachment];
|
197
|
+
|
198
|
+
uploadAttachment(msg.attachment, function (err, files) {
|
199
|
+
if (err) return callback(err);
|
200
|
+
files.forEach(function (file) {
|
201
|
+
var key = Object.keys(file);
|
202
|
+
var type = key[0]; // image_id, file_id, etc
|
203
|
+
form["" + type + "s"].push(file[type]); // push the id
|
204
|
+
});
|
205
|
+
cb();
|
206
|
+
});
|
207
|
+
}
|
208
|
+
else cb();
|
209
|
+
}
|
210
|
+
|
211
|
+
function handleMention(msg, form, callback, cb) {
|
212
|
+
if (msg.mentions) {
|
213
|
+
for (let i = 0; i < msg.mentions.length; i++) {
|
214
|
+
const mention = msg.mentions[i];
|
215
|
+
const tag = mention.tag;
|
216
|
+
if (typeof tag !== "string") return callback({ error: "Mention tags must be strings." });
|
217
|
+
const offset = msg.body.indexOf(tag, mention.fromIndex || 0);
|
218
|
+
if (offset < 0) log.warn("handleMention", 'Mention for "' + tag + '" not found in message string.');
|
219
|
+
if (mention.id == null) log.warn("handleMention", "Mention id should be non-null.");
|
220
|
+
|
221
|
+
const id = mention.id || 0;
|
222
|
+
const emptyChar = '\u200E';
|
223
|
+
form["body"] = emptyChar + msg.body;
|
224
|
+
form["profile_xmd[" + i + "][offset]"] = offset + 1;
|
225
|
+
form["profile_xmd[" + i + "][length]"] = tag.length;
|
226
|
+
form["profile_xmd[" + i + "][id]"] = id;
|
227
|
+
form["profile_xmd[" + i + "][type]"] = "p";
|
228
|
+
}
|
229
|
+
}
|
230
|
+
cb();
|
231
|
+
}
|
232
|
+
|
233
|
+
return function sendMessage(msg, threadID, callback, replyToMessage, isGroup) {
|
234
|
+
typeof isGroup == "undefined" ? isGroup = null : "";
|
235
|
+
if (!callback && (utils.getType(threadID) === "Function" || utils.getType(threadID) === "AsyncFunction")) return threadID({ error: "Pass a threadID as a second argument." });
|
236
|
+
if (!replyToMessage && utils.getType(callback) === "String") {
|
237
|
+
replyToMessage = callback;
|
238
|
+
callback = function () { };
|
239
|
+
}
|
240
|
+
|
241
|
+
var resolveFunc = function () { };
|
242
|
+
var rejectFunc = function () { };
|
243
|
+
var returnPromise = new Promise(function (resolve, reject) {
|
244
|
+
resolveFunc = resolve;
|
245
|
+
rejectFunc = reject;
|
246
|
+
});
|
247
|
+
|
248
|
+
if (!callback) {
|
249
|
+
callback = function (err, data) {
|
250
|
+
if (err) return rejectFunc(err);
|
251
|
+
resolveFunc(data);
|
252
|
+
};
|
253
|
+
}
|
254
|
+
|
255
|
+
var msgType = utils.getType(msg);
|
256
|
+
var threadIDType = utils.getType(threadID);
|
257
|
+
var messageIDType = utils.getType(replyToMessage);
|
258
|
+
|
259
|
+
if (msgType !== "String" && msgType !== "Object") return callback({ error: "Message should be of type string or object and not " + msgType + "." });
|
260
|
+
|
261
|
+
// Changing this to accomodate an array of users
|
262
|
+
if (threadIDType !== "Array" && threadIDType !== "Number" && threadIDType !== "String") return callback({ error: "ThreadID should be of type number, string, or array and not " + threadIDType + "." });
|
263
|
+
|
264
|
+
if (replyToMessage && messageIDType !== 'String') return callback({ error: "MessageID should be of type string and not " + threadIDType + "." });
|
265
|
+
|
266
|
+
if (msgType === "String") msg = { body: msg };
|
267
|
+
var disallowedProperties = Object.keys(msg).filter(prop => !allowedProperties[prop]);
|
268
|
+
if (disallowedProperties.length > 0) return callback({ error: "Dissallowed props: `" + disallowedProperties.join(", ") + "`" });
|
269
|
+
|
270
|
+
var messageAndOTID = utils.generateOfflineThreadingID();
|
271
|
+
|
272
|
+
var form = {
|
273
|
+
client: "mercury",
|
274
|
+
action_type: "ma-type:user-generated-message",
|
275
|
+
author: "fbid:" + ctx.userID,
|
276
|
+
timestamp: Date.now(),
|
277
|
+
timestamp_absolute: "Today",
|
278
|
+
timestamp_relative: utils.generateTimestampRelative(),
|
279
|
+
timestamp_time_passed: "0",
|
280
|
+
is_unread: false,
|
281
|
+
is_cleared: false,
|
282
|
+
is_forward: false,
|
283
|
+
is_filtered_content: false,
|
284
|
+
is_filtered_content_bh: false,
|
285
|
+
is_filtered_content_account: false,
|
286
|
+
is_filtered_content_quasar: false,
|
287
|
+
is_filtered_content_invalid_app: false,
|
288
|
+
is_spoof_warning: false,
|
289
|
+
source: "source:chat:web",
|
290
|
+
"source_tags[0]": "source:chat",
|
291
|
+
body: msg.body ? msg.body.toString() : "",
|
292
|
+
html_body: false,
|
293
|
+
ui_push_phase: "V3",
|
294
|
+
status: "0",
|
295
|
+
offline_threading_id: messageAndOTID,
|
296
|
+
message_id: messageAndOTID,
|
297
|
+
threading_id: utils.generateThreadingID(ctx.clientID),
|
298
|
+
"ephemeral_ttl_mode:": "0",
|
299
|
+
manual_retry_cnt: "0",
|
300
|
+
has_attachment: !!(msg.attachment || msg.url || msg.sticker),
|
301
|
+
signatureID: utils.getSignatureID(),
|
302
|
+
replied_to_message_id: replyToMessage
|
303
|
+
};
|
304
|
+
|
305
|
+
handleLocation(msg, form, callback, () =>
|
306
|
+
handleSticker(msg, form, callback, () =>
|
307
|
+
handleAttachment(msg, form, callback, () =>
|
308
|
+
handleUrl(msg, form, callback, () =>
|
309
|
+
handleEmoji(msg, form, callback, () =>
|
310
|
+
handleMention(msg, form, callback, () =>
|
311
|
+
send(form, threadID, messageAndOTID, callback, isGroup)
|
312
|
+
)
|
313
|
+
)
|
314
|
+
)
|
315
|
+
)
|
316
|
+
)
|
317
|
+
);
|
318
|
+
|
319
|
+
return returnPromise;
|
320
|
+
};
|
321
|
+
};
|
@@ -0,0 +1,80 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var utils = require("../utils");
|
4
|
+
var log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function (defaultFuncs, api, ctx) {
|
7
|
+
function makeTypingIndicator(typ, threadID, callback, isGroup) {
|
8
|
+
var form = {
|
9
|
+
typ: +typ,
|
10
|
+
to: "",
|
11
|
+
source: "mercury-chat",
|
12
|
+
thread: threadID
|
13
|
+
};
|
14
|
+
|
15
|
+
// Check if thread is a single person chat or a group chat
|
16
|
+
// More info on this is in api.sendMessage
|
17
|
+
if (utils.getType(isGroup) == "Boolean") {
|
18
|
+
if (!isGroup) {
|
19
|
+
form.to = threadID;
|
20
|
+
}
|
21
|
+
defaultFuncs
|
22
|
+
.post("https://www.facebook.com/ajax/messaging/typ.php", ctx.jar, form)
|
23
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
24
|
+
.then(function (resData) {
|
25
|
+
if (resData.error) throw resData;
|
26
|
+
return callback();
|
27
|
+
})
|
28
|
+
.catch(function (err) {
|
29
|
+
log.error("sendTypingIndicator", err);
|
30
|
+
if (utils.getType(err) == "Object" && err.error === "Not logged in") {
|
31
|
+
ctx.loggedIn = false;
|
32
|
+
}
|
33
|
+
return callback(err);
|
34
|
+
});
|
35
|
+
}
|
36
|
+
else {
|
37
|
+
api.getUserInfo(threadID, function (err, res) {
|
38
|
+
if (err) return callback(err);
|
39
|
+
// If id is single person chat
|
40
|
+
if (Object.keys(res).length > 0) form.to = threadID;
|
41
|
+
defaultFuncs
|
42
|
+
.post("https://www.facebook.com/ajax/messaging/typ.php", ctx.jar, form)
|
43
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
44
|
+
.then(function (resData) {
|
45
|
+
if (resData.error) throw resData;
|
46
|
+
return callback();
|
47
|
+
})
|
48
|
+
.catch(function (err) {
|
49
|
+
log.error("sendTypingIndicator", err);
|
50
|
+
if (utils.getType(err) == "Object" && err.error === "Not logged in.") ctx.loggedIn = false;
|
51
|
+
return callback(err);
|
52
|
+
});
|
53
|
+
});
|
54
|
+
}
|
55
|
+
}
|
56
|
+
|
57
|
+
return function sendTypingIndicator(threadID, callback, isGroup) {
|
58
|
+
if (
|
59
|
+
utils.getType(callback) !== "Function" &&
|
60
|
+
utils.getType(callback) !== "AsyncFunction"
|
61
|
+
) {
|
62
|
+
if (callback) log.warn("sendTypingIndicator", "callback is not a function - ignoring.");
|
63
|
+
callback = () => { };
|
64
|
+
}
|
65
|
+
|
66
|
+
makeTypingIndicator(true, threadID, callback, isGroup);
|
67
|
+
|
68
|
+
return function end(cb) {
|
69
|
+
if (
|
70
|
+
utils.getType(cb) !== "Function" &&
|
71
|
+
utils.getType(cb) !== "AsyncFunction"
|
72
|
+
) {
|
73
|
+
if (cb) log.warn("sendTypingIndicator", "callback is not a function - ignoring.");
|
74
|
+
cb = () => { };
|
75
|
+
}
|
76
|
+
|
77
|
+
makeTypingIndicator(false, threadID, cb, isGroup);
|
78
|
+
};
|
79
|
+
};
|
80
|
+
};
|
@@ -0,0 +1,109 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var utils = require("../utils");
|
4
|
+
var log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function (defaultFuncs, api, ctx) {
|
7
|
+
return function setMessageReaction(reaction, messageID, callback, forceCustomReaction) {
|
8
|
+
var resolveFunc = function () { };
|
9
|
+
var rejectFunc = function () { };
|
10
|
+
var returnPromise = new Promise(function (resolve, reject) {
|
11
|
+
resolveFunc = resolve;
|
12
|
+
rejectFunc = reject;
|
13
|
+
});
|
14
|
+
|
15
|
+
if (!callback) {
|
16
|
+
callback = function (err, data) {
|
17
|
+
if (err) return rejectFunc(err);
|
18
|
+
resolveFunc(data);
|
19
|
+
};
|
20
|
+
}
|
21
|
+
|
22
|
+
switch (reaction) {
|
23
|
+
case "\uD83D\uDE0D": //:heart_eyes:
|
24
|
+
case "\uD83D\uDE06": //:laughing:
|
25
|
+
case "\uD83D\uDE2E": //:open_mouth:
|
26
|
+
case "\uD83D\uDE22": //:cry:
|
27
|
+
case "\uD83D\uDE20": //:angry:
|
28
|
+
case "\uD83D\uDC4D": //:thumbsup:
|
29
|
+
case "\uD83D\uDC4E": //:thumbsdown:
|
30
|
+
case "\u2764": //:heart:
|
31
|
+
case "\uD83D\uDC97": //:glowingheart:
|
32
|
+
case "":
|
33
|
+
//valid
|
34
|
+
break;
|
35
|
+
case ":heart_eyes:":
|
36
|
+
case ":love:":
|
37
|
+
reaction = "\uD83D\uDE0D";
|
38
|
+
break;
|
39
|
+
case ":laughing:":
|
40
|
+
case ":haha:":
|
41
|
+
reaction = "\uD83D\uDE06";
|
42
|
+
break;
|
43
|
+
case ":open_mouth:":
|
44
|
+
case ":wow:":
|
45
|
+
reaction = "\uD83D\uDE2E";
|
46
|
+
break;
|
47
|
+
case ":cry:":
|
48
|
+
case ":sad:":
|
49
|
+
reaction = "\uD83D\uDE22";
|
50
|
+
break;
|
51
|
+
case ":angry:":
|
52
|
+
reaction = "\uD83D\uDE20";
|
53
|
+
break;
|
54
|
+
case ":thumbsup:":
|
55
|
+
case ":like:":
|
56
|
+
reaction = "\uD83D\uDC4D";
|
57
|
+
break;
|
58
|
+
case ":thumbsdown:":
|
59
|
+
case ":dislike:":
|
60
|
+
reaction = "\uD83D\uDC4E";
|
61
|
+
break;
|
62
|
+
case ":heart:":
|
63
|
+
reaction = "\u2764";
|
64
|
+
break;
|
65
|
+
case ":glowingheart:":
|
66
|
+
reaction = "\uD83D\uDC97";
|
67
|
+
break;
|
68
|
+
default:
|
69
|
+
if (forceCustomReaction) break;
|
70
|
+
return callback({ error: "Reaction is not a valid emoji." });
|
71
|
+
}
|
72
|
+
|
73
|
+
var variables = {
|
74
|
+
data: {
|
75
|
+
client_mutation_id: ctx.clientMutationId++,
|
76
|
+
actor_id: ctx.userID,
|
77
|
+
action: reaction == "" ? "REMOVE_REACTION" : "ADD_REACTION",
|
78
|
+
message_id: messageID,
|
79
|
+
reaction: reaction
|
80
|
+
}
|
81
|
+
};
|
82
|
+
|
83
|
+
var qs = {
|
84
|
+
doc_id: "1491398900900362",
|
85
|
+
variables: JSON.stringify(variables),
|
86
|
+
dpr: 1
|
87
|
+
};
|
88
|
+
|
89
|
+
defaultFuncs
|
90
|
+
.postFormData(
|
91
|
+
"https://www.facebook.com/webgraphql/mutation/",
|
92
|
+
ctx.jar,
|
93
|
+
{},
|
94
|
+
qs
|
95
|
+
)
|
96
|
+
.then(utils.parseAndCheckLogin(ctx.jar, defaultFuncs))
|
97
|
+
.then(function (resData) {
|
98
|
+
if (!resData) throw { error: "setReaction returned empty object." };
|
99
|
+
if (resData.error) throw resData;
|
100
|
+
callback(null);
|
101
|
+
})
|
102
|
+
.catch(function (err) {
|
103
|
+
log.error("setReaction", err);
|
104
|
+
return callback(err);
|
105
|
+
});
|
106
|
+
|
107
|
+
return returnPromise;
|
108
|
+
};
|
109
|
+
};
|
@@ -0,0 +1,102 @@
|
|
1
|
+
/**
|
2
|
+
* @fix by NTKhang
|
3
|
+
* update as Thursday, 10 February 2022
|
4
|
+
* do not remove the author name to get more updates
|
5
|
+
*/
|
6
|
+
|
7
|
+
"use strict";
|
8
|
+
|
9
|
+
var utils = require("../utils");
|
10
|
+
var log = require("npmlog");
|
11
|
+
|
12
|
+
function formatData(resData) {
|
13
|
+
return {
|
14
|
+
viewer_feedback_reaction_info: resData.feedback_react.feedback.viewer_feedback_reaction_info,
|
15
|
+
supported_reactions: resData.feedback_react.feedback.supported_reactions,
|
16
|
+
top_reactions: resData.feedback_react.feedback.top_reactions.edges,
|
17
|
+
reaction_count: resData.feedback_react.feedback.reaction_count
|
18
|
+
};
|
19
|
+
}
|
20
|
+
|
21
|
+
module.exports = function(defaultFuncs, api, ctx) {
|
22
|
+
return function setPostReaction(postID, type, callback) {
|
23
|
+
var resolveFunc = function(){};
|
24
|
+
var rejectFunc = function(){};
|
25
|
+
var returnPromise = new Promise(function (resolve, reject) {
|
26
|
+
resolveFunc = resolve;
|
27
|
+
rejectFunc = reject;
|
28
|
+
});
|
29
|
+
|
30
|
+
if (!callback) {
|
31
|
+
if (utils.getType(type) === "Function" || utils.getType(type) === "AsyncFunction") {
|
32
|
+
callback = type;
|
33
|
+
type = 0;
|
34
|
+
}
|
35
|
+
else {
|
36
|
+
callback = function (err, data) {
|
37
|
+
if (err) {
|
38
|
+
return rejectFunc(err);
|
39
|
+
}
|
40
|
+
resolveFunc(data);
|
41
|
+
};
|
42
|
+
}
|
43
|
+
}
|
44
|
+
|
45
|
+
var map = {
|
46
|
+
unlike: 0,
|
47
|
+
like: 1,
|
48
|
+
heart: 2,
|
49
|
+
love: 16,
|
50
|
+
haha: 4,
|
51
|
+
wow: 3,
|
52
|
+
sad: 7,
|
53
|
+
angry: 8
|
54
|
+
};
|
55
|
+
|
56
|
+
if (utils.getType(type) !== "Number" && utils.getType(type) === "String") {
|
57
|
+
type = map[type.toLowerCase()];
|
58
|
+
}
|
59
|
+
else {
|
60
|
+
throw {
|
61
|
+
error: "setPostReaction: Invalid reaction type"
|
62
|
+
};
|
63
|
+
}
|
64
|
+
|
65
|
+
var form = {
|
66
|
+
av: ctx.userID,
|
67
|
+
fb_api_caller_class: "RelayModern",
|
68
|
+
fb_api_req_friendly_name: "CometUFIFeedbackReactMutation",
|
69
|
+
doc_id: "4769042373179384",
|
70
|
+
variables: JSON.stringify({
|
71
|
+
input: {
|
72
|
+
actor_id: ctx.userID,
|
73
|
+
feedback_id: (new Buffer("feedback:" + postID)).toString("base64"),
|
74
|
+
feedback_reaction: type,
|
75
|
+
feedback_source: "OBJECT",
|
76
|
+
is_tracking_encrypted: true,
|
77
|
+
tracking: [],
|
78
|
+
session_id: "f7dd50dd-db6e-4598-8cd9-561d5002b423",
|
79
|
+
client_mutation_id: Math.round(Math.random() * 19).toString()
|
80
|
+
},
|
81
|
+
useDefaultActor: false,
|
82
|
+
scale: 3
|
83
|
+
})
|
84
|
+
};
|
85
|
+
|
86
|
+
defaultFuncs
|
87
|
+
.post("https://www.facebook.com/api/graphql/", ctx.jar, form)
|
88
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
89
|
+
.then(function(resData) {
|
90
|
+
if (resData.errors) {
|
91
|
+
throw resData;
|
92
|
+
}
|
93
|
+
return callback(null, formatData(resData.data));
|
94
|
+
})
|
95
|
+
.catch(function(err) {
|
96
|
+
log.error("setPostReaction", err);
|
97
|
+
return callback(err);
|
98
|
+
});
|
99
|
+
|
100
|
+
return returnPromise;
|
101
|
+
};
|
102
|
+
};
|
package/src/setTitle.js
ADDED
@@ -0,0 +1,74 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var utils = require("../utils");
|
4
|
+
var log = require("npmlog");
|
5
|
+
|
6
|
+
module.exports = function (defaultFuncs, api, ctx) {
|
7
|
+
return function setTitle(newTitle, threadID, callback) {
|
8
|
+
if (
|
9
|
+
!callback &&
|
10
|
+
(utils.getType(threadID) === "Function" ||
|
11
|
+
utils.getType(threadID) === "AsyncFunction")
|
12
|
+
) throw { error: "please pass a threadID as a second argument." };
|
13
|
+
|
14
|
+
|
15
|
+
var resolveFunc = function () { };
|
16
|
+
var rejectFunc = function () { };
|
17
|
+
var returnPromise = new Promise(function (resolve, reject) {
|
18
|
+
resolveFunc = resolve;
|
19
|
+
rejectFunc = reject;
|
20
|
+
});
|
21
|
+
|
22
|
+
if (!callback) {
|
23
|
+
callback = function (err, data) {
|
24
|
+
if (err) return rejectFunc(err);
|
25
|
+
resolveFunc(data);
|
26
|
+
};
|
27
|
+
}
|
28
|
+
|
29
|
+
var messageAndOTID = utils.generateOfflineThreadingID();
|
30
|
+
var form = {
|
31
|
+
client: "mercury",
|
32
|
+
action_type: "ma-type:log-message",
|
33
|
+
author: "fbid:" + ctx.userID,
|
34
|
+
author_email: "",
|
35
|
+
coordinates: "",
|
36
|
+
timestamp: Date.now(),
|
37
|
+
timestamp_absolute: "Today",
|
38
|
+
timestamp_relative: utils.generateTimestampRelative(),
|
39
|
+
timestamp_time_passed: "0",
|
40
|
+
is_unread: false,
|
41
|
+
is_cleared: false,
|
42
|
+
is_forward: false,
|
43
|
+
is_filtered_content: false,
|
44
|
+
is_spoof_warning: false,
|
45
|
+
source: "source:chat:web",
|
46
|
+
"source_tags[0]": "source:chat",
|
47
|
+
status: "0",
|
48
|
+
offline_threading_id: messageAndOTID,
|
49
|
+
message_id: messageAndOTID,
|
50
|
+
threading_id: utils.generateThreadingID(ctx.clientID),
|
51
|
+
manual_retry_cnt: "0",
|
52
|
+
thread_fbid: threadID,
|
53
|
+
thread_name: newTitle,
|
54
|
+
thread_id: threadID,
|
55
|
+
log_message_type: "log:thread-name"
|
56
|
+
};
|
57
|
+
|
58
|
+
defaultFuncs
|
59
|
+
.post("https://www.facebook.com/messaging/set_thread_name/", ctx.jar, form)
|
60
|
+
.then(utils.parseAndCheckLogin(ctx, defaultFuncs))
|
61
|
+
.then(function (resData) {
|
62
|
+
if (resData.error && resData.error === 1545012) throw { error: "Cannot change chat title: Not member of chat." };
|
63
|
+
if (resData.error && resData.error === 1545003) throw { error: "Cannot set title of single-user chat." };
|
64
|
+
if (resData.error) throw resData;
|
65
|
+
return callback();
|
66
|
+
})
|
67
|
+
.catch(function (err) {
|
68
|
+
log.error("setTitle", err);
|
69
|
+
return callback(err);
|
70
|
+
});
|
71
|
+
|
72
|
+
return returnPromise;
|
73
|
+
};
|
74
|
+
};
|