Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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.
- Host: GitHub
- URL: https://github.com/acuciureanu/js-maid
- Owner: acuciureanu
- License: mit
- Created: 2024-01-27T18:22:43.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-05-18T09:52:27.000Z (8 months ago)
- Last Synced: 2024-05-18T10:57:58.235Z (8 months ago)
- Topics: bugbounty-tool, bugbountytips, data-extraction, javascript, security-audit, static-code-analyzer
- Language: TypeScript
- Homepage:
- Size: 205 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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!