Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/acuciureanu/js-maid

A rule-driven engine designed for seamless extraction of data from JavaScript files.
https://github.com/acuciureanu/js-maid

bugbounty-tool bugbountytips data-extraction javascript security-audit static-code-analyzer

Last synced: 3 months ago
JSON representation

A rule-driven engine designed for seamless extraction of data from JavaScript files.

Awesome Lists containing this project

README

        

# js-maid ๐Ÿ•ต๏ธ - Your JavaScript Investigator

js-maid started off as an idea to break down JavaScript into an AST (something like a blueprint) and then run some smart checks on it. It's a handy little tool for folks diving into code, looking for bugs, or just trying to get a grip on what's happening under the hood.

## Usage

```sh
Usage: js-maid [--unpack] [--deobfuscate] [--unminify] [--unpackOutputDir ]

Options:
--unpack Unpack the code before analysis
--deobfuscate Deobfuscate the code before analysis
--unminify Unminify the code before analysis
--unpackOutputDir Specify the output directory for unpacked files (default: "unpacked")

Note: Use the flags to enable specific features as needed.
```

## Download latest compiled binaries

If you want to run the tool straight away, there are compiled binaries for you [here](https://github.com/acuciureanu/js-maid/releases/latest)

## Features ๐ŸŒŸ

- **In-depth Analysis**: Thorough investigation of JavaScript code to identify patterns and potential vulnerabilities.
- **Debundling**: Debundling, deobfuscation, unminifying through [webcrack](https://github.com/j4k0xb/webcrack)
- **Custom Rules**: Utilize predefined rules to enhance your code investigation.
- **Regex Guide**: Leverage detailed regex patterns to pinpoint specific code structures.

## Install Bun.sh

Check this out: [Bun.sh installation instructions](https://bun.sh/docs/installation)

## Installation ๐Ÿ› 

Get started with js-maid by installing the necessary dependencies:

```bash
npm install
```

## Running js-maid ๐Ÿƒ

To start investigating your JavaScript code, run:

```bash
bun run App.ts
```

## Compilation ๐Ÿ“ฆ

Compile your findings with js-maid:

```bash
bun build App.ts --compile --outfile=js-maid
```

## Running Tests ๐Ÿงช

Ensure your code's integrity by running tests:

```bash
bun test
```

## Developer Guide ๐Ÿ“š

### Implemented Rules

- **LiteralRule**: Checks text inside quotes against patterns to find important info like secrets.

- **ReferenceResolverRule**: Tracks variable names to their values for deeper code analysis.

- **TemplateLiteralRule**: Builds and analyzes dynamic strings with variables for pattern matching.

- More rules to come. The tool is not perfect and there are corner cases that I didn't know about.

## MatchingRule Instances

In our application, we use the `MatchingRule` feature to create specific instances for different matching needs. Here are a couple of examples:

```typescript
const urlMatchingRule = new MatchingRule("endpoints", urlPattern);
const secretsMatchingRule = new MatchingRule("secrets", secretsPatterns);
```

In the above code:

- `urlMatchingRule` is a `MatchingRule` instance that matches URLs. It uses the pattern defined in `urlPattern`. The label "endpoints" is used to identify matches found with this rule.

- `secretsMatchingRule` is a `MatchingRule` instance that matches secrets. It uses the pattern defined in `secretsPatterns`. The label "secrets" is used to identify matches found with this rule.

These instances can then be used throughout the application to check if certain strings match their respective patterns. The labels ("endpoints" or "secrets") can be used to identify which rule a match was found with.

## Contributing ๐Ÿค

We welcome contributions to js-maid! Whether it's enhancing the rules, expanding the regex patterns, or improving documentation, your input is invaluable.

## License ๐Ÿ“œ

js-maid is open-source software licensed under the MIT license.

## Support ๐Ÿ’–

Love js-maid? Star this on GitHub and spread the word! Your support motivates me to continuously improve.

Dive into your JavaScript investigations with js-maid and uncover the insights you need. Happy coding!