Commit 23c8ed48 authored by Cameron Swords's avatar Cameron Swords Committed by Stan Hu

Expose generic vulnerability finding details

parent 7676c7eb
......@@ -131,6 +131,18 @@ Example response:
"version": "1.5.0"
}
},
"details": {
"custom_field": {
"name": "URLs",
"type": "list",
"items": [
{
"type": "url",
"href": "http://site.com/page/1"
}
]
}
},
"solution": "Upgrade to fixed version.\r\n",
"blob_path": "/tests/yarn-remediation-test/blob/cc6c4a0778460455ae5d16ca7025ca9ca1ca75ac/yarn.lock"
}
......
# frozen_string_literal: true
module VulnerabilitiesHelper
FINDING_FIELDS = %i[metadata identifiers name issue_feedback merge_request_feedback project project_fingerprint scanner uuid].freeze
FINDING_FIELDS = %i[metadata identifiers name issue_feedback merge_request_feedback project project_fingerprint scanner uuid details].freeze
def vulnerability_details_json(vulnerability, pipeline)
vulnerability_details(vulnerability, pipeline).to_json
......
......@@ -41,6 +41,7 @@ class Vulnerabilities::FindingEntity < Grape::Entity
expose(:assets) { |model, _| model.assets }
end
expose :details
expose :state
expose :scan
......
---
title: Return generic vulnerability details in the response of the vulnerability_finding
endpoint
merge_request: 56448
author:
type: changed
......@@ -59,6 +59,17 @@ FactoryBot.define do
confidence { :medium }
scanner factory: :vulnerabilities_scanner
metadata_version { 'sast:1.0' }
details do
{
url: {
name: 'URL',
type: 'url',
href: 'http://site.com'
}
}
end
raw_metadata do
{
description: 'The cipher does not provide data integrity update 1',
......
......@@ -39,10 +39,11 @@ RSpec.describe VulnerabilitiesHelper do
:project,
:remediations,
:solution,
:uuid)
:uuid,
:details)
end
let(:desired_serializer_fields) { %i[metadata identifiers name issue_feedback merge_request_feedback project project_fingerprint scanner uuid] }
let(:desired_serializer_fields) { %i[metadata identifiers name issue_feedback merge_request_feedback project project_fingerprint scanner uuid details] }
before do
vulnerability_serializer_stub = instance_double("VulnerabilitySerializer")
......@@ -268,7 +269,8 @@ RSpec.describe VulnerabilitiesHelper do
evidence_source: anything,
assets: kind_of(Array),
supporting_messages: kind_of(Array),
uuid: kind_of(String)
uuid: kind_of(String),
details: kind_of(Hash)
)
expect(subject[:location]['blob_path']).to match(kind_of(String))
......
......@@ -60,6 +60,7 @@ RSpec.describe Vulnerabilities::FindingEntity do
expect(subject).to include(:scan)
expect(subject).to include(:assets, :evidence_source, :supporting_messages)
expect(subject).to include(:uuid)
expect(subject).to include(:details)
end
context 'when not allowed to admin vulnerability feedback' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment