The PT Application Inspector plugin finds vulnerabilities and undocumented features in application source code. In addition to code analysis, built-in modules detect errors in configuration files and vulnerabilities in third-party components and libraries used in application development. The plugin supports the following languages: C#, Go, Java, JavaScript, Kotlin, PHP, Python, Ruby, SQL, Solidity, and TypeScript.
You can enable or disable the plugin in an open project by clicking the icon in the bottom right toolbar. If it is not the first time you are opening the project, the plugin is enabled automatically (scan and action history is saved). You can also set up the plugin to be automatically enabled when a new project is opened.
When the plugin is enabled, the .ai folder is created in the project. This folder contains a database, log files, and a configuration file. For Git to ignore the .ai folder, create an empty file .gitignore
in the project folder.
For the plugin to operate correctly, the PT Application Inspector code analyzer is required. You can install it automatically by clicking Download Analyzer in the pop-up notification in the IntelliJ IDEA interface or manually by downloading it from the link in the instructions below.
To manually install the code analyzer:
-
Download the archive with the analyzer using one of the links:
-
In macOS, run the following command to remove the
com.apple.quarantine
attribute:xattr -d com.apple.quarantine <analyzer_file_path.pkg>
Then run the installation file and follow the instructions.
-
In Windows and Linux, unpack the archive to one of the following locations:
-
In Windows:
%LOCALAPPDATA%\Application Inspector Analyzer
-
In Linux:
~/application-inspector-analyzer
-
You can start a project scan in the following ways:
- By clicking Scan.
- By clicking Scan Options → Full Local Scan.
- By saving project changes (if you selected On saving for the Trigger scan setting).
The scan progress is displayed in the bottom panel and in the Log tab of the PT Application Inspector panel. The first scan usually takes longer due to the initial load on the database of vulnerable components.
Scans are performed based on the default settings. You can change these settings in the .aiproj.json
configuration file. To create the .aiproj.json
file, in the File menu, select New → Aiproj File.
To exclude files or folders from scanning, use the .aiignore
file. To create the .aiignore
file, in the File menu, select New → Aiignore File. The syntax of this file is similar to the .gitignore
syntax. For more information, see git-scm.com/docs/gitignore. You can also use the SkipGitIgnoreFiles setting in the .aiproj.json
file to exclude from scanning files and folders from the .gitignore
file. By default, this setting is enabled.
To stop scanning a project, click Stop Scan in the PT Application Inspector panel or close the scan progress bar in the bottom toolbar.
You can find the list of all detected vulnerabilities in the Detected Vulnerabilities tab of the PT Application Inspector panel. If you click a vulnerability in the list, the line with its exit point gets highlighted in the code editor. If the system detected vulnerabilities that are not included in the code analyzer database, they are marked with the ?
tag. Second-order vulnerabilities are marked with the 1>2
tag.
The Description tab contains the vulnerability description with example attack scripts, fix recommendations, and links to references.
The [PT AI] Vulnerability Details panel displays additional information about the vulnerability. The Data Flow tab contains a data-flow diagram that shows how each process converts its input data to output data and how processes interact. Data-flow diagrams consist of the following sections:
- Entry point. The starting point of the control flow.
- Data entry point. The file and code line with the coordinates of the data entry.
- Data changes. The description of one or several functions that modify potentially harmful input data. This section may not be displayed on the diagram if the input data were not modified.
- Exit point. The execution line of a potentially vulnerable function. This is the exit point related to the vulnerability in the source code.
- Best place to fix. The code line best suited for patching a vulnerability. This section is displayed before the data flow.
You can go to the corresponding place in the code editor from any section of the data-flow diagram.
For vulnerabilities detected in Solidity applications using the Pygrep core, the Metavariables tab is displayed in the card instead of the Data flow tab. When scanning a project, the Pygrep core uses rules from the PT AI Enterprise Edition knowledge base or custom rules, the path to which is specified in the Solidity language settings. Each rule contains templates describing metavariables and regular expressions for finding these metavariables. A vulnerability is considered to be found if there are lines of code in which a regular expression corresponding to a metavariable is triggered.
The Exploit tab contains a test HTTP request (exploit) that can be used to exploit the vulnerability in a deployed web application. You can automatically generate an exploit by clicking Generate Exploit.
Note. To exploit a vulnerability, specify the address of the host where your web application is deployed in the .aiproj.json
file. The default value is "localhost."
Note. This feature is available in commercial versions of JetBrains IDE.
Some vulnerabilities have additional exploitation conditions displayed on the Additional Conditions tab.
When you scroll through the sections of the diagram, the vulnerability information is automatically pinned until you move on to another vulnerability. If you want to view the information about a certain vulnerability while working on the code, you can pin this vulnerability manually.
Several vulnerabilities can have the same exit point. If these vulnerabilities belong to the same type, they are grouped together and displayed as one problem with different exploitation options. You can view detailed information about such vulnerabilities in the [PT AI] Vulnerability Details panel.
Note. If you confirm one vulnerability from the group, the whole problem will be confirmed automatically. To discard an entire problem, you must discard all the vulnerabilities in the group.
The PT Application Inspector plugin contains a set of tools for managing detected vulnerabilities. With these tools, you can do the following:
- Filter vulnerabilities by severity, status, and suppression from scan results by clicking the eye button.
- Confirm, discard, and suppress vulnerabilities in their context menu in the code editor.
- Confirm and discard vulnerabilities by clicking Confirm and Discard in the [PT AI] Vulnerability Details panel.
- Perform group actions on all vulnerabilities in the file. For example, in the context menu of a vulnerability, select Confirm Vulnerability → Fix all 'Vulnerable Code' problems in file.
If a large number of vulnerabilities is detected during project scanning, you can sort them out much faster using the assistant function. The assistant gives recommendations in the following order:
- Confirm vulnerabilities that have an exploit
- Discard vulnerabilities with a detected filtering function
- Confirm or discard a group of vulnerabilities similar in type or vulnerable code
- Review vulnerability statuses assigned manually by the user
You can start the assistant from the pop-up notification that appears when the scan is completed or by clicking the Assistant button and choose to go through the whole scenario or only certain steps.
![Assistant Action](https://github.com/POSIdev-community/AI.Plugin.IntelliJ/blob/release/2.4.0/media/readme/assistant_action.gif?raw=true
You can compare results of two scans within a project. To do this, in the Scan History tab, in the context menu of the first scan, select Compare with, and then select the second scan.
With the developer mode enabled, the PT Application Inspector panel displays additional tabs: Log → Analyzer (the code analyzer log) and Log → Plugin Log (the plugin log).
In the dev_mode_config.json
configuration file, you can configure how custom log tabs are displayed. By default, the file contains the path to output the analyzer log. To add extra tabs, in the panelName field, enter a tab name, and in the pathsToLogs field, enter at least one path to the log file that will be displayed on the tab.
Example configuration file dev_mode_config.json
:
{
"logPanels": [
{
"panelName": "Analyzer",
"pathsToLogs": [
"Analyzer.log"
]
},
{
"panelName": "test",
"pathsToLogs": [
"Configuration/error.log",
"process.log"
]
}
]
}
The PT Application Inspector plugin can be integrated with PT AI Enterprise Edition. The integration allows all team members to work with the source code from different environments, which makes the development process more secure.
To configure the integration:
-
In the main menu of IntelliJ IDEA, click Tools → PT Application Inspector → Connect to PT AI Server.
-
In the Address field, specify the PT AI Enterprise Server address and click Connect.
-
Sign in to PT AI Enterprise Edition using the SSO system you set up.
-
Perform the required integration scenario:
- Upload the source code to PT AI Enterprise Server.
- Send a local project for scanning to PT AI Enterprise Server with or without saving the results on the server.
- Synchronize the results of the local scan and the scan in PT AI Enterprise Server. For more information about the integration, see the PT AI Enterprise Edition User Guide.
To configure the plugin settings, select File → Settings → Tools → PT Application Inspector.
The plugin configuration page contains the following sections of settings.
General section:
- Analyzer log level. Severity level starting from which the code analyzer events will be logged. The default value is Error.
- Trigger scan. Start scan condition: manually on clicking a start button or automatically when a project file is changed. The default value is Manually.
- Automatically enable for any project. Silent activation of the plugin when opening a project. By default, this setting is disabled.
- Use an additional tool window to view information. Displays the Data Flow,Exploit, and Additional Conditions tabs in the separate panel [PT AI] Vulnerability Details. By default, this setting is enabled.
- Allow telemetry collection. Collection of general scan information to be sent to PT AI Enterprise Edition. By default, this setting is enabled. Here you will find an example of the data that we collect. For more information, see the privacy statement.
- Use all available resources. The use of all available RAM and CPU resources to increase the scanning speed. By default, this setting is disabled.
- Number of scan history results to store. Maximum number of scan results saved in the history. The default value is No limit. If the limit is exceeded, each new scan result deletes the oldest result.
- Number of days to store log files for. The default value is 30.
- Maximum number of stored log files. The default value is 100.
PT AI Integration section:
- Server address. Address of the connected PT AI Enterprise Server.
- Notify about new scan results from the PT AI server. Toggle the display of notifications about receiving new scan results from PT AI Enterprise Server if synchronization with the project is configured. By default, this setting is enabled.
- Automatically update scan results from the PT AI server. Update scan results from PT AI Enterprise Server if synchronization with the project is configured. This setting is available if notification of new scan results is enabled.
Assistant section:
- Run the assistant. Activation of the assistant automatically after the first scan or manually by clicking Assistant. The default value is "Automatically after the first scan."
- Show recommendations on the Quick Fix menu. Displays tips from the assistant. By default, this setting is enabled.
- The number of vulnerabilities to be confirmed or discarded starting from which a notification from the assistant will be displayed. The default value is 5.
- The number of similar vulnerabilities starting from which a notification from the assistant will be displayed. The default value is 5.
Developer mode section:
- Developer mode. Advanced plugin features. By default, this setting is disabled.
For the correct operation of the PT Application Inspector plugin, the following technical requirements must be met:
- JetBrains IDE (PhpStorm, IntelliJ IDEA, WebStorm) 2023.1 or later
- 8 GB RAM
- 5 GB of free hard drive space
Supported 64-bit OS:
- Debian 11 Bullseye or later
- Fedora Workstation 38 or later
- OpenSUSE Leap 15.5 or later
- Ubuntu 22.04 LTS or later
- Ubuntu 23.04 or later
- Windows 10
- ALT Linux OS in the test mode
Supported macOS:
- Big Sur 11.5 or later
- Monterey 12.0.0 or later
By default, the PT Application Inspector plugin collects anonymous usage data and sends it to our experts so that they can better understand how to improve the product. We do not share the collected information with third parties. We do not collect source code or IP addresses. To stop the data collection, disable the Allow telemetry collection setting.