# Revisión de código fuente / Herramientas SAST
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥 * ¿Trabajas en una **empresa de ciberseguridad**? ¿Quieres ver tu **empresa anunciada en HackTricks**? ¿O quieres tener acceso a la **última versión de PEASS o descargar HackTricks en PDF**? ¡Consulta los [**PLANES DE SUSCRIPCIÓN**](https://github.com/sponsors/carlospolop)! * Descubre [**The PEASS Family**](https://opensea.io/collection/the-peass-family), nuestra colección exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family) * Obtén el [**swag oficial de PEASS y HackTricks**](https://peass.creator-spring.com) * **Únete al** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo de Discord**](https://discord.gg/hRep4RUj7f) o al [**grupo de Telegram**](https://t.me/peass) o **sígueme** en **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks\_live)**.** * **Comparte tus trucos de hacking enviando PRs al** [**repositorio de hacktricks**](https://github.com/carlospolop/hacktricks) **y al** [**repositorio de hacktricks-cloud**](https://github.com/carlospolop/hacktricks-cloud).
## Guía y listas de herramientas * [**https://owasp.org/www-community/Source\_Code\_Analysis\_Tools**](https://owasp.org/www-community/Source\_Code\_Analysis\_Tools) * [**https://github.com/analysis-tools-dev/static-analysis**](https://github.com/analysis-tools-dev/static-analysis) ## Herramientas multi-lenguaje ### [Naxus - AI-Gents](https://www.naxusai.com/) Hay un **paquete gratuito para revisar PRs**. ### [**Semgrep**](https://github.com/returntocorp/semgrep) Es una **herramienta de código abierto**. #### Lenguajes compatibles | Categoría | Lenguajes | | ------------ | ----------------------------------------------------------------------------------------------------- | | GA | C# · Go · Java · JavaScript · JSX · JSON · PHP · Python · Ruby · Scala · Terraform · TypeScript · TSX | | Beta | Kotlin · Rust | | Experimental | Bash · C · C++ · Clojure · Dart · Dockerfile · Elixir · HTML · Julia · Jsonnet · Lisp · | #### Inicio rápido {% code overflow="wrap" %} ```bash # Install https://github.com/returntocorp/semgrep#option-1-getting-started-from-the-cli brew install semgrep # Go to your repo code and scan cd repo semgrep scan --config auto ``` {% endcode %} También puedes usar la [**extensión de semgrep para VSCode**](https://marketplace.visualstudio.com/items?itemName=Semgrep.semgrep) para obtener los resultados dentro de VSCode. ### [**SonarQube**](https://www.sonarsource.com/products/sonarqube/downloads/) Hay una versión gratuita **instalable**. #### Inicio rápido {% code overflow="wrap" %} ```bash # Run the paltform in docker docker run -d --name sonarqube -e SONAR_ES_BOOTSTRAP_CHECKS_DISABLE=true -p 9000:9000 sonarqube:latest # Install cli tool brew install sonar-scanner # Go to localhost:9000 and login with admin:admin or admin:sonar # Generate a local project and then a TOKEN for it # Using the token and from the folder with the repo, scan it cd path/to/repo sonar-scanner \ -Dsonar.projectKey= \ -Dsonar.sources=. \ -Dsonar.host.url=http://localhost:9000 \ -Dsonar.token= ``` {% endcode %} ### CodeQL Hay una **versión gratuita instalable**. #### Instalación {% code overflow="wrap" %} ```bash # Download your release from https://github.com/github/codeql-action/releases ## Example wget https://github.com/github/codeql-action/releases/download/codeql-bundle-v2.14.3/codeql-bundle-osx64.tar.gz # Move it to the destination folder mkdir ~/codeql mv codeql-bundle* ~/codeql # Decompress it cd ~/codeql tar -xzvf codeql-bundle-*.tar.gz rm codeql-bundle-*.tar.gz # Add to path echo 'export PATH="$PATH:/Users/username/codeql/codeql"' >> ~/.zshrc # Check it's correctly installed ## Open a new terminal codeql resolve qlpacks #Get paths to QL packs ``` {% endcode %} #### Inicio rápido - Preparar la base de datos {% hint style="success" %} Lo primero que debes hacer es **preparar la base de datos** (crear el árbol de código) para que luego se ejecuten las consultas sobre ella. {% endhint %} * Puedes permitir que codeql identifique automáticamente el lenguaje del repositorio y cree la base de datos {% code overflow="wrap" %} ```bash codeql database create --language # Example codeql database create /path/repo/codeql_db --source-root /path/repo ## DB will be created in /path/repo/codeql_db ``` {% endcode %} {% hint style="danger" %} Esto **suele desencadenar un error** que indica que se especificaron más de un lenguaje (o se detectaron automáticamente). ¡**Verifica las siguientes opciones** para solucionarlo! {% endhint %} * Puedes hacer esto **indicando manualmente** el **repositorio** y el **lenguaje** ([lista de lenguajes](https://docs.github.com/en/code-security/codeql-cli/getting-started-with-the-codeql-cli/preparing-your-code-for-codeql-analysis#running-codeql-database-create)) {% code overflow="wrap" %} ```bash codeql database create --language --source-root # Example codeql database create /path/repo/codeql_db --language javascript --source-root /path/repo ## DB will be created in /path/repo/codeql_db ``` {% endcode %} * Si tu repositorio está utilizando **más de 1 lenguaje**, también puedes crear **1 base de datos por lenguaje** indicando cada lenguaje. {% code overflow="wrap" %} ```bash export GITHUB_TOKEN=ghp_32849y23hij4... codeql database create --source-root /path/to/repo --db-cluster --language "javascript,python" # Example export GITHUB_TOKEN=ghp_32849y23hij4... codeql database create /path/repo/codeql_db --source-root /path/to/repo --db-cluster --language "javascript,python" ## DBs will be created in /path/repo/codeql_db/* ``` {% endcode %} * También puedes permitir que `codeql` **identifique todos los lenguajes** por ti y cree una base de datos por cada lenguaje. Necesitas proporcionarle un **GITHUB\_TOKEN**. {% code overflow="wrap" %} ```bash export GITHUB_TOKEN=ghp_32849y23hij4... codeql database create --db-cluster --source-root # Example export GITHUB_TOKEN=ghp_32849y23hij4... codeql database create /tmp/codeql_db --db-cluster --source-root /path/repo ## DBs will be created in /path/repo/codeql_db/* ``` {% endcode %} #### Inicio rápido - Analizar el código {% hint style="success" %} Ahora finalmente es el momento de analizar el código {% endhint %} Recuerda que si utilizaste varios lenguajes, se habrá creado una **base de datos por lenguaje** en la ruta que especificaste. {% code overflow="wrap" %} ```bash # Default analysis codeql database analyze --format= --output= # Example codeql database analyze /tmp/codeql_db/javascript --format=sarif-latest --output=/tmp/graphql_results.sarif # Specify QL pack to use in the analysis codeql database analyze \ --sarif-category= \ --sarif-add-baseline-file-info \ --format= \ --output=/out/file/path> # Example codeql database analyze /tmp/codeql_db \ javascript-security-extended --sarif-category=javascript \ --sarif-add-baseline-file-info --format=sarif-latest \ --output=/tmp/sec-extended.sarif ``` {% endcode %} #### Inicio rápido - Scripted {% code overflow="wrap" %} ```bash export GITHUB_TOKEN=ghp_32849y23hij4... export REPO_PATH=/path/to/repo export OUTPUT_DIR_PATH="$REPO_PATH/codeql_results" mkdir -p "$OUTPUT_DIR_PATH" export FINAL_MSG="Results available in: " echo "Creating DB" codeql database create "$REPO_PATH/codeql_db" --db-cluster --source-root "$REPO_PATH" for db in `ls "$REPO_PATH/codeql_db"`; do echo "Analyzing $db" codeql database analyze "$REPO_PATH/codeql_db/$db" --format=sarif-latest --output="${OUTPUT_DIR_PATH}/$db).sarif" FINAL_MSG="$FINAL_MSG ${OUTPUT_DIR_PATH}/$db.sarif ," echo "" done echo $FINAL_MSG ``` {% endcode %} Puedes visualizar los hallazgos en [**https://microsoft.github.io/sarif-web-component/**](https://microsoft.github.io/sarif-web-component/) o utilizando la extensión de VSCode [**SARIF viewer**](https://marketplace.visualstudio.com/items?itemName=MS-SarifVSCode.sarif-viewer). También puedes utilizar la [**extensión de VSCode**](https://marketplace.visualstudio.com/items?itemName=GitHub.vscode-codeql) para obtener los hallazgos dentro de VSCode. Aún necesitarás crear una base de datos manualmente, pero luego puedes seleccionar cualquier archivo y hacer clic en `Click derecho` -> `CodeQL: Run Queries in Selected Files` ### [**Snyk**](https://snyk.io/product/snyk-code/) Hay una **versión gratuita instalable**. #### Inicio rápido ```bash # Install sudo npm install -g snyk # Authenticate (you can use a free account) snyk auth # Test for open source vulns & license issues snyk test [--all-projects] # Test for code vulnerabilities ## This will upload your code and you need to enable this option in: Settings > Snyk Code snyk test code # Test for vulns in images snyk container test [image] # Test for IaC vulns snyk iac test ``` También puedes usar la [**Extensión de Snyk para VSCode**](https://marketplace.visualstudio.com/items?itemName=snyk-security.snyk-vulnerability-scanner) para obtener resultados dentro de VSCode. ### [Insider](https://github.com/insidersec/insider) Es **Open Source**, pero parece **desactualizado**. #### Lenguajes compatibles Java (Maven y Android), Kotlin (Android), Swift (iOS), .NET Full Framework, C# y Javascript (Node.js). #### Inicio rápido ```bash # Check the correct release for your environment $ wget https://github.com/insidersec/insider/releases/download/2.1.0/insider_2.1.0_linux_x86_64.tar.gz $ tar -xf insider_2.1.0_linux_x86_64.tar.gz $ chmod +x insider $ ./insider --tech javascript --target ``` ### [**DeepSource**](https://deepsource.com/pricing) Gratis para **repositorios públicos**. ## NodeJS * **`yarn`** ```bash # Install brew isntall yarn # Run cd /path/to/repo yarn audit npm audit ``` * [**nodejsscan**](https://github.com/ajinabraham/nodejsscan)**:** Escáner estático de código de seguridad (SAST) para aplicaciones Node.js impulsado por [libsast](https://github.com/ajinabraham/libsast) y [semgrep](https://github.com/returntocorp/semgrep). ```bash # Install & run docker run -it -p 9090:9090 opensecurity/nodejsscan:latest # Got to localhost:9090 # Upload a zip file with the code ``` * [**RetireJS**](https://github.com/RetireJS/retire.js)**:** El objetivo de Retire.js es ayudarte a detectar el uso de versiones de bibliotecas JS con vulnerabilidades conocidas. ```bash # Install npm install -g retire # Run cd /path/to/repo retire --colors ``` ## Electron * [**electronegativity**](https://github.com/doyensec/electronegativity)**:** Es una herramienta para identificar configuraciones incorrectas y patrones de seguridad en aplicaciones basadas en Electron. ## Python * [**Bandit**](https://github.com/PyCQA/bandit)**:** Bandit es una herramienta diseñada para encontrar problemas de seguridad comunes en el código de Python. Para hacer esto, Bandit procesa cada archivo, construye un AST a partir de él y ejecuta complementos apropiados contra los nodos AST. Una vez que Bandit ha terminado de escanear todos los archivos, genera un informe. ```bash # Install pip3 install bandit # Run bandit -r ``` * [**safety**](https://github.com/pyupio/safety): Safety verifica las dependencias de Python en busca de vulnerabilidades de seguridad conocidas y sugiere las soluciones adecuadas para las vulnerabilidades detectadas. Safety se puede ejecutar en máquinas de desarrollo, en tuberías de CI/CD y en sistemas de producción. ```bash # Install pip install safety # Run safety check ``` * [~~**Pyt**~~](https://github.com/python-security/pyt): Sin mantenimiento ## .NET ```bash # dnSpy https://github.com/0xd4d/dnSpy # .NET compilation C:\Windows\Microsoft.NET\Framework64\v4.0.30319\csc.exe test.cs ``` ## Java Java es un lenguaje de programación de alto nivel y orientado a objetos ampliamente utilizado en el desarrollo de aplicaciones web. Es conocido por su portabilidad y su capacidad para ejecutarse en diferentes plataformas. A continuación se presentan algunas herramientas de revisión de código que pueden ser útiles para realizar pruebas de penetración en aplicaciones web escritas en Java. ### FindBugs FindBugs es una herramienta de análisis estático de código que busca defectos comunes en el código Java. Puede detectar errores de programación, vulnerabilidades de seguridad y malas prácticas de codificación. FindBugs utiliza un enfoque basado en patrones para identificar problemas en el código fuente y proporciona sugerencias para corregirlos. ### PMD PMD es otra herramienta de análisis estático de código que se utiliza para encontrar problemas en el código Java. Puede detectar errores de programación, código duplicado, malas prácticas de codificación y otros problemas relacionados con la calidad del código. PMD utiliza reglas predefinidas y personalizables para analizar el código fuente y proporciona informes detallados sobre los problemas encontrados. ### Checkstyle Checkstyle es una herramienta de revisión de código que se utiliza para garantizar que el código Java cumpla con un conjunto de estándares de codificación predefinidos. Puede detectar problemas de estilo, convenciones de nomenclatura, errores de formato y otros aspectos relacionados con la legibilidad y mantenibilidad del código. Checkstyle utiliza reglas configurables para analizar el código fuente y proporciona informes detallados sobre los problemas encontrados. ### SonarQube SonarQube es una plataforma de análisis de código que proporciona una amplia gama de herramientas para evaluar la calidad del código Java. Puede detectar problemas de seguridad, errores de programación, malas prácticas de codificación y otros aspectos relacionados con la calidad del código. SonarQube utiliza reglas predefinidas y personalizables para analizar el código fuente y proporciona informes detallados sobre los problemas encontrados. Estas herramientas de revisión de código pueden ser útiles para identificar posibles vulnerabilidades y mejorar la calidad del código en aplicaciones web escritas en Java. Es importante utilizar estas herramientas como parte de un proceso de pruebas de penetración más amplio para garantizar la seguridad y confiabilidad de las aplicaciones. ```bash # JD-Gui https://github.com/java-decompiler/jd-gui # Java compilation step-by-step javac -source 1.8 -target 1.8 test.java mkdir META-INF echo "Main-Class: test" > META-INF/MANIFEST.MF jar cmvf META-INF/MANIFEST.MF test.jar test.class ``` | Tarea | Comando | | --------------- | --------------------------------------------------------- | | Ejecutar Jar | java -jar \[jar] | | Descomprimir Jar | unzip -d \[directorio de salida] \[jar] | | Crear Jar | jar -cmf META-INF/MANIFEST.MF \[jar de salida] \* | | Base64 SHA256 | sha256sum \[archivo] \| cut -d' ' -f1 \| xxd -r -p \| base64 | | Eliminar Firma | rm META-INF/_.SF META-INF/_.RSA META-INF/\*.DSA | | Eliminar del Jar | zip -d \[jar] \[archivo a eliminar] | | Descompilar clase | procyon -o . \[ruta de la clase] | | Descompilar Jar | procyon -jar \[jar] -o \[directorio de salida] | | Compilar clase | javac \[ruta del archivo .java] | ## Go ```bash https://github.com/securego/gosec ``` ## PHP [Psalm](https://phpmagazine.net/2018/12/find-errors-in-your-php-applications-with-psalm.html) y [PHPStan](https://phpmagazine.net/2020/09/phpstan-pro-edition-launched.html). ### Plugins de Wordpress [https://www.pluginvulnerabilities.com/plugin-security-checker/](https://www.pluginvulnerabilities.com/plugin-security-checker/) ## Solidity * [https://www.npmjs.com/package/solium](https://www.npmjs.com/package/solium) ## JavaScript ### Descubrimiento 1. Burp: * Spider y descubrir contenido * Sitemap > filtrar * Sitemap > clic derecho en el dominio > Herramientas de compromiso > Encontrar scripts 2. [WaybackURLs](https://github.com/tomnomnom/waybackurls): * `waybackurls |grep -i "\.js" |sort -u` ### Análisis estático #### Desminificar/Embellecer/Reformatear * [https://prettier.io/playground/](https://prettier.io/playground/) * [https://beautifier.io/](https://beautifier.io/) #### Desofuscar/Desempaquetar **Nota**: Es posible que no sea posible desofuscar completamente. 1. Encontrar y usar archivos .map: * Si los archivos .map están expuestos, se pueden usar para desofuscar fácilmente. * Comúnmente, foo.js.map se mapea a foo.js. Búscalos manualmente. * Usa [JS Miner](https://github.com/PortSwigger/js-miner) para buscarlos. * Asegúrate de realizar un escaneo activo. * Lee '[Consejos/Notas](https://github.com/minamo7sen/burp-JS-Miner/wiki#tips--notes)' * Si se encuentran, usa [Maximize](https://www.npmjs.com/package/maximize) para desofuscar. 2. Sin archivos .map, prueba con JSnice: * Referencias: http://jsnice.org/ y https://www.npmjs.com/package/jsnice * Consejos: * Si usas jsnice.org, haz clic en el botón de opciones junto al botón "Nicify JavaScript" y desmarca "Infer types" para reducir el desorden en el código con comentarios. * Asegúrate de no dejar líneas vacías antes del script, ya que puede afectar el proceso de desofuscación y dar resultados inexactos. 3. Usa console.log(); * Encuentra el valor de retorno al final y cámbialo por `console.log();` para que se imprima el JavaScript desofuscado en lugar de ejecutarse. * Luego, pega el JavaScript modificado (y aún ofuscado) en https://jsconsole.com/ para ver el JavaScript desofuscado registrado en la consola. * Finalmente, pega la salida desofuscada en https://prettier.io/playground/ para embellecerla y analizarla. * **Nota**: Si sigues viendo JavaScript empaquetado (pero diferente), puede estar empaquetado de forma recursiva. Repite el proceso. #### Analizar Referencias: https://medium.com/techiepedia/javascript-code-review-guide-for-bug-bounty-hunters-c95a8aa7037a Busca: * Carga anti-depuración * Angular: [enableProdMode](https://blog.nvisium.com/angular-for-pentesters-part-2) * Secretos * Usa: * [JS Miner](https://github.com/PortSwigger/js-miner) * Patrones de [RegHex](https://github.com/l4yton/RegHex) * Patrones de [gf](https://github.com/tomnomnom/gf/tree/master/examples) * Busca patrones relevantes en el diccionario: * pass, user, admin * auth, login, sign, challenge, 2fa * key, apikey, api\_key, api-key, jwt, token * secret, security, secure * ... * Revisión manual * Si se encuentra una clave de API, verifica aquí la sintaxis de uso potencial: https://github.com/streaak/keyhacks. * Funciones vulnerables * InnerHTML() - Si encuentras esto, significa que existe una posibilidad potencial de XSS si no se realiza una sanitización adecuada. Incluso si tu carga útil está sanitizada, no te preocupes. Rastrea el código para averiguar dónde se realiza la sanitización. Estúdialo e intenta evitar la sanitización. * Postmessage() - Si has leído mi publicación anterior (https://medium.com/techiepedia/what-are-sop-cors-and-ways-to-exploit-it-62a5e02100dc), te darás cuenta de que Postmessage() podría llevar a un posible problema de CORS. Si el segundo parámetro de la función está configurado como \*, eres afortunado. Consulta mi publicación anterior para comprender más sobre el mecanismo detrás de esto. * String.prototype.search() - Esta función parece normal. ¿Por qué sería una función peligrosa? Bueno, es porque algunos desarrolladores la usan para buscar la aparición de una cadena dentro de otra cadena. Sin embargo, "." se trata como comodín en esta función. Entonces, si esta función se usa como verificación de sanitización, simplemente puedes evitarla ingresando ".". Consulta el informe de Filedescryptor en hackerone: https://hackerone.com/reports/129873 * Endpoints y parámetros * Usa [LinkFinder](https://github.com/GerbenJavado/LinkFinder) y [JS Miner](https://github.com/PortSwigger/js-miner). * Bibliotecas y dependencias vulnerables * Usa [Retire.js](https://retirejs.github.io/retire.js/) y [NPM](https://snyk.io/advisor/) (desplázate hacia abajo hasta la sección de seguridad > enlace de todas las versiones). * URLs de la nube * Usa [JS Miner](https://github.com/PortSwigger/js-miner). * Subdominios * Usa [JS Miner](https://github.com/PortSwigger/js-miner). * Fallas de lógica * Obtén conciencia de la situación: * `use strict;`? * Busca controles del lado del cliente: * disable, enable, hidden, hide, show * catch, finally, throw, try * input, validate, verify, valid, correct, check, confirm, require, .. * Busca no primitivos: * function , => * class ### Análisis dinámico Referencias * https://www.youtube.com/watch?v=\_v8r\_t4v6hQ * https://blog.nvisium.com/angular-for-pentesters-part-1 * https://blog.nvisium.com/angular-for-pentesters-part-2 Herramientas * https://portswigger.net/burp/documentation/desktop/tools/dom-invader #### Referencias menos utilizadas * https://cyberchef.org/ * https://olajs.com/javascript-prettifier * https://jshint.com/ * https://github.com/jshint/jshint/
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥 * ¿Trabajas en una **empresa de ciberseguridad**? ¿Quieres ver tu **empresa anunciada en HackTricks**? ¿O quieres tener acceso a la **última versión de PEASS o descargar HackTricks en PDF**? ¡Consulta los [**PLANES DE SUSCRIPCIÓN**](https://github.com/sponsors/carlospolop)! * Descubre [**The PEASS Family**](https://opensea.io/collection/the-peass-family), nuestra colección exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family) * Obtén el [**merchandising oficial de PEASS y HackTricks**](https://peass.creator-spring.com) * **Únete al** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo de Discord**](https://discord.gg/hRep4RUj7f) o al [**grupo de Telegram**](https://t.me/peass) o **sígueme** en **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks\_live)**.** * **Comparte tus trucos de hacking enviando PRs al** [**repositorio de hacktricks**](https://github.com/carlospolop/hacktricks) **y al** [**repositorio de hacktricks-cloud**](https://github.com/carlospolop/hacktricks-cloud).