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
63a19a71
Commit
63a19a71
authored
May 31, 2021
by
GitLab Bot
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add latest changes from gitlab-org/security/gitlab@13-12-stable-ee
parent
66ae3887
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
66 additions
and
55 deletions
+66
-55
app/assets/javascripts/notebook/cells/markdown.vue
app/assets/javascripts/notebook/cells/markdown.vue
+1
-0
lib/gitlab/x509/signature.rb
lib/gitlab/x509/signature.rb
+7
-3
spec/frontend/notebook/cells/markdown_spec.js
spec/frontend/notebook/cells/markdown_spec.js
+12
-1
spec/lib/gitlab/x509/signature_spec.rb
spec/lib/gitlab/x509/signature_spec.rb
+39
-38
spec/tasks/gitlab/x509/update_rake_spec.rb
spec/tasks/gitlab/x509/update_rake_spec.rb
+7
-13
No files found.
app/assets/javascripts/notebook/cells/markdown.vue
View file @
63a19a71
...
@@ -195,6 +195,7 @@ export default {
...
@@ -195,6 +195,7 @@ export default {
'
var
'
,
'
var
'
,
],
],
ALLOWED_ATTR
:
[
'
class
'
,
'
style
'
,
'
href
'
,
'
src
'
],
ALLOWED_ATTR
:
[
'
class
'
,
'
style
'
,
'
href
'
,
'
src
'
],
ALLOW_DATA_ATTR
:
false
,
});
});
},
},
},
},
...
...
lib/gitlab/x509/signature.rb
View file @
63a19a71
...
@@ -23,7 +23,7 @@ module Gitlab
...
@@ -23,7 +23,7 @@ module Gitlab
end
end
def
user
def
user
User
.
find_by_any_email
(
@email
)
strong_memoize
(
:user
)
{
User
.
find_by_any_email
(
@email
)
}
end
end
def
verified_signature
def
verified_signature
...
@@ -31,9 +31,13 @@ module Gitlab
...
@@ -31,9 +31,13 @@ module Gitlab
end
end
def
verification_status
def
verification_status
return
:unverified
if
x509_certificate
.
nil?
||
x509_certificate
.
revoked?
return
:unverified
if
x509_certificate
.
nil?
||
x509_certificate
.
revoked?
||
!
verified_signature
||
user
.
nil?
if
verified_signature
&&
certificate_email
==
@email
if
user
.
verified_emails
.
include?
(
@email
)
&&
certificate_email
==
@email
:verified
:verified
else
else
:unverified
:unverified
...
...
spec/frontend/notebook/cells/markdown_spec.js
View file @
63a19a71
...
@@ -39,7 +39,7 @@ describe('Markdown component', () => {
...
@@ -39,7 +39,7 @@ describe('Markdown component', () => {
expect
(
vm
.
$el
.
querySelector
(
'
.markdown h1
'
)).
not
.
toBeNull
();
expect
(
vm
.
$el
.
querySelector
(
'
.markdown h1
'
)).
not
.
toBeNull
();
});
});
it
(
'
sanitizes output
'
,
async
()
=>
{
it
(
'
sanitizes
Markdown
output
'
,
async
()
=>
{
Object
.
assign
(
cell
,
{
Object
.
assign
(
cell
,
{
source
:
[
source
:
[
'
[XSS](data:text/html;base64,PHNjcmlwdD5hbGVydChkb2N1bWVudC5kb21haW4pPC9zY3JpcHQ+Cg==)
\n
'
,
'
[XSS](data:text/html;base64,PHNjcmlwdD5hbGVydChkb2N1bWVudC5kb21haW4pPC9zY3JpcHQ+Cg==)
\n
'
,
...
@@ -50,6 +50,17 @@ describe('Markdown component', () => {
...
@@ -50,6 +50,17 @@ describe('Markdown component', () => {
expect
(
vm
.
$el
.
querySelector
(
'
a
'
).
getAttribute
(
'
href
'
)).
toBeNull
();
expect
(
vm
.
$el
.
querySelector
(
'
a
'
).
getAttribute
(
'
href
'
)).
toBeNull
();
});
});
it
(
'
sanitizes HTML
'
,
async
()
=>
{
const
findLink
=
()
=>
vm
.
$el
.
querySelector
(
'
.xss-link
'
);
Object
.
assign
(
cell
,
{
source
:
[
'
<a href="test.js" data-remote=true data-type="script" class="xss-link">XSS</a>
\n
'
],
});
await
vm
.
$nextTick
();
expect
(
findLink
().
getAttribute
(
'
data-remote
'
)).
toBe
(
null
);
expect
(
findLink
().
getAttribute
(
'
data-type
'
)).
toBe
(
null
);
});
describe
(
'
tables
'
,
()
=>
{
describe
(
'
tables
'
,
()
=>
{
beforeEach
(()
=>
{
beforeEach
(()
=>
{
json
=
getJSONFixture
(
'
blob/notebook/markdown-table.json
'
);
json
=
getJSONFixture
(
'
blob/notebook/markdown-table.json
'
);
...
...
spec/lib/gitlab/x509/signature_spec.rb
View file @
63a19a71
...
@@ -12,20 +12,30 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -12,20 +12,30 @@ RSpec.describe Gitlab::X509::Signature do
end
end
shared_examples
"a verified signature"
do
shared_examples
"a verified signature"
do
it
'returns a verified signature if email does match'
do
let_it_be
(
:user
)
{
create
(
:user
,
email:
X509Helpers
::
User1
.
certificate_email
)
}
signature
=
described_class
.
new
(
subject
(
:signature
)
do
described_class
.
new
(
X509Helpers
::
User1
.
signed_commit_signature
,
X509Helpers
::
User1
.
signed_commit_signature
,
X509Helpers
::
User1
.
signed_commit_base_data
,
X509Helpers
::
User1
.
signed_commit_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
X509Helpers
::
User1
.
signed_commit_time
)
)
end
it
'returns a verified signature if email does match'
do
expect
(
signature
.
x509_certificate
).
to
have_attributes
(
certificate_attributes
)
expect
(
signature
.
x509_certificate
).
to
have_attributes
(
certificate_attributes
)
expect
(
signature
.
x509_certificate
.
x509_issuer
).
to
have_attributes
(
issuer_attributes
)
expect
(
signature
.
x509_certificate
.
x509_issuer
).
to
have_attributes
(
issuer_attributes
)
expect
(
signature
.
verified_signature
).
to
be_truthy
expect
(
signature
.
verified_signature
).
to
be_truthy
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
end
end
it
"returns an unverified signature if the email matches but isn't confirmed"
do
user
.
update!
(
confirmed_at:
nil
)
expect
(
signature
.
verification_status
).
to
eq
(
:unverified
)
end
it
'returns an unverified signature if email does not match'
do
it
'returns an unverified signature if email does not match'
do
signature
=
described_class
.
new
(
signature
=
described_class
.
new
(
X509Helpers
::
User1
.
signed_commit_signature
,
X509Helpers
::
User1
.
signed_commit_signature
,
...
@@ -55,13 +65,6 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -55,13 +65,6 @@ RSpec.describe Gitlab::X509::Signature do
end
end
it
'returns an unverified signature if certificate is revoked'
do
it
'returns an unverified signature if certificate is revoked'
do
signature
=
described_class
.
new
(
X509Helpers
::
User1
.
signed_commit_signature
,
X509Helpers
::
User1
.
signed_commit_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
)
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
signature
.
x509_certificate
.
revoked!
signature
.
x509_certificate
.
revoked!
...
@@ -253,23 +256,25 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -253,23 +256,25 @@ RSpec.describe Gitlab::X509::Signature do
end
end
describe
'#user'
do
describe
'#user'
do
signature
=
described_class
.
new
(
subject
do
described_class
.
new
(
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_base_data
,
X509Helpers
::
User1
.
signed_tag_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
X509Helpers
::
User1
.
signed_commit_time
)
).
user
end
context
'if email is assigned to a user'
do
context
'if email is assigned to a user'
do
let!
(
:user
)
{
create
(
:user
,
email:
X509Helpers
::
User1
.
certificate_email
)
}
let!
(
:user
)
{
create
(
:user
,
email:
X509Helpers
::
User1
.
certificate_email
)
}
it
'returns user'
do
it
'returns user'
do
expect
(
signature
.
user
)
.
to
eq
(
user
)
is_expected
.
to
eq
(
user
)
end
end
end
end
it
'if email is not assigned to a user, return nil'
do
it
'if email is not assigned to a user, return nil'
do
expect
(
signature
.
user
)
.
to
be_nil
is_expected
.
to
be_nil
end
end
end
end
...
@@ -292,6 +297,17 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -292,6 +297,17 @@ RSpec.describe Gitlab::X509::Signature do
end
end
context
'verified signature'
do
context
'verified signature'
do
let_it_be
(
:user
)
{
create
(
:user
,
email:
X509Helpers
::
User1
.
certificate_email
)
}
subject
(
:signature
)
do
described_class
.
new
(
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
)
end
context
'with trusted certificate store'
do
context
'with trusted certificate store'
do
before
do
before
do
store
=
OpenSSL
::
X509
::
Store
.
new
store
=
OpenSSL
::
X509
::
Store
.
new
...
@@ -301,19 +317,18 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -301,19 +317,18 @@ RSpec.describe Gitlab::X509::Signature do
end
end
it
'returns a verified signature if email does match'
do
it
'returns a verified signature if email does match'
do
signature
=
described_class
.
new
(
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
)
expect
(
signature
.
x509_certificate
).
to
have_attributes
(
certificate_attributes
)
expect
(
signature
.
x509_certificate
).
to
have_attributes
(
certificate_attributes
)
expect
(
signature
.
x509_certificate
.
x509_issuer
).
to
have_attributes
(
issuer_attributes
)
expect
(
signature
.
x509_certificate
.
x509_issuer
).
to
have_attributes
(
issuer_attributes
)
expect
(
signature
.
verified_signature
).
to
be_truthy
expect
(
signature
.
verified_signature
).
to
be_truthy
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
end
end
it
"returns an unverified signature if the email matches but isn't confirmed"
do
user
.
update!
(
confirmed_at:
nil
)
expect
(
signature
.
verification_status
).
to
eq
(
:unverified
)
end
it
'returns an unverified signature if email does not match'
do
it
'returns an unverified signature if email does not match'
do
signature
=
described_class
.
new
(
signature
=
described_class
.
new
(
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_signature
,
...
@@ -343,13 +358,6 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -343,13 +358,6 @@ RSpec.describe Gitlab::X509::Signature do
end
end
it
'returns an unverified signature if certificate is revoked'
do
it
'returns an unverified signature if certificate is revoked'
do
signature
=
described_class
.
new
(
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
)
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
expect
(
signature
.
verification_status
).
to
eq
(
:verified
)
signature
.
x509_certificate
.
revoked!
signature
.
x509_certificate
.
revoked!
...
@@ -368,13 +376,6 @@ RSpec.describe Gitlab::X509::Signature do
...
@@ -368,13 +376,6 @@ RSpec.describe Gitlab::X509::Signature do
end
end
it
'returns an unverified signature'
do
it
'returns an unverified signature'
do
signature
=
described_class
.
new
(
X509Helpers
::
User1
.
signed_tag_signature
,
X509Helpers
::
User1
.
signed_tag_base_data
,
X509Helpers
::
User1
.
certificate_email
,
X509Helpers
::
User1
.
signed_commit_time
)
expect
(
signature
.
x509_certificate
).
to
have_attributes
(
certificate_attributes
)
expect
(
signature
.
x509_certificate
).
to
have_attributes
(
certificate_attributes
)
expect
(
signature
.
x509_certificate
.
x509_issuer
).
to
have_attributes
(
issuer_attributes
)
expect
(
signature
.
x509_certificate
.
x509_issuer
).
to
have_attributes
(
issuer_attributes
)
expect
(
signature
.
verified_signature
).
to
be_falsey
expect
(
signature
.
verified_signature
).
to
be_falsey
...
...
spec/tasks/gitlab/x509/update_rake_spec.rb
View file @
63a19a71
...
@@ -8,12 +8,13 @@ RSpec.describe 'gitlab:x509 namespace rake task' do
...
@@ -8,12 +8,13 @@ RSpec.describe 'gitlab:x509 namespace rake task' do
end
end
describe
'update_signatures'
do
describe
'update_signatures'
do
subject
{
run_rake_task
(
'gitlab:x509:update_signatures'
)
}
let
(
:user
)
{
create
(
:user
,
email:
X509Helpers
::
User1
.
certificate_email
)
}
let
(
:project
)
{
create
(
:project
,
:repository
,
path:
X509Helpers
::
User1
.
path
,
creator:
user
)
}
let
(
:project
)
{
create
:project
,
:repository
,
path:
X509Helpers
::
User1
.
path
}
let
(
:x509_signed_commit
)
{
project
.
commit_by
(
oid:
'189a6c924013fc3fe40d6f1ec1dc20214183bc97'
)
}
let
(
:x509_signed_commit
)
{
project
.
commit_by
(
oid:
'189a6c924013fc3fe40d6f1ec1dc20214183bc97'
)
}
let
(
:x509_commit
)
{
Gitlab
::
X509
::
Commit
.
new
(
x509_signed_commit
).
signature
}
let
(
:x509_commit
)
{
Gitlab
::
X509
::
Commit
.
new
(
x509_signed_commit
).
signature
}
subject
{
run_rake_task
(
'gitlab:x509:update_signatures'
)
}
it
'changes from unverified to verified if the certificate store contains the root certificate'
do
it
'changes from unverified to verified if the certificate store contains the root certificate'
do
x509_commit
x509_commit
...
@@ -22,21 +23,14 @@ RSpec.describe 'gitlab:x509 namespace rake task' do
...
@@ -22,21 +23,14 @@ RSpec.describe 'gitlab:x509 namespace rake task' do
store
.
add_cert
(
certificate
)
store
.
add_cert
(
certificate
)
allow
(
OpenSSL
::
X509
::
Store
).
to
receive
(
:new
).
and_return
(
store
)
allow
(
OpenSSL
::
X509
::
Store
).
to
receive
(
:new
).
and_return
(
store
)
expect
(
x509_commit
.
verification_status
).
to
eq
(
'unverified'
)
expect_any_instance_of
(
Gitlab
::
X509
::
Commit
).
to
receive
(
:update_signature!
).
and_call_original
expect_any_instance_of
(
Gitlab
::
X509
::
Commit
).
to
receive
(
:update_signature!
).
and_call_original
expect
{
subject
}.
to
change
{
x509_commit
.
reload
.
verification_status
}.
from
(
'unverified'
).
to
(
'verified'
)
subject
x509_commit
.
reload
expect
(
x509_commit
.
verification_status
).
to
eq
(
'verified'
)
end
end
it
'returns if no signature is available'
do
it
'returns if no signature is available'
do
expect_any_instance_of
(
Gitlab
::
X509
::
Commit
)
do
|
x509_commit
|
expect_any_instance_of
(
Gitlab
::
X509
::
Commit
).
not_to
receive
(
:update_signature!
)
expect
(
x509_commit
).
not_to
receive
(
:update_signature!
)
subject
subject
end
end
end
end
end
end
end
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