Metadata-Version: 2.1
Name: androidMemoryTool
Version: 0.3
Summary: Read/Write android/linux Runtime RAM Memory
Home-page: https://github.com/Anonym0usWork1221/android-memorytool
Author: Abdul Moez
Author-email: abdulmoez123456789@gmail.com
License: GPL-3.0 license
Platform: UNKNOWN
Classifier: License :: OSI Approved :: GNU General Public License v3 or later (GPLv3+)
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Software Development :: Disassemblers
Classifier: Topic :: Games/Entertainment
Classifier: Topic :: Software Development :: Debuggers
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Environment :: Console
Description-Content-Type: text/markdown
License-File: LICENSE.md

AndroidMemoryTool
====
[![GitHub stars](https://img.shields.io/github/stars/Anonym0usWork1221/android-memorytool.svg)](https://github.com/Anonym0usWork1221/android-memorytool/stargazers)
[![GitHub forks](https://img.shields.io/github/forks/Anonym0usWork1221/android-memorytool.svg)](https://github.com/Anonym0usWork1221/android-memorytool/network/members)
[![GitHub issues](https://img.shields.io/github/issues/Anonym0usWork1221/android-memorytool.svg)](https://github.com/Anonym0usWork1221/android-memorytool/issues)
[![GitHub watchers](https://img.shields.io/github/watchers/Anonym0usWork1221/android-memorytool.svg)](https://github.com/Anonym0usWork1221/android-memorytool/watchers)
[![Python](https://img.shields.io/badge/language-Python%203-blue.svg)](https://www.python.org)
[![GPT_LICENSE](https://img.shields.io/badge/license-GPL-red.svg)](https://opensource.org/licenses/)

-----------


AndroidMemoryTool is a memory reader and writer tool designed for android and linux os's 
.This Tool is written in python using ctypes not affective as c.
If you find any bug or not working function you can contact me. 

 *  date   : 2022/03/23
 *  author : **__Abdul Moez__**
 *  Version : 0.3
 *  Study  : UnderGraduate in GCU Lahore, Pakistan
 *  repo  : https://github.com/Anonym0usWork1221/android-memorytool
 
 GNU General Public License

 Copyright (c) 2022 AbdulMoez

# Note
    1. This documentation is only for 0.3 version
    2. You can find old version on pypi if you want to use it
    3. This version is totally different from old

# Version 3.0
    1. Removed complexity to use tool
    2. Implemented Oop Structures
    3. Added new data types for libs direct read/write
    4. Added raw dump support
    5. Fixed the bugs
    6. Fixed Search and Reading returnig offset issues
    7. Added Refiners inorder to check the changed in old values
    

Requirments
-----------

* Python 3.x

* Android Requirments -> Rooted Device Needed

Installation
----------------------------------------
    Simply install it by pip and use it in your project
        pip install androidMemoryTool==0.3

    Or by cloning and then run command
        pip install .

    Project live at   
        https://pypi.org/project/androidMemoryTool/0.3/


Memory Tool with example which can be found in the `Android-Py-Cheats-Script @ 9d2520e` sub folder.

## Documentation  

* Getting Process ID

    ```py
    from androidMemoryTool import AndroidMemoryTool
    tool = AndroidMemoryTool.get_pid('ac_client') # for android use package name e.g(com.app.org)
    print(tool)

    ```
* Getting Module Base

    ```py
    from androidMemoryTool import AndroidMemoryTool
    pid = AndroidMemoryTool.get_pid('ac_client')
    base_addr = AndroidMemoryTool.get_module_base_address(pid, "client.so")
    print(base_addr)

    ```

* Searching and Read process memory

    ```py
    from androidMemoryTool import AndroidMemoryTool

    # initialize tool
    tool = AndroidMemoryTool(PKG="ac_client", TYPE=AndroidMemoryTool.DataTypes.DWORD, SPEED_MODE=False, WORKERS=55,
                            pMAP=AndroidMemoryTool.PMAP(ALL=True))
    values = tool.read_value(100)
    founded_offsets = values[0]
    founded_values = values[1]
    print(founded_values)
    print(founded_offsets)
    ```

* Search and Write process memory

    ```py
    from androidMemoryTool import AndroidMemoryTool

    # initialize tool
    tool = AndroidMemoryTool(PKG="ac_client", TYPE=AndroidMemoryTool.DataTypes.DWORD, SPEED_MODE=False, WORKERS=55,
                            pMAP=AndroidMemoryTool.PMAP(ALL=True))

    values1 = tool.read_write_value(100, 10)
    print(values1)
    ```

* Read address value
    ```py
    from androidMemoryTool import AndroidMemoryTool
    pid = AndroidMemoryTool.get_pid('ac_client')
    base_addr = AndroidMemoryTool.get_module_base_address(pid, "client.so")
    tool = AndroidMemoryTool(PKG="ac_client", TYPE=AndroidMemoryTool.DataTypes.DWORD)
    values1 = tool.read_lib(base_addr, 0xfff150d)
    print(values1)

    ```

* Write address value
    ```py
    from androidMemoryTool import AndroidMemoryTool
    pid = AndroidMemoryTool.get_pid('ac_client')
    base_addr = AndroidMemoryTool.get_module_base_address(pid, "client.so")
    tool = AndroidMemoryTool(PKG="ac_client", TYPE=AndroidMemoryTool.DataTypes.DWORD)
    values1 = tool.write_lib(base_addr, 0xfff150d, 58)
    print(values1)

    ```

* Raw Dump Process memory 
    ```py
    from androidMemoryTool import AndroidMemoryTool
    tool = AndroidMemoryTool(PKG="ac_client")
    dump = tool.raw_dump(lib_name='client.so', path='/home/kali/Documents/')
    print(dump) # True or False

    ```

* Address Refiner 
    ```py
    from androidMemoryTool import AndroidMemoryTool
    tool = AndroidMemoryTool(PKG="ac_client", TYPE=AndroidMemoryTool.DataTypes.DWORD, SPEED_MODE=False, WORKERS=55,
                         pMAP=AndroidMemoryTool.PMAP(ALL=True))
    values = tool.read_value(100)
    founded_offsets = values[0]
    refined_address = tool.refiner_address(list_address=founded_offsets, value_to_refine=50)
    print(refined_address)

    ```


# Video Demonstration
[![usage](https://img.youtube.com/vi/vebE1Rf1ogo/0.jpg)](https://www.youtube.com/watch?v=vebE1Rf1ogo)


Supported Data Types For read/write 0.3
-------------------

All data types are signed.

| **Range** | **Name** |  **Ctype** |
| ------- | -------- | ------------|
| -2,147,483,648 to 2,147,483,647 | DWORD | signed int 
| 3.4E +/- 38 (7 digits) | FLOAT | float
| 1.7E +/- 308 (15 digits) | DOUBLE | double
| -32,768 to 32,767 | WORD | signed short int
| -128 to 127 | BYTE | signed char
| -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807 | QWORD | signed long long
| -2,147,483,648 to 2,147,483,647 | XOR | signed long
| Random | UTF-8 | Text
| Random | UTF-16LE | Text

Supported Data Types For libs direct read/write 0.3
-------------------

All data types are signed.

| **Range** | **Name** |  **Ctype** |
| ------- | -------- | ------------|
| -2,147,483,648 to 2,147,483,647 | DWORD | signed int 
| 3.4E +/- 38 (7 digits) | FLOAT | float
| 1.7E +/- 308 (15 digits) | DOUBLE | double
| -32,768 to 32,767 | WORD | signed short int
| -128 to 127 | BYTE | signed char
| -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807 | QWORD | signed long long
| -2,147,483,648 to 2,147,483,647 | XOR | signed long


Supported Map Ranges 0.3
--------------------
| **Script Name** | **Name** |  **Description** |
| ------- | -------- | ------------|
| ALL | Whole Memory | Whole Memory of current process (slow)
| C_ALLOC | C++ alloc | RAM c++ Allocated memory
| A_ANONYMOUS  | Anonymous | Range with r-w access only
| CODE_APP | Code App  | shared libs memory (dangerous)
|JAVA_HEAP|Java Heap| Java heap
|C_HEAP|C++ Heap| Heap memory of cpp
|C_DATA|C++ .data| .Data Memory
|C_BSS|C++ .bss| .bss section memory
|J_Java| Java |Java memory section
|STACK|Stack| Stack Memory
|ASHMEM|Ashmen| Ashmen Memory
|V_video|Video| Video memory range 
|B_Bad|Bad| Bad Memory (dangerous)
|CODE_SYSTEM|Code system| Code system memory (dangerous)


# Contributor

<a href = "https://github.com/Anonym0usWork1221/android-memorytool/graphs/contributors">
  <img src = "https://contrib.rocks/image?repo=Anonym0usWork1221/android-memorytool"/>
</a>


Assistance
----------
If you need assistance, you can ask for help on my mailing list:

* Email      : abdulmoez123456789@gmail.com

I also created a Discord group:

* Server     : https://discord.gg/RMNcqzmt9f


Buy Me a coffe
--------------
If you want to support me you can buy me coffe.

BitCoin_addr: ``` 19vwfRXfthPY7f2aqDBpxQvZa6AJFKcdBS ```



