SonarQube
Overview
This installation happens on the
dsb-hub
.
According to SonarQube's Website, SonarQube is an open-source platform used to continuously inspect the quality of code in various programming languages. It is designed to detect bugs, security vulnerabilities, and code smells, providing detailed reports to help developers maintain high standards in their codebases. SonarQube is widely used in DevSecOps environments to ensure that code remains secure, maintainable, and follows industry best practices.
Prerequisites
-
Switch to the PostgreSQL User
First, switch to thepostgres
user to perform database-related tasks:sudo -i -u postgres
-
Create a Database and User for SonarQube
Create a new PostgreSQL user and database for SonarQube:createuser sonar
createdb sonar -
Set Password and Grant Privileges
Set a password for thesonar
user and grant the necessary privileges:psql
ALTER USER sonar WITH ENCRYPTED PASSWORD 'your_password';
GRANT ALL PRIVILEGES ON DATABASE sonar TO sonar;
\c sonar
GRANT ALL ON SCHEMA public TO sonar;
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO sonar;
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO sonar;
GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public TO sonar;
GRANT USAGE ON SCHEMA public TO sonar;
GRANT CREATE ON SCHEMA public TO sonar; -
Exit PostgreSQL and Return to the Original User
Exit the PostgreSQL session and return to your original user:exit
exit -
Update the
pg_hba.conf
File
Modify thepg_hba.conf
file to configure authentication:sudo nano /etc/postgresql/16/main/pg_hba.conf
Add the following line to enable
scram-sha-256
authentication for thesonar
user:local sonar sonar scram-sha-256
Installation Steps
-
Download and Install SonarQube
Download the SonarQube package and extract it:cd /opt
sudo wget https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-10.6.0.92116.zip
sudo apt install unzip -y
sudo unzip sonarqube-10.6.0.92116.zip
sudo mv sonarqube-10.6.0.92116 sonarqube -
Create a SonarQube User
Create a dedicated user for running SonarQube and set the correct permissions:sudo adduser sonar
sudo chown -R sonar:sonar /opt/sonarqube -
Update SonarQube Database Configuration
Edit thesonar.properties
file to configure SonarQube's connection to the PostgreSQL database:sudo nano /opt/sonarqube/conf/sonar.properties
Update the PostgreSQL settings:
# PostgreSQL settings
sonar.jdbc.username=sonar
sonar.jdbc.password=your_password
sonar.jdbc.url=jdbc:postgresql://localhost/sonar -
Set Up the SonarQube Service
Create a new systemd service file for SonarQube:sudo nano /etc/systemd/system/sonarqube.service
Copy the following content into the file:
[Unit]
Description=SonarQube service
After=syslog.target network.target
[Service]
Type=forking
User=sonar
Group=sonar
ExecStart=/opt/sonarqube/bin/linux-x86-64/sonar.sh start
ExecStop=/opt/sonarqube/bin/linux-x86-64/sonar.sh stop
ExecReload=/opt/sonarqube/bin/linux-x86-64/sonar.sh restart
Restart=on-failure
[Install]
WantedBy=multi-user.target -
Reload Systemd and Start SonarQube
Reload the systemd daemon and start the SonarQube service:sudo systemctl daemon-reload
sudo systemctl start sonarqube
sudo systemctl enable sonarqube -
Confirm SonarQube is Running
Verify that SonarQube is running by opening your web browser and navigating to:http://your_ip_address:9000
Configuring SonarQube
-
Log into SonarQube and type in the default credentials (username:
admin
, password:admin
). -
Change your password to something new after the first login.
-
You will be directed to the dashboard. Click on 'Create Project':
-
Create a local project and enter
owasp-juice-shop
as the display name and project key. Set branch =master
. -
Hit next and set 'Use global setting', then hit 'Create Project'.