Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/corellium/ios_persistence_mapping

Accompanying code for blog post "Mapping iOS Persistence Attack Surface using Corellium"
https://github.com/corellium/ios_persistence_mapping

Last synced: 2 months ago
JSON representation

Accompanying code for blog post "Mapping iOS Persistence Attack Surface using Corellium"

Awesome Lists containing this project

README

        

# Mapping iOS Persistence Attack Surface using Corellium

Accompanying code for a [blog post](https://www.corellium.com/blog/mapping-ios-persistence).

This repository contains a `uniq_opens.txt` file as generated in the blog post. Replace this file if new data is generated.

## Setup

1. Install Neo4J Desktop or create [AuraDB](https://neo4j.com/cloud/platform/aura-graph-database/) instance
2. Run `brew install libmagic`
3. Run `python3 -m pip install -r requirements.txt` in the project root
4. Run `npm install` in the project root
5. Download and unpack the target IPSW and mount the root filesystem
6. Run `diskutil enableOwnership /Volumes//Volumes/SkyF19F77.D10D101D20D201OS` (or whatever the actual mount point is)
7. Edit the `process_opens.py` script so that `ROOT_FS_PATH` is the mount point of the filesystem
8. Edit the `process_opens.py` script to fill in the Neo4J credentials/host
9. Copy `config.json.example` to `config.json` and fill in the Corellium credentials, project name, and device UUID
10. Invoke the script: `sudo python3 process_opens.py` (as root because we enable permissions on the FS)

Once complete, validate that the data imported successfully by running this Cypher query in the Neo4J Browser:

```
MATCH (p:Process) RETURN p
```