Skip to content

Commit

Permalink
Add documentation for field types
Browse files Browse the repository at this point in the history
  • Loading branch information
MWedl committed Feb 13, 2024
1 parent 68ece09 commit a16cde2
Show file tree
Hide file tree
Showing 19 changed files with 215 additions and 4 deletions.
8 changes: 6 additions & 2 deletions docs/docs/designer/debugging.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,5 +24,9 @@ There exists no interactive CSS editor like dev tools console in browsers.
However, you can set background colors or borders on elements to see where they are positioned and how big they are, e.g.

```
{background: rgba(150,150,150,0.1)}
```
<div id="element-to-debug">...</div>
#element-to-debug {
background-color: rgba(255, 0, 0, 0.2);
}
```
205 changes: 205 additions & 0 deletions docs/docs/designer/field-types.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,205 @@
# Report Field Types

This page describes field types available in SysReptor and how to use them in reports and findings.

Report and finding definitions define what input fields are available in report sections and findings when writing report.
Fields are available as form input fields when writing reports in the web interface.
Field values are also available in Vue templates as variables.


## Common Options
All fields have the following common options:

* ID: A unique identifier for the field. This ID is used to access the field in the HTML/Vue template.
* Data Type: The data type defines the structure of the field and its allowed values. See below for a list of available data types.
* Label: The label is shown in the input form when writing a report. It is a friendly name for users to understand what the field is for.
* Required: Mark the field as required (must be filled) or optional (can be empty). If a required field is not filled out, a warning message generated before publishing the report.
* Default Value: The default value is the initial value of the field when creating a new project. Some fields support TODOs in the default value to remind the user to fill out parts of the field.


## Markdown
Markdown fields are used to write text blocks with markdown formatting.
See [Markdown Syntax](/reporting/markdown-features.md) for more information on markdown formatting.

![Markdown field](/images/fields_markdown.png)

```html title="Usage in Vue templates"
<markdown :text="report.field_markdown" />
```

## String
String fields are used to write a short, single-line text.
Compared to markdown fields, only a single line is allowed and no text formatting is available.

Options:

* Spellcheck Supported: Enable or disable spellcheck for the field. Spellchecking is only useful for fields containing natural language text (e.g. a sentance, like for `short_description`). It is not useful for fields containing URLs, IDs, codes or other non-natural language text.
* Pattern: Regex pattern to validate the input. If the input does not match the pattern, a warning message is generated before publishing the report.

![String field](/images/fields_string.png)

```html title="Usage in Vue templates"
Text: {{ report.field_string }}
```


## CVSS
CVSS fields are used to write a CVSS vector. A graphical CVSS vector editor is available in the input form.

Options:

* CVSS Version: Require a specific CVSS version (CVSS:3.1 or CVSS:4.0) or allow both versions.

![CVSS field](/images/fields_cvss.png)


The field content is a CVSS vector string or "n/a" to indicate that no CVSS vector is applicable.
The CVSS score is calculated from the vector and shown in the input form and provided in Vue templates.

```html title="Usage in Vue templates"
Vector: {{ report.field_cvss.vector }}
Score: {{ report.field_cvss.score }}
Level: {{ report.field_cvss.level }} <!-- "critical", "high", "medium", "low", "info" -->
Level (numeric): {{ report.field_cvss.level_number }} <!-- 5, 4, 3, 2, 1 -->
CVSS Version: {{ report.field_cvss.version }} <!-- "3.1", "4.0" -->
```


## Enum
Enum fields are used to select a single value from a list of predefined options.

Options:

* Choices: A list of options to choose from. Each option has a value and a label. The value is used as the field value and the label is shown in the input form.

![Enum field](/images/fields_enum.png)

```html title="Usage in Vue templates"
Value: {{ report.field_enum.value }}
Label: {{ report.field_enum.label }}
```


## Combobox
Combobox fields are a combination of an enum field and a string field. The user can select a predefined option or enter a custom value.

Options:

* Suggestions: A list of predefined texts to choose from.

![Combobox field](/images/fields_combobox.png)

```html title="Usage in Vue templates"
Text: {{ report.field_combobox }}
```


## CWE
CWE fields are used to select a CWE (Common Weakness Enumeration).
This field is similar to an enum field, but provides more information about CWEs and enhanced search capabilities.

![CWE field](/images/fields_cwe.png)

```html title="Usage in Vue templates"
ID: {{ report.field_cwe.id }} <!-- 284 -->
Value: {{ report.field_cwe.value }} <!-- "CWE-284" -->
Name: {{ report.field_cwe.name }} <!-- "Improper Access Control" -->
Description: {{ report.field_cwe.description }} <!-- "The software does not restrict or incorrectly restricts access to a resource from an unauthorized actor." -->
```

## Date
Date fields are used to select a date. A date picker is available in the input form.

![Date field](/images/fields_date.png)

Dates are stored in ISO 8601 format (YYYY-MM-DD). In Vue templates, the date can be formatted using the [`formatDate()` function](/designer/formatting-utils/#date-formatting).

```html title="Usage in Vue templates"
ISO Date: {{ report.field_date }} <!-- 2024-02-13 -->
Formatted Date: {{ formatDate(report.field_date, 'long', 'en-US') }} <!-- February 13, 2024 -->
```


## Number
Number fields are used to enter a numeric value.

![Number field](/images/fields_number.png)

```html title="Usage in Vue templates"
Value: {{ report.field_number }}
```


## Boolean
Boolean fields are used to select a true or false value. This field is represented as a checkbox in the input form.

![Boolean field](/images/fields_boolean.png)

This field is useful enable/disable parts of the report rendering or change the behavior of the report template.
Booleans values are often combined with `v-if` and `v-else` directives in Vue templates to conditionally render parts of the report.

```html title="Usage in Vue templates"
Value: {{ report.field_boolean }}
If: <div v-if="report.field_boolean">...</div><div v-else>...</div>
```


## User
User fields are used to select a user from the list of project members.
In the Vue template the whole user object is available with the user's ID, name, email, phone number, etc.

![User field definition](/images/fields_user.png)
![User field form](/images/fields_user2.png)

```html title="Usage in Vue templates"
ID: {{ report.field_user.id }}
Name: {{ report.field_user.name }}
Email: {{ report.field_user.email }}
Full Data: <pre><code>{{ report.field_user }}</code></pre> <!--
{
"id": "27a04015-353f-4237-8c71-f297c8395ad5",
"name": "John Doe",
"email": "[email protected]",
"phone": "+43 1234 5678",
"mobile": "+43 1234 5678",
"title_before": null,
"first_name": "John",
"middle_name": null,
"last_name": "Doe",
"title_after": null,
"roles": ["lead", "pentester"]
}
-->
```


## Object
Object fields are used to group multiple fields together. This is useful to structure complex data in the report.

Options:

* Properties: A list of nested fields that are part of the object. Properties can have any data type. Note: Properties are ordered by their ID in the input form.

![Object field](/images/fields_object.png)

```html title="Usage in Vue templates"
Property value: {{ report.field_object.property1 }}
Property value: {{ report.field_object.property2 }}
```


## List
List fields are used to dynamically add multiple values of a specific data type.

Options:

* Item Type: The data type of the list items. The item type can be any data type, including other lists or objects.

![List field](/images/fields_list.png)

```html title="Usage in Vue templates"
List length: {{ report.field_list.length }}
List item by index: {{ report.field_list[0] }}
Iterate over list items: <div v-for="item in report.field_list">{{ item }}</div>
```

Binary file added docs/docs/images/fields_boolean.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_combobox.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_cvss.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_cwe.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_date.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_enum.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_list.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_markdown.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_number.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_object.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_string.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_user.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/docs/images/fields_user2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion docs/docs/reporting/references.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ You can reference headings if your [design supports it](/designer/headings-and-t

```md title="Markdown"
# Findings {#findings .in-toc.numbered}
Find details in []"#findings" /> (rendered as "1 Findings").
Find details in [](#findings) (rendered as "1 Findings").
```

```html title="HTML"
Expand Down
1 change: 1 addition & 0 deletions docs/mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ nav:
- Locked Sections: reporting/locking.md
- Designing Reports:
- Designer: designer/designer.md
- Field Types: designer/field-types.md
- Page Layout: designer/page-layout.md
- Headings and ToC: designer/headings-and-table-of-contents.md
- Tables: designer/tables.md
Expand Down
2 changes: 1 addition & 1 deletion frontend/src/components/Design/InputFieldDefinition.vue
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@
@update:model-value="updateProperty('required', $event)"
:readonly="props.readonly"
label="Required"
hint="Determines whether this field is required must be filled or optional"
hint="Determines whether this field is required (must be filled) or optional (can be empty)"
/>
</v-col>

Expand Down
1 change: 1 addition & 0 deletions frontend/src/components/DynamicInputField.vue
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@
item-title="label"
item-value="value"
:clearable="!props.readonly"
spellcheck="false"
v-bind="fieldAttrs"
/>

Expand Down

0 comments on commit a16cde2

Please sign in to comment.