frida 16.2.1 → 16.2.2
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/BSDmakefile +6 -0
- package/Makefile +16 -0
- package/README.md +14 -11
- package/configure +18 -0
- package/configure.bat +22 -0
- package/dist/native.js +0 -8
- package/lib/application.ts +98 -0
- package/lib/authentication.ts +3 -0
- package/lib/build.py +50 -0
- package/lib/bus.ts +30 -0
- package/lib/cancellable.ts +33 -0
- package/lib/child.ts +15 -0
- package/lib/crash.ts +11 -0
- package/lib/device.ts +329 -0
- package/lib/device_manager.ts +69 -0
- package/lib/endpoint_parameters.ts +56 -0
- package/lib/icon.ts +15 -0
- package/lib/index.ts +311 -0
- package/lib/iostream.ts +78 -0
- package/lib/meson.build +53 -0
- package/lib/native.ts +9 -0
- package/lib/portal_membership.ts +10 -0
- package/lib/portal_service.ts +105 -0
- package/lib/process.ts +57 -0
- package/lib/relay.ts +44 -0
- package/lib/script.ts +352 -0
- package/lib/session.ts +113 -0
- package/lib/signals.ts +45 -0
- package/lib/socket_address.ts +35 -0
- package/lib/spawn.ts +4 -0
- package/lib/system_parameters.ts +78 -0
- package/make.bat +23 -0
- package/meson.build +160 -0
- package/meson.options +11 -0
- package/package.json +27 -6
- package/releng/deps.py +1133 -0
- package/releng/deps.toml +391 -0
- package/releng/devkit-assets/frida-core-example-unix.c +188 -0
- package/releng/devkit-assets/frida-core-example-windows.c +197 -0
- package/releng/devkit-assets/frida-core-example.sln +28 -0
- package/releng/devkit-assets/frida-core-example.vcxproj +157 -0
- package/releng/devkit-assets/frida-core-example.vcxproj.filters +27 -0
- package/releng/devkit-assets/frida-gum-example-unix.c +122 -0
- package/releng/devkit-assets/frida-gum-example-windows.c +132 -0
- package/releng/devkit-assets/frida-gum-example.sln +28 -0
- package/releng/devkit-assets/frida-gum-example.vcxproj +157 -0
- package/releng/devkit-assets/frida-gum-example.vcxproj.filters +27 -0
- package/releng/devkit-assets/frida-gumjs-example-unix.c +84 -0
- package/releng/devkit-assets/frida-gumjs-example-windows.c +91 -0
- package/releng/devkit-assets/frida-gumjs-example.sln +28 -0
- package/releng/devkit-assets/frida-gumjs-example.vcxproj +157 -0
- package/releng/devkit-assets/frida-gumjs-example.vcxproj.filters +27 -0
- package/releng/devkit.py +535 -0
- package/releng/env.py +420 -0
- package/releng/env_android.py +150 -0
- package/releng/env_apple.py +176 -0
- package/releng/env_generic.py +373 -0
- package/releng/frida_version.py +69 -0
- package/releng/machine_file.py +44 -0
- package/releng/machine_spec.py +290 -0
- package/releng/meson/meson.py +27 -0
- package/releng/meson/mesonbuild/__init__.py +0 -0
- package/releng/meson/mesonbuild/_pathlib.py +63 -0
- package/releng/meson/mesonbuild/_typing.py +69 -0
- package/releng/meson/mesonbuild/arglist.py +321 -0
- package/releng/meson/mesonbuild/ast/__init__.py +23 -0
- package/releng/meson/mesonbuild/ast/interpreter.py +441 -0
- package/releng/meson/mesonbuild/ast/introspection.py +374 -0
- package/releng/meson/mesonbuild/ast/postprocess.py +109 -0
- package/releng/meson/mesonbuild/ast/printer.py +620 -0
- package/releng/meson/mesonbuild/ast/visitor.py +161 -0
- package/releng/meson/mesonbuild/backend/__init__.py +0 -0
- package/releng/meson/mesonbuild/backend/backends.py +2047 -0
- package/releng/meson/mesonbuild/backend/ninjabackend.py +3808 -0
- package/releng/meson/mesonbuild/backend/nonebackend.py +26 -0
- package/releng/meson/mesonbuild/backend/vs2010backend.py +2078 -0
- package/releng/meson/mesonbuild/backend/vs2012backend.py +35 -0
- package/releng/meson/mesonbuild/backend/vs2013backend.py +34 -0
- package/releng/meson/mesonbuild/backend/vs2015backend.py +35 -0
- package/releng/meson/mesonbuild/backend/vs2017backend.py +59 -0
- package/releng/meson/mesonbuild/backend/vs2019backend.py +54 -0
- package/releng/meson/mesonbuild/backend/vs2022backend.py +54 -0
- package/releng/meson/mesonbuild/backend/xcodebackend.py +1781 -0
- package/releng/meson/mesonbuild/build.py +3249 -0
- package/releng/meson/mesonbuild/cargo/__init__.py +5 -0
- package/releng/meson/mesonbuild/cargo/builder.py +238 -0
- package/releng/meson/mesonbuild/cargo/cfg.py +274 -0
- package/releng/meson/mesonbuild/cargo/interpreter.py +733 -0
- package/releng/meson/mesonbuild/cargo/manifest.py +227 -0
- package/releng/meson/mesonbuild/cargo/version.py +95 -0
- package/releng/meson/mesonbuild/cmake/__init__.py +28 -0
- package/releng/meson/mesonbuild/cmake/common.py +331 -0
- package/releng/meson/mesonbuild/cmake/data/__init__.py +0 -0
- package/releng/meson/mesonbuild/cmake/data/preload.cmake +82 -0
- package/releng/meson/mesonbuild/cmake/executor.py +241 -0
- package/releng/meson/mesonbuild/cmake/fileapi.py +324 -0
- package/releng/meson/mesonbuild/cmake/generator.py +186 -0
- package/releng/meson/mesonbuild/cmake/interpreter.py +1267 -0
- package/releng/meson/mesonbuild/cmake/toolchain.py +248 -0
- package/releng/meson/mesonbuild/cmake/traceparser.py +814 -0
- package/releng/meson/mesonbuild/cmake/tracetargets.py +161 -0
- package/releng/meson/mesonbuild/compilers/__init__.py +86 -0
- package/releng/meson/mesonbuild/compilers/asm.py +307 -0
- package/releng/meson/mesonbuild/compilers/c.py +788 -0
- package/releng/meson/mesonbuild/compilers/c_function_attributes.py +143 -0
- package/releng/meson/mesonbuild/compilers/compilers.py +1388 -0
- package/releng/meson/mesonbuild/compilers/cpp.py +1035 -0
- package/releng/meson/mesonbuild/compilers/cs.py +136 -0
- package/releng/meson/mesonbuild/compilers/cuda.py +806 -0
- package/releng/meson/mesonbuild/compilers/cython.py +91 -0
- package/releng/meson/mesonbuild/compilers/d.py +861 -0
- package/releng/meson/mesonbuild/compilers/detect.py +1396 -0
- package/releng/meson/mesonbuild/compilers/fortran.py +523 -0
- package/releng/meson/mesonbuild/compilers/java.py +113 -0
- package/releng/meson/mesonbuild/compilers/mixins/__init__.py +0 -0
- package/releng/meson/mesonbuild/compilers/mixins/arm.py +167 -0
- package/releng/meson/mesonbuild/compilers/mixins/ccrx.py +113 -0
- package/releng/meson/mesonbuild/compilers/mixins/clang.py +170 -0
- package/releng/meson/mesonbuild/compilers/mixins/clike.py +1330 -0
- package/releng/meson/mesonbuild/compilers/mixins/compcert.py +117 -0
- package/releng/meson/mesonbuild/compilers/mixins/elbrus.py +93 -0
- package/releng/meson/mesonbuild/compilers/mixins/emscripten.py +89 -0
- package/releng/meson/mesonbuild/compilers/mixins/gnu.py +629 -0
- package/releng/meson/mesonbuild/compilers/mixins/intel.py +167 -0
- package/releng/meson/mesonbuild/compilers/mixins/islinker.py +120 -0
- package/releng/meson/mesonbuild/compilers/mixins/metrowerks.py +279 -0
- package/releng/meson/mesonbuild/compilers/mixins/pgi.py +88 -0
- package/releng/meson/mesonbuild/compilers/mixins/ti.py +130 -0
- package/releng/meson/mesonbuild/compilers/mixins/visualstudio.py +458 -0
- package/releng/meson/mesonbuild/compilers/mixins/xc16.py +111 -0
- package/releng/meson/mesonbuild/compilers/objc.py +120 -0
- package/releng/meson/mesonbuild/compilers/objcpp.py +102 -0
- package/releng/meson/mesonbuild/compilers/rust.py +230 -0
- package/releng/meson/mesonbuild/compilers/swift.py +131 -0
- package/releng/meson/mesonbuild/compilers/vala.py +121 -0
- package/releng/meson/mesonbuild/coredata.py +1532 -0
- package/releng/meson/mesonbuild/dependencies/__init__.py +252 -0
- package/releng/meson/mesonbuild/dependencies/base.py +663 -0
- package/releng/meson/mesonbuild/dependencies/boost.py +1083 -0
- package/releng/meson/mesonbuild/dependencies/cmake.py +656 -0
- package/releng/meson/mesonbuild/dependencies/coarrays.py +80 -0
- package/releng/meson/mesonbuild/dependencies/configtool.py +163 -0
- package/releng/meson/mesonbuild/dependencies/cuda.py +295 -0
- package/releng/meson/mesonbuild/dependencies/data/CMakeLists.txt +102 -0
- package/releng/meson/mesonbuild/dependencies/data/CMakeListsLLVM.txt +204 -0
- package/releng/meson/mesonbuild/dependencies/data/CMakePathInfo.txt +31 -0
- package/releng/meson/mesonbuild/dependencies/data/__init__.py +0 -0
- package/releng/meson/mesonbuild/dependencies/detect.py +225 -0
- package/releng/meson/mesonbuild/dependencies/dev.py +707 -0
- package/releng/meson/mesonbuild/dependencies/dub.py +424 -0
- package/releng/meson/mesonbuild/dependencies/factory.py +146 -0
- package/releng/meson/mesonbuild/dependencies/framework.py +111 -0
- package/releng/meson/mesonbuild/dependencies/hdf5.py +168 -0
- package/releng/meson/mesonbuild/dependencies/misc.py +618 -0
- package/releng/meson/mesonbuild/dependencies/mpi.py +231 -0
- package/releng/meson/mesonbuild/dependencies/pkgconfig.py +570 -0
- package/releng/meson/mesonbuild/dependencies/platform.py +52 -0
- package/releng/meson/mesonbuild/dependencies/python.py +431 -0
- package/releng/meson/mesonbuild/dependencies/qt.py +484 -0
- package/releng/meson/mesonbuild/dependencies/scalapack.py +142 -0
- package/releng/meson/mesonbuild/dependencies/ui.py +281 -0
- package/releng/meson/mesonbuild/depfile.py +82 -0
- package/releng/meson/mesonbuild/envconfig.py +480 -0
- package/releng/meson/mesonbuild/environment.py +987 -0
- package/releng/meson/mesonbuild/interpreter/__init__.py +47 -0
- package/releng/meson/mesonbuild/interpreter/compiler.py +900 -0
- package/releng/meson/mesonbuild/interpreter/dependencyfallbacks.py +386 -0
- package/releng/meson/mesonbuild/interpreter/interpreter.py +3595 -0
- package/releng/meson/mesonbuild/interpreter/interpreterobjects.py +1096 -0
- package/releng/meson/mesonbuild/interpreter/kwargs.py +479 -0
- package/releng/meson/mesonbuild/interpreter/mesonmain.py +487 -0
- package/releng/meson/mesonbuild/interpreter/primitives/__init__.py +29 -0
- package/releng/meson/mesonbuild/interpreter/primitives/array.py +108 -0
- package/releng/meson/mesonbuild/interpreter/primitives/boolean.py +52 -0
- package/releng/meson/mesonbuild/interpreter/primitives/dict.py +88 -0
- package/releng/meson/mesonbuild/interpreter/primitives/integer.py +86 -0
- package/releng/meson/mesonbuild/interpreter/primitives/range.py +38 -0
- package/releng/meson/mesonbuild/interpreter/primitives/string.py +247 -0
- package/releng/meson/mesonbuild/interpreter/type_checking.py +853 -0
- package/releng/meson/mesonbuild/interpreterbase/__init__.py +126 -0
- package/releng/meson/mesonbuild/interpreterbase/_unholder.py +25 -0
- package/releng/meson/mesonbuild/interpreterbase/baseobjects.py +174 -0
- package/releng/meson/mesonbuild/interpreterbase/decorators.py +806 -0
- package/releng/meson/mesonbuild/interpreterbase/disabler.py +35 -0
- package/releng/meson/mesonbuild/interpreterbase/exceptions.py +22 -0
- package/releng/meson/mesonbuild/interpreterbase/helpers.py +67 -0
- package/releng/meson/mesonbuild/interpreterbase/interpreterbase.py +665 -0
- package/releng/meson/mesonbuild/interpreterbase/operator.py +32 -0
- package/releng/meson/mesonbuild/linkers/__init__.py +20 -0
- package/releng/meson/mesonbuild/linkers/base.py +39 -0
- package/releng/meson/mesonbuild/linkers/detect.py +229 -0
- package/releng/meson/mesonbuild/linkers/linkers.py +1614 -0
- package/releng/meson/mesonbuild/mcompile.py +380 -0
- package/releng/meson/mesonbuild/mconf.py +368 -0
- package/releng/meson/mesonbuild/mdevenv.py +234 -0
- package/releng/meson/mesonbuild/mdist.py +376 -0
- package/releng/meson/mesonbuild/mesondata.py +38 -0
- package/releng/meson/mesonbuild/mesonlib.py +23 -0
- package/releng/meson/mesonbuild/mesonmain.py +289 -0
- package/releng/meson/mesonbuild/minit.py +204 -0
- package/releng/meson/mesonbuild/minstall.py +864 -0
- package/releng/meson/mesonbuild/mintro.py +667 -0
- package/releng/meson/mesonbuild/mlog.py +542 -0
- package/releng/meson/mesonbuild/modules/__init__.py +270 -0
- package/releng/meson/mesonbuild/modules/cmake.py +442 -0
- package/releng/meson/mesonbuild/modules/cuda.py +377 -0
- package/releng/meson/mesonbuild/modules/dlang.py +117 -0
- package/releng/meson/mesonbuild/modules/external_project.py +306 -0
- package/releng/meson/mesonbuild/modules/fs.py +323 -0
- package/releng/meson/mesonbuild/modules/gnome.py +2215 -0
- package/releng/meson/mesonbuild/modules/hotdoc.py +487 -0
- package/releng/meson/mesonbuild/modules/i18n.py +405 -0
- package/releng/meson/mesonbuild/modules/icestorm.py +123 -0
- package/releng/meson/mesonbuild/modules/java.py +112 -0
- package/releng/meson/mesonbuild/modules/keyval.py +65 -0
- package/releng/meson/mesonbuild/modules/modtest.py +33 -0
- package/releng/meson/mesonbuild/modules/pkgconfig.py +744 -0
- package/releng/meson/mesonbuild/modules/python.py +556 -0
- package/releng/meson/mesonbuild/modules/python3.py +85 -0
- package/releng/meson/mesonbuild/modules/qt.py +621 -0
- package/releng/meson/mesonbuild/modules/qt4.py +23 -0
- package/releng/meson/mesonbuild/modules/qt5.py +23 -0
- package/releng/meson/mesonbuild/modules/qt6.py +22 -0
- package/releng/meson/mesonbuild/modules/rust.py +355 -0
- package/releng/meson/mesonbuild/modules/simd.py +114 -0
- package/releng/meson/mesonbuild/modules/sourceset.py +291 -0
- package/releng/meson/mesonbuild/modules/wayland.py +151 -0
- package/releng/meson/mesonbuild/modules/windows.py +207 -0
- package/releng/meson/mesonbuild/mparser.py +1114 -0
- package/releng/meson/mesonbuild/msetup.py +365 -0
- package/releng/meson/mesonbuild/msubprojects.py +764 -0
- package/releng/meson/mesonbuild/mtest.py +2201 -0
- package/releng/meson/mesonbuild/munstable_coredata.py +107 -0
- package/releng/meson/mesonbuild/optinterpreter.py +276 -0
- package/releng/meson/mesonbuild/programs.py +367 -0
- package/releng/meson/mesonbuild/rewriter.py +1075 -0
- package/releng/meson/mesonbuild/scripts/__init__.py +10 -0
- package/releng/meson/mesonbuild/scripts/clangformat.py +55 -0
- package/releng/meson/mesonbuild/scripts/clangtidy.py +30 -0
- package/releng/meson/mesonbuild/scripts/cleantrees.py +35 -0
- package/releng/meson/mesonbuild/scripts/cmake_run_ctgt.py +103 -0
- package/releng/meson/mesonbuild/scripts/cmd_or_ps.ps1 +17 -0
- package/releng/meson/mesonbuild/scripts/copy.py +19 -0
- package/releng/meson/mesonbuild/scripts/coverage.py +214 -0
- package/releng/meson/mesonbuild/scripts/delwithsuffix.py +27 -0
- package/releng/meson/mesonbuild/scripts/depfixer.py +495 -0
- package/releng/meson/mesonbuild/scripts/depscan.py +198 -0
- package/releng/meson/mesonbuild/scripts/dirchanger.py +20 -0
- package/releng/meson/mesonbuild/scripts/env2mfile.py +402 -0
- package/releng/meson/mesonbuild/scripts/externalproject.py +106 -0
- package/releng/meson/mesonbuild/scripts/gettext.py +86 -0
- package/releng/meson/mesonbuild/scripts/gtkdochelper.py +286 -0
- package/releng/meson/mesonbuild/scripts/hotdochelper.py +40 -0
- package/releng/meson/mesonbuild/scripts/itstool.py +77 -0
- package/releng/meson/mesonbuild/scripts/meson_exe.py +115 -0
- package/releng/meson/mesonbuild/scripts/msgfmthelper.py +29 -0
- package/releng/meson/mesonbuild/scripts/pycompile.py +54 -0
- package/releng/meson/mesonbuild/scripts/python_info.py +121 -0
- package/releng/meson/mesonbuild/scripts/regen_checker.py +55 -0
- package/releng/meson/mesonbuild/scripts/run_tool.py +58 -0
- package/releng/meson/mesonbuild/scripts/scanbuild.py +57 -0
- package/releng/meson/mesonbuild/scripts/symbolextractor.py +322 -0
- package/releng/meson/mesonbuild/scripts/tags.py +44 -0
- package/releng/meson/mesonbuild/scripts/test_loaded_modules.py +14 -0
- package/releng/meson/mesonbuild/scripts/uninstall.py +41 -0
- package/releng/meson/mesonbuild/scripts/vcstagger.py +35 -0
- package/releng/meson/mesonbuild/scripts/yasm.py +24 -0
- package/releng/meson/mesonbuild/templates/__init__.py +0 -0
- package/releng/meson/mesonbuild/templates/cpptemplates.py +143 -0
- package/releng/meson/mesonbuild/templates/cstemplates.py +90 -0
- package/releng/meson/mesonbuild/templates/ctemplates.py +126 -0
- package/releng/meson/mesonbuild/templates/cudatemplates.py +143 -0
- package/releng/meson/mesonbuild/templates/dlangtemplates.py +109 -0
- package/releng/meson/mesonbuild/templates/fortrantemplates.py +101 -0
- package/releng/meson/mesonbuild/templates/javatemplates.py +94 -0
- package/releng/meson/mesonbuild/templates/mesontemplates.py +70 -0
- package/releng/meson/mesonbuild/templates/objcpptemplates.py +126 -0
- package/releng/meson/mesonbuild/templates/objctemplates.py +126 -0
- package/releng/meson/mesonbuild/templates/rusttemplates.py +79 -0
- package/releng/meson/mesonbuild/templates/samplefactory.py +41 -0
- package/releng/meson/mesonbuild/templates/sampleimpl.py +160 -0
- package/releng/meson/mesonbuild/templates/valatemplates.py +82 -0
- package/releng/meson/mesonbuild/utils/__init__.py +0 -0
- package/releng/meson/mesonbuild/utils/core.py +166 -0
- package/releng/meson/mesonbuild/utils/platform.py +27 -0
- package/releng/meson/mesonbuild/utils/posix.py +32 -0
- package/releng/meson/mesonbuild/utils/universal.py +2445 -0
- package/releng/meson/mesonbuild/utils/vsenv.py +126 -0
- package/releng/meson/mesonbuild/utils/win32.py +29 -0
- package/releng/meson/mesonbuild/wrap/__init__.py +59 -0
- package/releng/meson/mesonbuild/wrap/wrap.py +846 -0
- package/releng/meson/mesonbuild/wrap/wraptool.py +198 -0
- package/releng/meson-scripts/BSDmakefile +6 -0
- package/releng/meson-scripts/Makefile +16 -0
- package/releng/meson-scripts/configure +18 -0
- package/releng/meson-scripts/configure.bat +22 -0
- package/releng/meson-scripts/make.bat +23 -0
- package/releng/meson_configure.py +506 -0
- package/releng/meson_make.py +131 -0
- package/releng/mkdevkit.py +107 -0
- package/releng/mkfatmacho.py +54 -0
- package/releng/post-process-oabi.py +97 -0
- package/releng/progress.py +14 -0
- package/releng/sync-from-upstream.py +185 -0
- package/releng/tomlkit/tomlkit/__init__.py +59 -0
- package/releng/tomlkit/tomlkit/_compat.py +22 -0
- package/releng/tomlkit/tomlkit/_types.py +83 -0
- package/releng/tomlkit/tomlkit/_utils.py +158 -0
- package/releng/tomlkit/tomlkit/api.py +308 -0
- package/releng/tomlkit/tomlkit/container.py +875 -0
- package/releng/tomlkit/tomlkit/exceptions.py +227 -0
- package/releng/tomlkit/tomlkit/items.py +1967 -0
- package/releng/tomlkit/tomlkit/parser.py +1141 -0
- package/releng/tomlkit/tomlkit/py.typed +0 -0
- package/releng/tomlkit/tomlkit/source.py +180 -0
- package/releng/tomlkit/tomlkit/toml_char.py +52 -0
- package/releng/tomlkit/tomlkit/toml_document.py +7 -0
- package/releng/tomlkit/tomlkit/toml_file.py +58 -0
- package/releng/winenv.py +140 -0
- package/scripts/adjust-version.py +19 -0
- package/scripts/detect-version.py +40 -0
- package/scripts/fetch-abi-bits.py +343 -0
- package/scripts/install.js +23 -0
- package/scripts/package.py +15 -0
- package/src/addon.cc +76 -0
- package/src/application.cc +148 -0
- package/src/application.h +31 -0
- package/src/authentication.cc +174 -0
- package/src/authentication.h +24 -0
- package/src/bus.cc +167 -0
- package/src/bus.h +33 -0
- package/src/cancellable.cc +117 -0
- package/src/cancellable.h +31 -0
- package/src/child.cc +150 -0
- package/src/child.h +32 -0
- package/src/crash.cc +122 -0
- package/src/crash.h +30 -0
- package/src/device.cc +1302 -0
- package/src/device.h +55 -0
- package/src/device_manager.cc +362 -0
- package/src/device_manager.h +35 -0
- package/src/endpoint_parameters.cc +171 -0
- package/src/endpoint_parameters.h +28 -0
- package/src/glib_context.cc +62 -0
- package/src/glib_context.h +29 -0
- package/src/glib_object.cc +25 -0
- package/src/glib_object.h +37 -0
- package/src/iostream.cc +247 -0
- package/src/iostream.h +30 -0
- package/src/meson.build +26 -0
- package/src/operation.h +94 -0
- package/src/portal_membership.cc +100 -0
- package/src/portal_membership.h +26 -0
- package/src/portal_service.cc +401 -0
- package/src/portal_service.h +40 -0
- package/src/process.cc +135 -0
- package/src/process.h +30 -0
- package/src/relay.cc +139 -0
- package/src/relay.h +31 -0
- package/src/runtime.cc +443 -0
- package/src/runtime.h +64 -0
- package/src/script.cc +301 -0
- package/src/script.h +36 -0
- package/src/session.cc +860 -0
- package/src/session.h +42 -0
- package/src/signals.cc +334 -0
- package/src/signals.h +47 -0
- package/src/spawn.cc +95 -0
- package/src/spawn.h +27 -0
- package/src/usage_monitor.h +117 -0
- package/src/uv_context.cc +118 -0
- package/src/uv_context.h +40 -0
- package/src/win_delay_load_hook.cc +63 -0
- package/subprojects/frida-core.wrap +8 -0
- package/subprojects/nan.wrap +9 -0
- package/subprojects/packagefiles/nan.patch +13 -0
- package/test/data/index.ts +13 -0
- package/test/data/unixvictim-linux-x86 +0 -0
- package/test/data/unixvictim-linux-x86_64 +0 -0
- package/test/data/unixvictim-macos +0 -0
- package/test/device.ts +27 -0
- package/test/device_manager.ts +16 -0
- package/test/labrat.ts +32 -0
- package/test/script.ts +176 -0
- package/test/session.ts +73 -0
- package/tsconfig.json +18 -0
|
@@ -0,0 +1,343 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
from dataclasses import dataclass
|
|
3
|
+
from io import BytesIO, IOBase
|
|
4
|
+
import json
|
|
5
|
+
import os
|
|
6
|
+
from pathlib import Path
|
|
7
|
+
import shutil
|
|
8
|
+
import struct
|
|
9
|
+
import subprocess
|
|
10
|
+
import sys
|
|
11
|
+
import tarfile
|
|
12
|
+
import tempfile
|
|
13
|
+
from typing import Union
|
|
14
|
+
import urllib.request
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
IMAGE_ARCHIVE_START = b"!<arch>\n"
|
|
18
|
+
IMAGE_FILE_MACHINE_UNKNOWN = 0
|
|
19
|
+
IMPORT_OBJECT_HDR_SIG2 = 0xffff
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
def main(argv: list[str]):
|
|
23
|
+
runtime, target, gyp_os, gyp_arch = argv[1:5]
|
|
24
|
+
flavor = "|".join(argv[1:5])
|
|
25
|
+
node, npm, outdir = [Path(p) for p in argv[5:8]]
|
|
26
|
+
|
|
27
|
+
abidir = outdir / "abi-bits"
|
|
28
|
+
metadata_file = abidir / "abi-bits.json"
|
|
29
|
+
|
|
30
|
+
metadata = None
|
|
31
|
+
if metadata_file.exists():
|
|
32
|
+
metadata = json.loads(metadata_file.read_text(encoding="utf-8"))
|
|
33
|
+
if metadata["flavor"] != flavor:
|
|
34
|
+
metadata = None
|
|
35
|
+
|
|
36
|
+
if metadata is None:
|
|
37
|
+
if abidir.exists():
|
|
38
|
+
shutil.rmtree(abidir)
|
|
39
|
+
|
|
40
|
+
(node_incdirs, node_gypdir, node_libs) = load_dev_assets(runtime, target, gyp_os, gyp_arch,
|
|
41
|
+
node, outdir, abidir)
|
|
42
|
+
|
|
43
|
+
subprocess.run([npm, "init", "-y"],
|
|
44
|
+
capture_output=True,
|
|
45
|
+
cwd=abidir,
|
|
46
|
+
check=True)
|
|
47
|
+
subprocess.run([npm, "install", "node-abi", "node-gyp"],
|
|
48
|
+
capture_output=True,
|
|
49
|
+
cwd=abidir,
|
|
50
|
+
check=True)
|
|
51
|
+
|
|
52
|
+
abi = subprocess.run([node, "-e", f"console.log(require('node-abi').getAbi('{target}', '{runtime}'))"],
|
|
53
|
+
capture_output=True,
|
|
54
|
+
encoding="utf-8",
|
|
55
|
+
cwd=abidir,
|
|
56
|
+
check=True).stdout.strip()
|
|
57
|
+
|
|
58
|
+
node_defines = load_node_defines(gyp_os, gyp_arch, node_gypdir,
|
|
59
|
+
abidir / "node_modules" / "node-gyp" / "gyp" / "pylib")
|
|
60
|
+
|
|
61
|
+
node_incdirs_rel = [d.relative_to(outdir) if d.is_relative_to(outdir) else d for d in node_incdirs]
|
|
62
|
+
node_libs_rel = [l.relative_to(outdir) if l.is_relative_to(outdir) else l for l in node_libs]
|
|
63
|
+
|
|
64
|
+
metadata = {
|
|
65
|
+
"flavor": flavor,
|
|
66
|
+
"abi": abi,
|
|
67
|
+
"node_defines": node_defines,
|
|
68
|
+
"node_incdirs": [str(d) for d in node_incdirs_rel],
|
|
69
|
+
"node_libs": [str(l) for l in node_libs_rel],
|
|
70
|
+
}
|
|
71
|
+
metadata_file.write_text(json.dumps(metadata, indent=2), encoding="utf-8")
|
|
72
|
+
|
|
73
|
+
print_metadata(metadata)
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
def print_metadata(metadata: dict[str, Union[str, list[str]]]):
|
|
77
|
+
print("abi:", metadata["abi"])
|
|
78
|
+
print("node_defines:", " ".join(metadata["node_defines"]))
|
|
79
|
+
for d in metadata["node_incdirs"]:
|
|
80
|
+
print("node_incdir:", d)
|
|
81
|
+
for l in metadata["node_libs"]:
|
|
82
|
+
print("node_lib:", l)
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
def load_dev_assets(runtime: str,
|
|
86
|
+
target: str,
|
|
87
|
+
gyp_os: str,
|
|
88
|
+
gyp_arch: str,
|
|
89
|
+
node: Path,
|
|
90
|
+
outdir: Path,
|
|
91
|
+
abidir: Path) -> tuple[list[Path], Path, list[Path]]:
|
|
92
|
+
if runtime == "node" and target == "" and gyp_os != "win":
|
|
93
|
+
node_incroot = node.parent.parent / "include"
|
|
94
|
+
node_incdir = node_incroot / "node"
|
|
95
|
+
if node_incdir.exists():
|
|
96
|
+
abidir.mkdir()
|
|
97
|
+
node_gypdir = node_incdir
|
|
98
|
+
node_libs = []
|
|
99
|
+
return ([node_incdir, node_incroot], node_gypdir, node_libs)
|
|
100
|
+
|
|
101
|
+
if target == "":
|
|
102
|
+
version = subprocess.run([node, "--version"], capture_output=True, encoding="utf-8").stdout.strip()
|
|
103
|
+
else:
|
|
104
|
+
version = f"v{target}"
|
|
105
|
+
|
|
106
|
+
node_arch = "x86" if gyp_arch == "ia32" else gyp_arch
|
|
107
|
+
|
|
108
|
+
if runtime == "node":
|
|
109
|
+
base_url = f"https://nodejs.org/dist/{version}"
|
|
110
|
+
headers_stem = f"node-{version}-headers"
|
|
111
|
+
libs_subpath = f"/win-{node_arch}"
|
|
112
|
+
compression_formats = ["xz", "gz"]
|
|
113
|
+
elif runtime == "electron":
|
|
114
|
+
base_url = f"https://electronjs.org/headers/{version}"
|
|
115
|
+
headers_stem = f"node-{version}-headers"
|
|
116
|
+
libs_subpath = f"/win-{node_arch}"
|
|
117
|
+
compression_formats = ["gz"]
|
|
118
|
+
else:
|
|
119
|
+
assert runtime == "node-webkit"
|
|
120
|
+
base_url = f"https://node-webkit.s3.amazonaws.com/{version}"
|
|
121
|
+
headers_stem = f"nw-headers-{version}"
|
|
122
|
+
libs_subpath = "" if node_arch == "x86" else f"/{node_arch}"
|
|
123
|
+
compression_formats = ["gz"]
|
|
124
|
+
|
|
125
|
+
download_error = None
|
|
126
|
+
for compression in compression_formats:
|
|
127
|
+
try:
|
|
128
|
+
with urllib.request.urlopen(f"{base_url}/{headers_stem}.tar.{compression}") as response:
|
|
129
|
+
tar_blob = response.read()
|
|
130
|
+
except urllib.error.HTTPError as e:
|
|
131
|
+
download_error = e
|
|
132
|
+
if e.code == 404:
|
|
133
|
+
continue
|
|
134
|
+
raise e
|
|
135
|
+
|
|
136
|
+
with tarfile.open(fileobj=BytesIO(tar_blob), mode=f"r:{compression}") as tar:
|
|
137
|
+
extracted_rootdir_name = tar.getnames()[0].split("/", maxsplit=1)[0]
|
|
138
|
+
tar.extractall(outdir)
|
|
139
|
+
|
|
140
|
+
download_error = None
|
|
141
|
+
break
|
|
142
|
+
if download_error is not None:
|
|
143
|
+
print(download_error, file=sys.stderr)
|
|
144
|
+
sys.exit(1)
|
|
145
|
+
|
|
146
|
+
extracted_rootdir = outdir / extracted_rootdir_name
|
|
147
|
+
|
|
148
|
+
node_libnames = []
|
|
149
|
+
if gyp_os == "win":
|
|
150
|
+
libdir = extracted_rootdir / "lib"
|
|
151
|
+
libdir.mkdir()
|
|
152
|
+
|
|
153
|
+
node_lib = libdir / "node.lib"
|
|
154
|
+
with urllib.request.urlopen(f"{base_url}{libs_subpath}/node.lib") as response:
|
|
155
|
+
vanilla_lib = response.read()
|
|
156
|
+
redacted_lib = BytesIO(vanilla_lib)
|
|
157
|
+
redact_node_lib_symbols(redacted_lib, gyp_arch)
|
|
158
|
+
node_lib.write_bytes(redacted_lib.getvalue())
|
|
159
|
+
node_libnames.append(node_lib.name)
|
|
160
|
+
|
|
161
|
+
if runtime == "node-webkit":
|
|
162
|
+
nw_lib = libdir / "nw.lib"
|
|
163
|
+
with urllib.request.urlopen(f"{base_url}{libs_subpath}/nw.lib") as response:
|
|
164
|
+
nw_lib.write_bytes(response.read())
|
|
165
|
+
node_libnames.append(nw_lib.name)
|
|
166
|
+
|
|
167
|
+
os.rename(extracted_rootdir, abidir)
|
|
168
|
+
|
|
169
|
+
if runtime == "node-webkit":
|
|
170
|
+
node_incdirs = [
|
|
171
|
+
abidir / "src",
|
|
172
|
+
abidir / "deps" / "uv" / "include",
|
|
173
|
+
abidir / "deps" / "v8" / "include",
|
|
174
|
+
]
|
|
175
|
+
node_gypdir = abidir
|
|
176
|
+
else:
|
|
177
|
+
incdir = abidir / "include" / "node"
|
|
178
|
+
node_incdirs = [incdir]
|
|
179
|
+
node_gypdir = incdir
|
|
180
|
+
|
|
181
|
+
node_libs = [abidir / "lib" / name for name in node_libnames]
|
|
182
|
+
|
|
183
|
+
return (node_incdirs, node_gypdir, node_libs)
|
|
184
|
+
|
|
185
|
+
|
|
186
|
+
def load_node_defines(gyp_os: str, gyp_arch: str, node_gypdir: Path, gyp_pylib: Path) -> list[str]:
|
|
187
|
+
sys.path.insert(0, str(gyp_pylib))
|
|
188
|
+
import gyp
|
|
189
|
+
|
|
190
|
+
with tempfile.NamedTemporaryFile(mode="w", encoding="utf-8", delete=False) as binding_gyp:
|
|
191
|
+
binding_gyp.write("""{
|
|
192
|
+
"targets": [
|
|
193
|
+
{
|
|
194
|
+
"target_name": "frida_binding",
|
|
195
|
+
"type": "loadable_module",
|
|
196
|
+
"sources": [
|
|
197
|
+
"src/addon.cc",
|
|
198
|
+
],
|
|
199
|
+
},
|
|
200
|
+
],
|
|
201
|
+
}
|
|
202
|
+
""")
|
|
203
|
+
binding_gyp.close()
|
|
204
|
+
try:
|
|
205
|
+
[generator, flat_list, targets, data] = \
|
|
206
|
+
gyp.Load([binding_gyp.name],
|
|
207
|
+
"compile_commands_json",
|
|
208
|
+
default_variables={
|
|
209
|
+
"OS": gyp_os,
|
|
210
|
+
"target_arch": gyp_arch,
|
|
211
|
+
"MSVS_VERSION": "auto",
|
|
212
|
+
"node_engine": "v8",
|
|
213
|
+
},
|
|
214
|
+
includes=[
|
|
215
|
+
node_gypdir / "common.gypi",
|
|
216
|
+
node_gypdir / "config.gypi",
|
|
217
|
+
],
|
|
218
|
+
params={
|
|
219
|
+
"options": GypOptions(),
|
|
220
|
+
"parallel": False,
|
|
221
|
+
"root_targets": None,
|
|
222
|
+
})
|
|
223
|
+
finally:
|
|
224
|
+
os.unlink(binding_gyp.name)
|
|
225
|
+
|
|
226
|
+
target = targets[flat_list[0]]
|
|
227
|
+
config = target["configurations"][target["default_configuration"]]
|
|
228
|
+
return [adapt_node_define(d) for d in config["defines"] if want_node_define(d)]
|
|
229
|
+
|
|
230
|
+
|
|
231
|
+
def want_node_define(d: str) -> bool:
|
|
232
|
+
if d.startswith("V8_") and "DEPRECATION_WARNINGS" in d:
|
|
233
|
+
return False
|
|
234
|
+
return True
|
|
235
|
+
|
|
236
|
+
|
|
237
|
+
def adapt_node_define(d: str) -> str:
|
|
238
|
+
if d.startswith("BUILDING_"):
|
|
239
|
+
return "USING_" + d[9:]
|
|
240
|
+
if d == "_HAS_EXCEPTIONS=1":
|
|
241
|
+
return "_HAS_EXCEPTIONS=0"
|
|
242
|
+
return d
|
|
243
|
+
|
|
244
|
+
|
|
245
|
+
class GypOptions:
|
|
246
|
+
generator_output = os.getcwd()
|
|
247
|
+
|
|
248
|
+
|
|
249
|
+
def redact_node_lib_symbols(lib: Path, gyp_arch: str):
|
|
250
|
+
magic = lib.read(8)
|
|
251
|
+
assert magic == IMAGE_ARCHIVE_START
|
|
252
|
+
|
|
253
|
+
file_header = read_image_archive_member_header(lib)
|
|
254
|
+
|
|
255
|
+
num_symbols, = struct.unpack(">I", lib.read(4))
|
|
256
|
+
|
|
257
|
+
symbol_offsets = []
|
|
258
|
+
for i in range(num_symbols):
|
|
259
|
+
sym_offset, = struct.unpack(">I", lib.read(4))
|
|
260
|
+
symbol_offsets.append(sym_offset)
|
|
261
|
+
symbol_offsets = list(sorted(set(symbol_offsets)))
|
|
262
|
+
|
|
263
|
+
string_pool_start = lib.tell()
|
|
264
|
+
string_pool_end = symbol_offsets[0]
|
|
265
|
+
|
|
266
|
+
renamed_symbols = {}
|
|
267
|
+
node_prefixes = [function_name_to_cdecl_symbol(p, gyp_arch).encode("ascii") for p in {"napi_", "node", "uv_"}]
|
|
268
|
+
for offset in symbol_offsets:
|
|
269
|
+
lib.seek(offset)
|
|
270
|
+
|
|
271
|
+
member_header = read_image_archive_member_header(lib)
|
|
272
|
+
object_header = read_import_object_header(lib)
|
|
273
|
+
|
|
274
|
+
if object_header.sig1 == IMAGE_FILE_MACHINE_UNKNOWN and \
|
|
275
|
+
object_header.sig2 == IMPORT_OBJECT_HDR_SIG2:
|
|
276
|
+
import_name_offset = lib.tell()
|
|
277
|
+
strings = lib.read(object_header.size_of_data).split(b"\x00")
|
|
278
|
+
import_name = strings[0]
|
|
279
|
+
dll_name = strings[1]
|
|
280
|
+
is_node_symbol = import_name.startswith(b"?") or (
|
|
281
|
+
next((p for p in node_prefixes if import_name.startswith(p)), None) is not None)
|
|
282
|
+
if not is_node_symbol:
|
|
283
|
+
new_prefix = b"X" if not import_name.startswith(B"X") else b"Y"
|
|
284
|
+
redacted_name = new_prefix + import_name[1:]
|
|
285
|
+
lib.seek(import_name_offset)
|
|
286
|
+
lib.write(redacted_name)
|
|
287
|
+
renamed_symbols[import_name] = redacted_name
|
|
288
|
+
|
|
289
|
+
lib.seek(string_pool_start)
|
|
290
|
+
string_pool = lib.read(string_pool_end - string_pool_start)
|
|
291
|
+
lib.seek(string_pool_start)
|
|
292
|
+
lib.write(update_string_pool(string_pool, renamed_symbols))
|
|
293
|
+
|
|
294
|
+
|
|
295
|
+
def function_name_to_cdecl_symbol(name: str, gyp_arch: str) -> str:
|
|
296
|
+
if gyp_arch == "ia32":
|
|
297
|
+
return "_" + name
|
|
298
|
+
return name
|
|
299
|
+
|
|
300
|
+
|
|
301
|
+
def read_image_archive_member_header(f: IOBase) -> ImageArchiveMemberHeader:
|
|
302
|
+
data = f.read(60)
|
|
303
|
+
|
|
304
|
+
raw_name = data[:16].decode("utf-8")
|
|
305
|
+
name = raw_name[:raw_name.index("/")]
|
|
306
|
+
|
|
307
|
+
size = int(data[48:58].decode("utf-8"))
|
|
308
|
+
|
|
309
|
+
return ImageArchiveMemberHeader(name, size, data)
|
|
310
|
+
|
|
311
|
+
|
|
312
|
+
def read_import_object_header(f: IOBase) -> ImportObjectHeader:
|
|
313
|
+
data = f.read(20)
|
|
314
|
+
|
|
315
|
+
(sig1, sig2, version, machine, time_date_stamp, size_of_data) \
|
|
316
|
+
= struct.unpack("<HHHHII", data[:16])
|
|
317
|
+
|
|
318
|
+
return ImportObjectHeader(sig1, sig2, version, machine, size_of_data, data)
|
|
319
|
+
|
|
320
|
+
|
|
321
|
+
def update_string_pool(pool: bytes, renames: dict[str, str]) -> bytes:
|
|
322
|
+
return b"\x00".join(map(lambda s: renames.get(s, s), pool.split(b"\x00")))
|
|
323
|
+
|
|
324
|
+
|
|
325
|
+
@dataclass
|
|
326
|
+
class ImageArchiveMemberHeader:
|
|
327
|
+
name: str
|
|
328
|
+
size: int
|
|
329
|
+
raw_header: bytes
|
|
330
|
+
|
|
331
|
+
|
|
332
|
+
@dataclass
|
|
333
|
+
class ImportObjectHeader:
|
|
334
|
+
sig1: int
|
|
335
|
+
sig2: int
|
|
336
|
+
version: int
|
|
337
|
+
machine: int
|
|
338
|
+
size_of_data: int
|
|
339
|
+
raw_header: bytes
|
|
340
|
+
|
|
341
|
+
|
|
342
|
+
if __name__ == "__main__":
|
|
343
|
+
main(sys.argv)
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
const { execSync } = require('child_process');
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
const path = require('path');
|
|
4
|
+
|
|
5
|
+
const pkgRoot = path.dirname(path.dirname(__filename));
|
|
6
|
+
const binding = path.join(pkgRoot, 'build', 'frida_binding.node');
|
|
7
|
+
if (fs.existsSync(binding)) {
|
|
8
|
+
process.exit(0);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
try {
|
|
12
|
+
execSync('prebuild-install', { stdio: 'inherit' });
|
|
13
|
+
process.exit(0);
|
|
14
|
+
} catch (e) {
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
try {
|
|
18
|
+
execSync('make', { stdio: 'inherit' });
|
|
19
|
+
process.exit(0);
|
|
20
|
+
} catch (e) {
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
process.exit(1);
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
from pathlib import Path
|
|
2
|
+
import sys
|
|
3
|
+
import tarfile
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
def main(argv: list[str]):
|
|
7
|
+
binding = Path(argv[1])
|
|
8
|
+
outfile = Path(argv[2])
|
|
9
|
+
|
|
10
|
+
with tarfile.open(outfile, "w:gz") as tar:
|
|
11
|
+
tar.add(binding, arcname="build/frida_binding.node")
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
if __name__ == "__main__":
|
|
15
|
+
main(sys.argv)
|
package/src/addon.cc
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
#include "application.h"
|
|
2
|
+
#include "bus.h"
|
|
3
|
+
#include "cancellable.h"
|
|
4
|
+
#include "child.h"
|
|
5
|
+
#include "crash.h"
|
|
6
|
+
#include "device.h"
|
|
7
|
+
#include "device_manager.h"
|
|
8
|
+
#include "endpoint_parameters.h"
|
|
9
|
+
#include "glib_context.h"
|
|
10
|
+
#include "iostream.h"
|
|
11
|
+
#include "portal_membership.h"
|
|
12
|
+
#include "portal_service.h"
|
|
13
|
+
#include "process.h"
|
|
14
|
+
#include "relay.h"
|
|
15
|
+
#include "runtime.h"
|
|
16
|
+
#include "script.h"
|
|
17
|
+
#include "session.h"
|
|
18
|
+
#include "signals.h"
|
|
19
|
+
#include "spawn.h"
|
|
20
|
+
#include "uv_context.h"
|
|
21
|
+
|
|
22
|
+
using v8::Context;
|
|
23
|
+
using v8::Local;
|
|
24
|
+
using v8::Object;
|
|
25
|
+
using v8::Value;
|
|
26
|
+
|
|
27
|
+
namespace frida {
|
|
28
|
+
|
|
29
|
+
static void DisposeAll(void* data);
|
|
30
|
+
|
|
31
|
+
static void InitAll(Local<Object> exports,
|
|
32
|
+
Local<Value> module,
|
|
33
|
+
Local<Context> context) {
|
|
34
|
+
frida_init();
|
|
35
|
+
|
|
36
|
+
auto uv_context = new UVContext(uv_default_loop());
|
|
37
|
+
auto glib_context = new GLibContext(frida_get_main_context());
|
|
38
|
+
auto runtime = new Runtime(uv_context, glib_context);
|
|
39
|
+
|
|
40
|
+
Signals::Init(exports, runtime);
|
|
41
|
+
|
|
42
|
+
DeviceManager::Init(exports, runtime);
|
|
43
|
+
Device::Init(exports, runtime);
|
|
44
|
+
Application::Init(exports, runtime);
|
|
45
|
+
Process::Init(exports, runtime);
|
|
46
|
+
Spawn::Init(exports, runtime);
|
|
47
|
+
Child::Init(exports, runtime);
|
|
48
|
+
Crash::Init(exports, runtime);
|
|
49
|
+
Bus::Init(exports, runtime);
|
|
50
|
+
Session::Init(exports, runtime);
|
|
51
|
+
Script::Init(exports, runtime);
|
|
52
|
+
Relay::Init(exports, runtime);
|
|
53
|
+
PortalMembership::Init(exports, runtime);
|
|
54
|
+
PortalService::Init(exports, runtime);
|
|
55
|
+
EndpointParameters::Init(exports, runtime);
|
|
56
|
+
IOStream::Init(exports, runtime);
|
|
57
|
+
Cancellable::Init(exports, runtime);
|
|
58
|
+
|
|
59
|
+
#if NODE_VERSION_AT_LEAST(11, 0, 0)
|
|
60
|
+
node::AddEnvironmentCleanupHook(context->GetIsolate(), DisposeAll, runtime);
|
|
61
|
+
#else
|
|
62
|
+
node::AtExit(DisposeAll, runtime);
|
|
63
|
+
#endif
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
static void DisposeAll(void* data) {
|
|
67
|
+
auto runtime = static_cast<Runtime*>(data);
|
|
68
|
+
|
|
69
|
+
DeviceManager::Dispose(runtime);
|
|
70
|
+
|
|
71
|
+
delete runtime;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
NODE_MODULE_CONTEXT_AWARE(frida_binding, frida::InitAll)
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
#include "application.h"
|
|
2
|
+
|
|
3
|
+
#include <cstring>
|
|
4
|
+
|
|
5
|
+
#define APPLICATION_DATA_CONSTRUCTOR "application:ctor"
|
|
6
|
+
|
|
7
|
+
using std::strcmp;
|
|
8
|
+
using v8::DEFAULT;
|
|
9
|
+
using v8::External;
|
|
10
|
+
using v8::Function;
|
|
11
|
+
using v8::Integer;
|
|
12
|
+
using v8::Isolate;
|
|
13
|
+
using v8::Local;
|
|
14
|
+
using v8::Object;
|
|
15
|
+
using v8::Persistent;
|
|
16
|
+
using v8::ReadOnly;
|
|
17
|
+
using v8::String;
|
|
18
|
+
using v8::Value;
|
|
19
|
+
|
|
20
|
+
namespace frida {
|
|
21
|
+
|
|
22
|
+
Application::Application(FridaApplication* handle, Runtime* runtime)
|
|
23
|
+
: GLibObject(handle, runtime) {
|
|
24
|
+
g_object_ref(handle_);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
Application::~Application() {
|
|
28
|
+
g_object_unref(handle_);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
void Application::Init(Local<Object> exports, Runtime* runtime) {
|
|
32
|
+
auto isolate = Isolate::GetCurrent();
|
|
33
|
+
|
|
34
|
+
auto name = Nan::New("Application").ToLocalChecked();
|
|
35
|
+
auto tpl = CreateTemplate(name, Application::New, runtime);
|
|
36
|
+
|
|
37
|
+
auto instance_tpl = tpl->InstanceTemplate();
|
|
38
|
+
auto data = Local<Value>();
|
|
39
|
+
Nan::SetAccessor(instance_tpl, Nan::New("parameters").ToLocalChecked(),
|
|
40
|
+
GetParameters, 0, data, DEFAULT, ReadOnly);
|
|
41
|
+
Nan::SetAccessor(instance_tpl, Nan::New("pid").ToLocalChecked(),
|
|
42
|
+
GetPid, 0, data, DEFAULT, ReadOnly);
|
|
43
|
+
Nan::SetAccessor(instance_tpl, Nan::New("name").ToLocalChecked(),
|
|
44
|
+
GetName, 0, data, DEFAULT, ReadOnly);
|
|
45
|
+
Nan::SetAccessor(instance_tpl, Nan::New("identifier").ToLocalChecked(),
|
|
46
|
+
GetIdentifier, 0, data, DEFAULT, ReadOnly);
|
|
47
|
+
|
|
48
|
+
auto ctor = Nan::GetFunction(tpl).ToLocalChecked();
|
|
49
|
+
Nan::Set(exports, name, ctor);
|
|
50
|
+
runtime->SetDataPointer(APPLICATION_DATA_CONSTRUCTOR,
|
|
51
|
+
new Persistent<Function>(isolate, ctor));
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
Local<Object> Application::New(gpointer handle, Runtime* runtime) {
|
|
55
|
+
auto ctor = Nan::New<Function>(
|
|
56
|
+
*static_cast<Persistent<Function>*>(
|
|
57
|
+
runtime->GetDataPointer(APPLICATION_DATA_CONSTRUCTOR)));
|
|
58
|
+
|
|
59
|
+
const int argc = 1;
|
|
60
|
+
Local<Value> argv[argc] = { Nan::New<External>(handle) };
|
|
61
|
+
return Nan::NewInstance(ctor, argc, argv).ToLocalChecked();
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
NAN_METHOD(Application::New) {
|
|
65
|
+
if (!info.IsConstructCall()) {
|
|
66
|
+
Nan::ThrowError("Use the `new` keyword to create a new instance");
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
if (info.Length() != 1 || !info[0]->IsExternal()) {
|
|
71
|
+
Nan::ThrowTypeError("Bad argument, expected raw handle");
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
auto runtime = GetRuntimeFromConstructorArgs(info);
|
|
76
|
+
|
|
77
|
+
auto handle = static_cast<FridaApplication*>(
|
|
78
|
+
Local<External>::Cast(info[0])->Value());
|
|
79
|
+
auto wrapper = new Application(handle, runtime);
|
|
80
|
+
auto obj = info.This();
|
|
81
|
+
wrapper->Wrap(obj);
|
|
82
|
+
|
|
83
|
+
info.GetReturnValue().Set(obj);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
NAN_PROPERTY_GETTER(Application::GetIdentifier) {
|
|
87
|
+
auto handle = ObjectWrap::Unwrap<Application>(
|
|
88
|
+
info.Holder())->GetHandle<FridaApplication>();
|
|
89
|
+
|
|
90
|
+
info.GetReturnValue().Set(
|
|
91
|
+
Nan::New(frida_application_get_identifier(handle)).ToLocalChecked());
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
NAN_PROPERTY_GETTER(Application::GetName) {
|
|
95
|
+
auto handle = ObjectWrap::Unwrap<Application>(
|
|
96
|
+
info.Holder())->GetHandle<FridaApplication>();
|
|
97
|
+
|
|
98
|
+
info.GetReturnValue().Set(
|
|
99
|
+
Nan::New(frida_application_get_name(handle)).ToLocalChecked());
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
NAN_PROPERTY_GETTER(Application::GetPid) {
|
|
103
|
+
auto isolate = info.GetIsolate();
|
|
104
|
+
auto handle = ObjectWrap::Unwrap<Application>(
|
|
105
|
+
info.Holder())->GetHandle<FridaApplication>();
|
|
106
|
+
|
|
107
|
+
info.GetReturnValue().Set(
|
|
108
|
+
Integer::NewFromUnsigned(isolate, frida_application_get_pid(handle)));
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
NAN_PROPERTY_GETTER(Application::GetParameters) {
|
|
112
|
+
auto wrapper = ObjectWrap::Unwrap<Application>(info.Holder());
|
|
113
|
+
auto handle = wrapper->GetHandle<FridaApplication>();
|
|
114
|
+
|
|
115
|
+
GHashTable* parameters = frida_application_get_parameters(handle);
|
|
116
|
+
info.GetReturnValue().Set(ParseParameters(parameters));
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
Local<Value> Application::ParseParameters(GHashTable* dict) {
|
|
120
|
+
auto result = Nan::New<Object>();
|
|
121
|
+
|
|
122
|
+
GHashTableIter iter;
|
|
123
|
+
gpointer raw_key, raw_value;
|
|
124
|
+
|
|
125
|
+
g_hash_table_iter_init(&iter, dict);
|
|
126
|
+
|
|
127
|
+
while (g_hash_table_iter_next(&iter, &raw_key, &raw_value)) {
|
|
128
|
+
char* canonicalized_key =
|
|
129
|
+
Runtime::ParameterNameFromC(static_cast<char*>(raw_key));
|
|
130
|
+
GVariant* var_value = static_cast<GVariant*>(raw_value);
|
|
131
|
+
|
|
132
|
+
Local<String> key = Nan::New(canonicalized_key).ToLocalChecked();
|
|
133
|
+
Local<Value> value;
|
|
134
|
+
if (strcmp(canonicalized_key, "started") == 0 &&
|
|
135
|
+
g_variant_is_of_type(var_value, G_VARIANT_TYPE_STRING)) {
|
|
136
|
+
value = Runtime::ValueFromDatetime(g_variant_get_string(var_value, NULL));
|
|
137
|
+
} else {
|
|
138
|
+
value = Runtime::ValueFromVariant(var_value);
|
|
139
|
+
}
|
|
140
|
+
Nan::Set(result, key, value);
|
|
141
|
+
|
|
142
|
+
g_free(canonicalized_key);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return result;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
#ifndef FRIDANODE_APPLICATION_H
|
|
2
|
+
#define FRIDANODE_APPLICATION_H
|
|
3
|
+
|
|
4
|
+
#include "glib_object.h"
|
|
5
|
+
|
|
6
|
+
#include <frida-core.h>
|
|
7
|
+
|
|
8
|
+
namespace frida {
|
|
9
|
+
|
|
10
|
+
class Application : public GLibObject {
|
|
11
|
+
public:
|
|
12
|
+
static void Init(v8::Local<v8::Object> exports, Runtime* runtime);
|
|
13
|
+
static v8::Local<v8::Object> New(gpointer handle, Runtime* runtime);
|
|
14
|
+
|
|
15
|
+
private:
|
|
16
|
+
explicit Application(FridaApplication* handle, Runtime* runtime);
|
|
17
|
+
~Application();
|
|
18
|
+
|
|
19
|
+
static NAN_METHOD(New);
|
|
20
|
+
|
|
21
|
+
static NAN_PROPERTY_GETTER(GetIdentifier);
|
|
22
|
+
static NAN_PROPERTY_GETTER(GetName);
|
|
23
|
+
static NAN_PROPERTY_GETTER(GetPid);
|
|
24
|
+
static NAN_PROPERTY_GETTER(GetParameters);
|
|
25
|
+
|
|
26
|
+
static v8::Local<v8::Value> ParseParameters(GHashTable* dict);
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
#endif
|