description |
---|
A query language for repositories of code |
Follow the Getting Started documentation to install the precompiled binary:
{% embed url="https://docs.github.com/en/code-security/codeql-cli/using-the-codeql-cli/getting-started-with-the-codeql-cli" %} Getting Started with installing the CodeQL CLI and some other useful tools {% endembed %}
On the releases page, you should download the "CodeQL Bundle" from any of the assets, likely codeql-bundle-linux64.tar.gz
.
In case you need more queries for different languages not already included in the bundle, try downloading a precompiled pack of queries per language:
{% code title="Example" %}
codeql pack download codeql/python-queries
{% endcode %}
{% embed url="https://docs.github.com/en/code-security/codeql-cli/using-the-codeql-cli/creating-codeql-databases" %} Create a CodeQL database from a repository to analyze later with queries {% endembed %}
Create a database with the following command, inside the root folder of the project you are trying to analyze. <database>
will be the output directory, and <language-identifier>
is one of the supported languages that the project is written in.
codeql database create <database> --language=<language-identifier>
{% code title="Example" %}
codeql database create .codeql --language=python
{% endcode %}
{% hint style="info" %}
Tip: For some compiled languages like java
, the autobuilder may not be able to build your source code to index it. You can choose for --build-mode=none
to disable building the project and just look at the source files.
{% endhint %}
{% embed url="https://docs.github.com/en/code-security/codeql-cli/using-the-codeql-cli/analyzing-databases-with-the-codeql-cli" %} Use queries to analyze a CodeQL database {% endembed %}
When you have created a database, use the analyze
command to run queries on a database. <format>
can be one of the possible multiple formats, like csv
or sarif-latest
.
codeql database analyze <database> --format=<format> --output <output-file>
{% code title="Example" %}
codeql database analyze .codeql --format=sarif-latest --output codeql.sarif
{% endcode %}
You can view a CSV file with any spreadsheet program, but the most useful format is .sarif
. To view the findings and locations in the code you can use the Sarif Viewer VSCode extension.
{% embed url="https://marketplace.visualstudio.com/items?itemName=MS-SarifVSCode.sarif-viewer" %} Download SARIF Viewer extension by Microsoft DevLabs {% endembed %}