Workflows

Updating the Greenbone Community Containers

To update the Greenbone Community Containers to the latest version, it is required to pull the images and restart the containers which have new images. This can be done with:

Downloading the Greenbone Community Containers
docker compose -f $DOWNLOAD_DIR/docker-compose.yml pull
Starting the Greenbone Community Containers
docker compose -f $DOWNLOAD_DIR/docker-compose.yml up -d

Performing a Feed Synchronization

For the actual vulnerability scanning, Vulnerability Tests, security information like CVEs, port lists and scan configurations are required. All this data is provided by the Greenbone Community Feed via dedicated data container images.

A feed synchronization always consists of two parts:

  1. Downloading the changes via pulling new container images

  2. Loading the changes into memory and a database by a daemon

Both steps may take a while, from several minutes up to hours, especially for the initial synchronization. Only if both steps are finished, the synchronized data is up-to-date and can be used.

The first step is done via the docker compose pull. The second step is done automatically when the daemons are running.

Downloading the Feed Changes

The data of the Greenbone Community Feed is provided via several container images. When these images are started, they copy the data into the used docker volumes automatically. Afterwards, the data is picked up from the volumes by the running daemons.

To download the latest feed data container images run

Downloading the Greenbone Community Edition feed data containers
docker compose -f $DOWNLOAD_DIR/docker-compose.yml pull notus-data vulnerability-tests scap-data dfn-cert-data cert-bund-data report-formats data-objects

To copy the data from the images to the volumes run

Starting the Greenbone Community feed data containers
docker compose -f $DOWNLOAD_DIR/docker-compose.yml up -d notus-data vulnerability-tests scap-data dfn-cert-data cert-bund-data report-formats data-objects

Loading the Feed Changes

Important

When feed content has been downloaded, the new data must be loaded by the corresponding daemons. This may take several minutes up to hours, especially for the initial loading of the data. Without loaded data, scans will contain incomplete and erroneous results.

After the Greenbone Community Containers have been started, the running daemons will always pick up the feed content and load the data automatically.

Vulnerability Tests Data

If the log (of ospd-openvas) contains the following output, the OpenVAS Scanner starts to load the new VT data:

ospd-openvas VT loading log message
Loading VTs. Scans will be [requested|queued] until VTs are loaded. This may
take a few minutes, please wait...

The loading of the VT data is finished if the log message can be found:

ospd-openvas VTs loading finished log message
Finished loading VTs. The VT cache has been updated from version X to Y.

After the scanner is aware of the VT data, the data will be requested by gvmd. This will result in the following log message:

gvmd VTs loading log message
OSP service has different VT status (version X) from database (version (Y), Z VTs). Starting update ...

When gvmd has finished loading all VTs, the following message appears:

gvmd VTs loading finished log message
Updating VTs in database ... done (X VTs).

SCAP Data

gvmd starts loading the SCAP data containing CPE and CVE information when the following message can be found in the logs:

gvmd SCAP data loading log message
update_scap: Updating data from feed

The SCAP data is loaded and the synchronization is finished when the (gvmd) log contains the following message:

gvmd SCAP data loading finished log message
update_scap_end: Updating SCAP info succeeded

CERT Data

gvmd starts loading the CERT data containing DFN-CERT and CERT-Bund advisories when the following message can be found in the logs:

gvmd CERT data loading log message
sync_cert: Updating data from feed

The CERT data is loaded and the synchronization is finished when the (gvmd) log contains the following message:

gvmd CERT data finished loading log message
sync_cert: Updating CERT info succeeded.

GVMD Data

The log contains several messages when the gvmd data is loaded. For port lists, these messages are similar to:

gvmd port list loaded log message
Port list All IANA assigned TCP (33d0cd82-57c6-11e1-8ed1-406186ea4fc5) has been created by admin

For report formats:

gvmd report format loaded log message
Report format XML (a994b278-1f62-11e1-96ac-406186ea4fc5) has been created by admin

Hint

Scan Configs can only be loaded if the VT data is available in gvmd and a Feed Import Owner is set.

For scan configs:

gvmd scan config loaded log message
Scan config Full and fast (daba56c8-73ec-11df-a475-002264764cea) has been created by admin

Accessing the Web Interface Remotely

When using the docker compose file, the web server is configured to listen only on the local address of the host (127.0.0.1). To allow remote access on all interfaces of the host, the compose file must be modified to configure the web server gsad to listen on all network interfaces.

The following change of the docker compose file must be applied:

Allowing access on all host interfaces
...
  gsa:
    image: greenbone/gsa:stable
    restart: on-failure
    ports:
-      - 127.0.0.1:9392:80
+      - 9392:80
    volumes:
      - gvmd_socket_vol:/run/gvmd
    depends_on:
      - gvmd
...

Starting from Scratch

To start from scratch, the containers must be stopped. Afterwards, the containers and volumes must be removed to delete all data. All this can be done by running:

Remove containers and volumes (all data)
docker compose -f $DOWNLOAD_DIR/docker-compose.yml down -v

Gaining a Terminal for a Container

If you want to debug something in a container, install additional software, take a look at the file content, or change some configuration, it is possible to gain shell access to a container.

To access a container with a bash shell as a root user, you can run:

Gain a Terminal for a Container
docker compose -f $DOWNLOAD_DIR/docker-compose.yml exec <container-name> /bin/bash

Afterwards, you can execute standard bash commands within the running container.

Using gvm-tools for CLI access

To query data or control gvmd and ospd-openvas via CLI, gvm-tools can be used. gvm-tools is provided in the gvm-tools container. This container can be started with:

Start container for gvm-tools CLI access
docker compose -f $DOWNLOAD_DIR/docker-compose.yml run --rm gvm-tools

Afterwards, a bash shell is provided and gvm-cli, gvm-pyshell or gvm-script can be run. For example:

Query gvmd version via gvm-cli
gvm-cli --gmp-username admin socket --pretty --xml "<get_version/>"

Exposing gvmd Unix socket for GMP Access

To enable the use of the protocol GMP provided by gvmd from the docker host, a bind mount must be used for the /run/gvmd directory. To make the gvmd Unix socket available, a directory must be created first and the permissions must be adjusted.

mkdir -p /tmp/gvm/gvmd
chmod -R 777 /tmp/gvm

In the next step, the docker compose file must be changed as follows:

  gvmd:
    image: greenbone/gvmd:stable
    restart: on-failure
    volumes:
       - gvmd_data_vol:/var/lib/gvm
       - vt_data_vol:/var/lib/openvas
       - psql_data_vol:/var/lib/postgresql
-      - gvmd_socket_vol:/run/gvmd
+      - /tmp/gvm/gvmd:/run/gvmd
       - ospd_openvas_socket_vol:/run/ospd
       - psql_socket_vol:/var/run/postgresql
     depends_on:
      - pg-gvm

...

  gsa:
    image: greenbone/gsa:stable
    restart: on-failure
     ports:
       - 9392:80
     volumes:
-      - gvmd_socket_vol:/run/gvmd
+      - /tmp/gvm/gvmd:/run/gvmd
     depends_on:
       - gvmd

After restarting the containers with

docker compose -f $DOWNLOAD_DIR/docker-compose.yml up -d

the Unix socket should be available at /tmp/gvm/gvmd/gvmd.sock. For example, to use the socket with gvm-tools, the following command can be executed:

gvm-cli socket --socketpath /tmp/gvm/gvmd/gvmd.sock --pretty --xml "<get_version/>"

Setting up a mail transport agent inside Docker container

gvmd uses the msmtp client as MTA. It can be configured with environment variables within compose file or command line. Available variables (for detailed explanation refer to msmtp documentation, note that not all mstmp options implemented in gvmd container):

  • MTA_HOST: The SMTP server to send the mail to. (Mandatory parameter).

  • MTA_PORT: The port that the SMTP server listens on. (default = ‘25’).

  • MTA_TLS: Enable or disable TLS (on|off’).

  • MTA_STARTTLS: TLS variant: start TLS from within the session (‘on’, default), or tunnel the session through TLS (‘off’).

  • MTA_TLS_CERTCHECK: Enable or disable checks of the server certificate. (WARNING: When the checks are disabled, TLS sessions will not be secure!) (‘on’|’off’).

  • MTA_AUTH: Enable or disable authentication and optionally choose a method to use (‘on’|’off’|’method’).

  • MTA_USER: Username for authentication.

  • MTA_PASSWORD: Password for authentication.

  • MTA_FROM: Set the envelope-from address.

  • MTA_LOGFILE: Enable logging to the specified file.

Examples:

Use a local network relay without authorization
...
  gvmd:
    image: registry.community.greenbone.net/community/gvmd:stable
    environment:
      - MTA_HOST=postfix-server.example.org
      - MTA_PORT=25
      - MTA_TLS=off
      - MTA_STARTTLS=off
      - MTA_AUTH=off
...
Use the Google Mail services with SSL and authorization
...
  gvmd:
    image: registry.community.greenbone.net/community/gvmd:stable
    environment:
      - MTA_HOST=smtp.gmail.com
      - MTA_PORT=587
      - MTA_TLS=on
      - MTA_STARTTLS=on
      - MTA_AUTH=on
      - MTA_USER=<username>
      - MTA_FROM=<username>@gmail.com
      - MTA_PASSWORD=<some_password>
...

Performing a Manual Feed Sync

It is possible to do a manual feed sync using rsync instead of pulling the current feed content via the newest container images.

Warning

Please be aware that the manually synced data will be overridden if the data containers are (re-)started.

For the manual feed sync, the greenbone-feed-sync script will be used. The greenbone-feed-sync script is also provided via a container image. Using the container image requires extending the docker compose file as follows:

Extending the docker compose file for performing a manual feed sync using the greenbone-feed-sync script
...
  greenbone-feed-sync:
    image: registry.community.greenbone.net/community/greenbone-feed-sync
    volumes:
      - vt_data_vol:/var/lib/openvas/plugins
      - notus_data_vol:/var/lib/notus
      - gvmd_data_vol:/var/lib/gvm
      - scap_data_vol:/var/lib/gvm/scap-data
      - cert_data_vol:/var/lib/gvm/cert-data
      - data_objects_vol:/var/lib/gvm/data-objects/gvmd
...

Syncing Vulnerability Tests

VT data contains .nasl and .notus files for creating results during a vulnerability scan.

Downloading NASL VTs processed by the ospd-openvas scanner, this will take a while.
docker compose -f $DOWNLOAD_DIR/docker-compose.yml \
    run --rm greenbone-feed-sync greenbone-feed-sync --type nasl
Downloading notus VTs processed for local security checks, this will take a while.
docker compose -f $DOWNLOAD_DIR/docker-compose.yml \
    run --rm greenbone-feed-sync greenbone-feed-sync --type notus

Syncing SCAP, CERT and GVMD Data

SCAP data contains CPE and CVE information.

Downloading SCAP data processed by gvmd, this will take a while
docker compose -f $DOWNLOAD_DIR/docker-compose.yml \
    run --rm greenbone-feed-sync greenbone-feed-sync --type scap

CERT data contains vulnerability information from the German DFN-CERT and CERT-Bund agencies.

Downloading CERT data processed by gvmd
docker compose -f $DOWNLOAD_DIR/docker-compose.yml \
    run --rm greenbone-feed-sync greenbone-feed-sync --type cert

gvmd data (or also called data-objects) are scan configurations, compliance policies, port lists and report formats.

Downloading data objects processed by gvmd
docker compose -f $DOWNLOAD_DIR/docker-compose.yml \
    run --rm greenbone-feed-sync greenbone-feed-sync --type gvmd-data

Setting up SSL/TLS for GSA

Enabling SSL/TLS for the the web interface (GSA) requires generating a private key and public certificate, and adjusting the gsa container settings in the docker-compose.yml file.

As of September 2020, the maximum validity period for publicly trusted SSL/TLS certificates is 398 days. An expiration date of more than 397 days is not valid and may cause some browsers to block the connection. OpenSSL can be used to generate the private key and certificate:

openssl req -x509 -newkey rsa:4096 -keyout serverkey.pem -out servercert.pem -nodes -days 397

The user that executes the docker compose command must have read access to the private key and certificate. So, they must be placed in an appropriate location such as the user’s home directory or the tmp directory.

mkdir $HOME/.ssl && mv serverkey.pem servercert.pem $HOME/.ssl

Finally, the GSA configuration in the docker-compose.yml file must be modified to enable SSL/TLS. The changes include:

  1. Setting the GSAD_ARGS environment variable to initialize SSL/TLS. In the example below, three arguments are set. A complete list of GSAD arguments are in the gsad manpage (execute gsad --help from within the GSA container), and in the gsad documentation in its GitHub repository. The arguments used in this example are:

    • --no-redirect: Don’t redirect HTTP to HTTPS and only allow HTTPS connections to the web interface

    • --http-sts: Enables HSTS (HTTP Strict Transport Security) for the GSAD web-server

    • --gnutls-priorities: Disables insecure versions of TLS (1.0 and 1.1)

  2. Copying the private key and certificate files from the host system into the GSA container upon initialization.

  3. Changing the web interface port to the standard SSL/TLS port 443 and optionally enabling remote access

Sample gsa container settings to enable SSL/TLS:

gsa:
  image: registry.community.greenbone.net/community/gsa:stable
  restart: on-failure
+ environment:
+   - GSAD_ARGS=--no-redirect --http-sts --gnutls-priorities=SECURE256:-VERS-TLS-ALL:+VERS-TLS1.2:+VERS-TLS1.3
  ports:
-   - 127.0.0.1:9293:80
    # Make GSA accessible locally on port 443
+   - 127.0.0.1:443:443
    # Make GSA accessible remotely on port 443
+   - 443:443
  volumes:
    # Move the private key into the container. Replace <username> with your own.
+   - /home/<username>/.ssl/serverkey.pem:/var/lib/gvm/private/CA/serverkey.pem
    # Move the certificate into the container Replace <username> with your own.
+   - /home/<username>/.ssl/servercert.pem:/var/lib/gvm/CA/servercert.pem
    - gvmd_socket_vol:/run/gvmd
  depends_on:
    - gvmd

After modifying the docker-compose.yml file, restart the containers to enable the changes.

Restart the Greenbone Community Containers
docker compose -f $DOWNLOAD_DIR/docker-compose.yml up -d