Skip to content

Latest commit

 

History

History
125 lines (105 loc) · 6.61 KB

README.md

File metadata and controls

125 lines (105 loc) · 6.61 KB

Collector for Confluence

Collects meta-information about conducted threat modeling activities from Confluence wiki pages.

Meta-information about a Threat Modeling Activity

In the OWASP Foundation community article (Nov 2023) Threat Modeling Process, lists following meta-information for a threat model:

Information identifying the threat model typically includes the following:

  1. Application Name: The name of the application examined.
  2. Application Version: The version of the application examined.
  3. Description: A high level description of the application.
  4. Document Owner: The owner of the threat modeling document.
  5. Participants: The participants involved in the threat modeling process for this application.
  6. Reviewer: The reviewer(s) of the threat model.

However, for the purpose of metric collection for DSOMM we adjusted our information demand to:

  1. Application Name: The name of the application examined.
  2. Team Name: The name of the team that owns/maintains the application.
  3. Title: The title summarizing the scope or question of the threat modeling.
  4. Date: The date when the threat modeling activity was conducted.
  5. Links: The list of links to the threat modeling document (main source) and to supplementary reference material like:
    • recorded drawings or pictures from physical/virtual whiteboards (e.g. Miro boards)
    • resulting tickets (e.g. JIRA issues)

See also:

Quickstart

Prerequisite: Python 3 must be installed.

Installation

Steps:

  1. Clone the repository source-code
  2. Make sure all required packages are installed

Example:

git clone https://github.com/devsecopsmaturitymodel/collector-confluence.git
cd collector-confluence
pip install -r requirements.txt

Configuration

Confluence Access

We recommend to prepare a .env file and specify the confluence URL, account and credentials there.

Example file .env (with anonymized data):

CONFLUENCE_URL='https://example.atlassian.net/wiki' # change to your Confluence cloud URL
CONFLUENCE_LOGIN='[email protected]'  # change to your account name/email 
CONFLUENCE_PASSWORD=''  # fill in your API token from your Atlassian profile

However, you can also set those environment-variables separately. In case both are present, the .env file and environment-variables, then the environment-variables are finally used.

Scraping configuration

Use a YAML file to configure the label for the Confluence-search and the Confluence-space to application/team mapping, The key-value pair for space_mapping is required, the search_label defaults to 'threat-modeling'.

See example scraping_config.yaml:

space_mapping:
  MR:
    application_name: 'magic-records'
    team_name: 'magic-team'
  EK: { application_name: 'elastic-kube', team_name: 'elastic-kubernauts' }
  BED: { application_name: 'bed-beats' }
search_label: 'threat-modeling'
activity_name: 'Threat Modeling'

Git Configuration

The application is based on Github and easily adaoptable for github enterprise. Example file .env:

GIT_HUB_REPO='metricca-data'
GIT_HUB_OWNER='devsecopsmaturitymodel'

GIT_HUB_APP_ID=''
GIT_HUB_APP_PRIVATE_KEY_BASE64=''
# or
GIT_HUB_ACCESS_TOKEN='' # fine granted

Run and Deployment

Locally with python

Run the CLI app with your prepared Scraping configuration YAML as argument (e.g. on Linux and macOS):

./confluence_collector.py example/scraping_config.yaml

To see the CLI help for more options (like e.g. --out-path or --debug):

./confluence_collector.py --help

Help screen:

 Usage: confluence_collector.py [OPTIONS] SCRAPING_CONFIG                                                                                                                                                                       
                                                                                                                                                                                                                                
╭─ Arguments ───────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ *    scraping_config      PATH  [default: None] [required]                                                        │
╰───────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
╭─ Options ─────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ --out-path                  PATH  [default: /tmp/collector-confluence]                                                                  │
│ --debug       --no-debug          [default: debug]                                                                │
│ --help                            Show this message and exit.                                                     │
╰───────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯

Docker

# Please cd into this directory and fill out .env
docker build -t wurstbrot/collector-confluence .
docker run --env-file .env --volume ./scraping_config.yaml:/app/scraping_config.yaml wurstbrot/collector-confluence

Kubernetes

TODO: Kustomize