Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
f4e84c57
Commit
f4e84c57
authored
Oct 26, 2020
by
Michael Eddington
Committed by
James Lopez
Oct 26, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add new DAST schema fields to backend for API Fuzzing
parent
a5d51a14
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
3951 additions
and
1600 deletions
+3951
-1600
ee/app/helpers/vulnerabilities_helper.rb
ee/app/helpers/vulnerabilities_helper.rb
+4
-1
ee/app/models/vulnerabilities/finding.rb
ee/app/models/vulnerabilities/finding.rb
+68
-10
ee/app/serializers/vulnerabilities/finding_entity.rb
ee/app/serializers/vulnerabilities/finding_entity.rb
+3
-0
ee/app/serializers/vulnerabilities/request_entity.rb
ee/app/serializers/vulnerabilities/request_entity.rb
+1
-0
ee/app/serializers/vulnerabilities/response_entity.rb
ee/app/serializers/vulnerabilities/response_entity.rb
+1
-0
ee/changelogs/unreleased/260432-add-new-schema-fields-api-fuzzing.yml
...s/unreleased/260432-add-new-schema-fields-api-fuzzing.yml
+5
-0
ee/spec/factories/vulnerabilities/findings.rb
ee/spec/factories/vulnerabilities/findings.rb
+43
-3
ee/spec/fixtures/security_reports/master/gl-api-fuzzing-report.json
...xtures/security_reports/master/gl-api-fuzzing-report.json
+3752
-1570
ee/spec/helpers/vulnerabilities_helper_spec.rb
ee/spec/helpers/vulnerabilities_helper_spec.rb
+4
-1
ee/spec/models/vulnerabilities/finding_spec.rb
ee/spec/models/vulnerabilities/finding_spec.rb
+69
-15
ee/spec/serializers/vulnerabilities/finding_entity_spec.rb
ee/spec/serializers/vulnerabilities/finding_entity_spec.rb
+1
-0
No files found.
ee/app/helpers/vulnerabilities_helper.rb
View file @
f4e84c57
...
@@ -65,7 +65,10 @@ module VulnerabilitiesHelper
...
@@ -65,7 +65,10 @@ module VulnerabilitiesHelper
:scanner
,
:scanner
,
:solution
,
:solution
,
:request
,
:request
,
:response
:response
,
:evidence_source
,
:supporting_messages
,
:assets
)
)
if
data
[
:location
][
'file'
]
if
data
[
:location
][
'file'
]
...
...
ee/app/models/vulnerabilities/finding.rb
View file @
f4e84c57
...
@@ -263,19 +263,67 @@ module Vulnerabilities
...
@@ -263,19 +263,67 @@ module Vulnerabilities
metadata
.
dig
(
'remediations'
)
metadata
.
dig
(
'remediations'
)
end
end
def
build_evidence_request
(
data
)
return
if
data
.
nil?
{
headers:
data
.
fetch
(
'headers'
,
[]).
map
do
|
request_header
|
{
name:
request_header
[
'name'
],
value:
request_header
[
'value'
]
}
end
,
method:
data
[
'method'
],
url:
data
[
'url'
],
body:
data
[
'body'
]
}
end
def
build_evidence_response
(
data
)
return
if
data
.
nil?
{
headers:
data
.
fetch
(
'headers'
,
[]).
map
do
|
header_data
|
{
name:
header_data
[
'name'
],
value:
header_data
[
'value'
]
}
end
,
status_code:
data
[
'status_code'
],
reason_phrase:
data
[
'reason_phrase'
],
body:
data
[
'body'
]
}
end
def
build_evidence_supporting_messages
(
data
)
return
[]
if
data
.
nil?
data
.
map
do
|
message
|
{
name:
message
[
'name'
],
request:
build_evidence_request
(
message
[
'request'
]),
response:
build_evidence_response
(
message
[
'response'
])
}
end
end
def
build_evidence_source
(
data
)
return
if
data
.
nil?
{
id:
data
[
'id'
],
name:
data
[
'name'
],
url:
data
[
'url'
]
}
end
def
evidence
def
evidence
{
{
summary:
metadata
.
dig
(
'evidence'
,
'summary'
),
summary:
metadata
.
dig
(
'evidence'
,
'summary'
),
request:
{
request:
build_evidence_request
(
metadata
.
dig
(
'evidence'
,
'request'
)),
headers:
metadata
.
dig
(
'evidence'
,
'request'
,
'headers'
)
||
[],
response:
build_evidence_response
(
metadata
.
dig
(
'evidence'
,
'response'
)),
method:
metadata
.
dig
(
'evidence'
,
'request'
,
'method'
),
source:
build_evidence_source
(
metadata
.
dig
(
'evidence'
,
'source'
)),
url:
metadata
.
dig
(
'evidence'
,
'request'
,
'url'
)
supporting_messages:
build_evidence_supporting_messages
(
metadata
.
dig
(
'evidence'
,
'supporting_messages'
))
},
response:
{
headers:
metadata
.
dig
(
'evidence'
,
'response'
,
'headers'
)
||
[],
status_code:
metadata
.
dig
(
'evidence'
,
'response'
,
'status_code'
),
reason_phrase:
metadata
.
dig
(
'evidence'
,
'response'
,
'reason_phrase'
)
}
}
}
end
end
...
@@ -295,6 +343,16 @@ module Vulnerabilities
...
@@ -295,6 +343,16 @@ module Vulnerabilities
identifiers
.
select
(
&
:other?
).
map
(
&
:name
)
identifiers
.
select
(
&
:other?
).
map
(
&
:name
)
end
end
def
assets
metadata
.
fetch
(
'assets'
,
[]).
map
do
|
asset_data
|
{
name:
asset_data
[
'name'
],
type:
asset_data
[
'type'
],
url:
asset_data
[
'url'
]
}
end
end
alias_method
:==
,
:eql?
# eql? is necessary in some cases like array intersection
alias_method
:==
,
:eql?
# eql? is necessary in some cases like array intersection
def
eql?
(
other
)
def
eql?
(
other
)
...
...
ee/app/serializers/vulnerabilities/finding_entity.rb
View file @
f4e84c57
...
@@ -31,6 +31,9 @@ class Vulnerabilities::FindingEntity < Grape::Entity
...
@@ -31,6 +31,9 @@ class Vulnerabilities::FindingEntity < Grape::Entity
expose
(
:evidence
)
{
|
model
,
_
|
model
.
evidence
[
:summary
]
}
expose
(
:evidence
)
{
|
model
,
_
|
model
.
evidence
[
:summary
]
}
expose
(
:request
,
using:
Vulnerabilities
::
RequestEntity
)
{
|
model
,
_
|
model
.
evidence
[
:request
]
}
expose
(
:request
,
using:
Vulnerabilities
::
RequestEntity
)
{
|
model
,
_
|
model
.
evidence
[
:request
]
}
expose
(
:response
,
using:
Vulnerabilities
::
ResponseEntity
)
{
|
model
,
_
|
model
.
evidence
[
:response
]
}
expose
(
:response
,
using:
Vulnerabilities
::
ResponseEntity
)
{
|
model
,
_
|
model
.
evidence
[
:response
]
}
expose
(
:evidence_source
)
{
|
model
,
_
|
model
.
evidence
[
:source
]
}
expose
(
:supporting_messages
)
{
|
model
,
_
|
model
.
evidence
[
:supporting_messages
]}
expose
(
:assets
)
{
|
model
,
_
|
model
.
assets
}
end
end
expose
:state
expose
:state
...
...
ee/app/serializers/vulnerabilities/request_entity.rb
View file @
f4e84c57
...
@@ -4,4 +4,5 @@ class Vulnerabilities::RequestEntity < Grape::Entity
...
@@ -4,4 +4,5 @@ class Vulnerabilities::RequestEntity < Grape::Entity
expose
:headers
expose
:headers
expose
:method
expose
:method
expose
:url
expose
:url
expose
:body
end
end
ee/app/serializers/vulnerabilities/response_entity.rb
View file @
f4e84c57
...
@@ -4,4 +4,5 @@ class Vulnerabilities::ResponseEntity < Grape::Entity
...
@@ -4,4 +4,5 @@ class Vulnerabilities::ResponseEntity < Grape::Entity
expose
:headers
expose
:headers
expose
:reason_phrase
expose
:reason_phrase
expose
:status_code
expose
:status_code
expose
:body
end
end
ee/changelogs/unreleased/260432-add-new-schema-fields-api-fuzzing.yml
0 → 100644
View file @
f4e84c57
---
title
:
Add new security report schema fields to backend for API Fuzzing
merge_request
:
44800
author
:
type
:
changed
ee/spec/factories/vulnerabilities/findings.rb
View file @
f4e84c57
...
@@ -56,18 +56,58 @@ FactoryBot.define do
...
@@ -56,18 +56,58 @@ FactoryBot.define do
url:
'https://crypto.stackexchange.com/questions/31428/pbewithmd5anddes-cipher-does-not-check-for-integrity-first'
url:
'https://crypto.stackexchange.com/questions/31428/pbewithmd5anddes-cipher-does-not-check-for-integrity-first'
}
}
],
],
assets:
[
{
type:
"postman"
,
name:
"Test Postman Collection"
,
url:
"http://localhost/test.collection"
}
],
evidence:
{
evidence:
{
summary:
'Credit card detected'
,
summary:
'Credit card detected'
,
request:
{
request:
{
headers:
[{
name:
'Accept'
,
value:
'*/*'
}],
headers:
[{
name:
'Accept'
,
value:
'*/*'
}],
method:
'GET'
,
method:
'GET'
,
url:
'http://goat:8080/WebGoat/logout'
url:
'http://goat:8080/WebGoat/logout'
,
body:
nil
},
},
response:
{
response:
{
headers:
[{
name:
'Content-Length'
,
value:
'0'
}],
headers:
[{
name:
'Content-Length'
,
value:
'0'
}],
reason_phrase:
'OK'
,
reason_phrase:
'OK'
,
status_code:
200
status_code:
200
,
body:
nil
},
source:
{
id:
'assert:Response Body Analysis'
,
name:
'Response Body Analysis'
,
url:
'htpp://hostname/documentation'
},
supporting_messages:
[
{
name:
'Origional'
,
request:
{
headers:
[{
name:
'Accept'
,
value:
'*/*'
}],
method:
'GET'
,
url:
'http://goat:8080/WebGoat/logout'
,
body:
''
}
}
},
{
name:
'Recorded'
,
request:
{
headers:
[{
name:
'Accept'
,
value:
'*/*'
}],
method:
'GET'
,
url:
'http://goat:8080/WebGoat/logout'
,
body:
''
},
response:
{
headers:
[{
name:
'Content-Length'
,
value:
'0'
}],
reason_phrase:
'OK'
,
status_code:
200
,
body:
''
}
}
]
}
}
}.
to_json
}.
to_json
end
end
...
...
ee/spec/fixtures/security_reports/master/gl-api-fuzzing-report.json
View file @
f4e84c57
This source diff could not be displayed because it is too large. You can
view the blob
instead.
ee/spec/helpers/vulnerabilities_helper_spec.rb
View file @
f4e84c57
...
@@ -161,7 +161,10 @@ RSpec.describe VulnerabilitiesHelper do
...
@@ -161,7 +161,10 @@ RSpec.describe VulnerabilitiesHelper do
evidence:
kind_of
(
String
),
evidence:
kind_of
(
String
),
scanner:
kind_of
(
Grape
::
Entity
::
Exposure
::
NestingExposure
::
OutputBuilder
),
scanner:
kind_of
(
Grape
::
Entity
::
Exposure
::
NestingExposure
::
OutputBuilder
),
request:
kind_of
(
Grape
::
Entity
::
Exposure
::
NestingExposure
::
OutputBuilder
),
request:
kind_of
(
Grape
::
Entity
::
Exposure
::
NestingExposure
::
OutputBuilder
),
response:
kind_of
(
Grape
::
Entity
::
Exposure
::
NestingExposure
::
OutputBuilder
)
response:
kind_of
(
Grape
::
Entity
::
Exposure
::
NestingExposure
::
OutputBuilder
),
evidence_source:
anything
,
assets:
kind_of
(
Array
),
supporting_messages:
kind_of
(
Array
)
)
)
expect
(
subject
[
:location
][
'blob_path'
]).
to
match
(
kind_of
(
String
))
expect
(
subject
[
:location
][
'blob_path'
]).
to
match
(
kind_of
(
String
))
...
...
ee/spec/models/vulnerabilities/finding_spec.rb
View file @
f4e84c57
...
@@ -628,15 +628,75 @@ RSpec.describe Vulnerabilities::Finding do
...
@@ -628,15 +628,75 @@ RSpec.describe Vulnerabilities::Finding do
is_expected
.
to
match
a_hash_including
(
is_expected
.
to
match
a_hash_including
(
summary:
evidence
[
'summary'
],
summary:
evidence
[
'summary'
],
request:
{
request:
{
headers:
evidence
[
'request'
][
'headers'
],
headers:
[
{
name:
evidence
[
'request'
][
'headers'
][
0
][
'name'
],
value:
evidence
[
'request'
][
'headers'
][
0
][
'value'
]
}
],
url:
evidence
[
'request'
][
'url'
],
url:
evidence
[
'request'
][
'url'
],
method:
evidence
[
'request'
][
'method'
]
method:
evidence
[
'request'
][
'method'
],
body:
evidence
[
'request'
][
'body'
]
},
},
response:
{
response:
{
headers:
evidence
[
'response'
][
'headers'
],
headers:
[
{
name:
evidence
[
'response'
][
'headers'
][
0
][
'name'
],
value:
evidence
[
'response'
][
'headers'
][
0
][
'value'
]
}
],
reason_phrase:
evidence
[
'response'
][
'reason_phrase'
],
reason_phrase:
evidence
[
'response'
][
'reason_phrase'
],
status_code:
evidence
[
'response'
][
'status_code'
]
status_code:
evidence
[
'response'
][
'status_code'
],
})
body:
evidence
[
'request'
][
'body'
]
},
source:
{
id:
evidence
.
dig
(
'source'
,
'id'
),
name:
evidence
.
dig
(
'source'
,
'name'
),
url:
evidence
.
dig
(
'source'
,
'url'
)
},
supporting_messages:
[
{
name:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'name'
),
request:
{
headers:
[
{
name:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'request'
,
'headers'
)[
0
].
dig
(
'name'
),
value:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'request'
,
'headers'
)[
0
].
dig
(
'value'
)
}
],
url:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'request'
,
'url'
),
method:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'request'
,
'method'
),
body:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'request'
,
'body'
)
},
response:
evidence
.
dig
(
'supporting_messages'
)[
0
].
dig
(
'response'
)
},
{
name:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'name'
),
request:
{
headers:
[
{
name:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'request'
,
'headers'
)[
0
].
dig
(
'name'
),
value:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'request'
,
'headers'
)[
0
].
dig
(
'value'
)
}
],
url:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'request'
,
'url'
),
method:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'request'
,
'method'
),
body:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'request'
,
'body'
)
},
response:
{
headers:
[
{
name:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'response'
,
'headers'
)[
0
].
dig
(
'name'
),
value:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'response'
,
'headers'
)[
0
].
dig
(
'value'
)
}
],
reason_phrase:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'response'
,
'reason_phrase'
),
status_code:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'response'
,
'status_code'
),
body:
evidence
.
dig
(
'supporting_messages'
)[
1
].
dig
(
'response'
,
'body'
)
}
}
]
)
end
end
end
end
...
@@ -646,16 +706,10 @@ RSpec.describe Vulnerabilities::Finding do
...
@@ -646,16 +706,10 @@ RSpec.describe Vulnerabilities::Finding do
it
do
it
do
is_expected
.
to
match
a_hash_including
(
is_expected
.
to
match
a_hash_including
(
summary:
nil
,
summary:
nil
,
request:
{
source:
nil
,
headers:
[],
supporting_messages:
[],
url:
nil
,
request:
nil
,
method:
nil
response:
nil
)
},
response:
{
headers:
[],
reason_phrase:
nil
,
status_code:
nil
})
end
end
end
end
end
end
...
...
ee/spec/serializers/vulnerabilities/finding_entity_spec.rb
View file @
f4e84c57
...
@@ -58,6 +58,7 @@ RSpec.describe Vulnerabilities::FindingEntity do
...
@@ -58,6 +58,7 @@ RSpec.describe Vulnerabilities::FindingEntity do
expect
(
subject
).
to
include
(
:description
,
:links
,
:location
,
:remediations
,
:solution
,
:evidence
)
expect
(
subject
).
to
include
(
:description
,
:links
,
:location
,
:remediations
,
:solution
,
:evidence
)
expect
(
subject
).
to
include
(
:blob_path
,
:request
,
:response
)
expect
(
subject
).
to
include
(
:blob_path
,
:request
,
:response
)
expect
(
subject
).
to
include
(
:scan
)
expect
(
subject
).
to
include
(
:scan
)
expect
(
subject
).
to
include
(
:assets
,
:evidence_source
,
:supporting_messages
)
end
end
context
'when not allowed to admin vulnerability feedback'
do
context
'when not allowed to admin vulnerability feedback'
do
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment