Skip to content
Snippets Groups Projects
Unverified Commit 953f789f authored by Steve Xuereb's avatar Steve Xuereb :speech_balloon: Committed by Steve Azzopardi
Browse files

Merge branch 'security-11-3-2717-xss-username-autocomplete' into 'security-11-3'

[11.3] Escape user fullname while rendering autocomplete template to prevent XSS

See merge request gitlab/gitlabhq!2608
parent e70f2a5b
No related branches found
No related tags found
No related merge requests found
Loading
Loading
@@ -149,10 +149,16 @@ class GfmAutoComplete {
// Team Members
$input.atwho({
at: '@',
alias: 'users',
displayTpl(value) {
let tmpl = GfmAutoComplete.Loading.template;
if (value.username != null) {
tmpl = GfmAutoComplete.Members.template;
const { avatarTag, username, title } = value;
if (username != null) {
tmpl = GfmAutoComplete.Members.templateFunction({
avatarTag,
username,
title,
});
}
return tmpl;
},
Loading
Loading
@@ -512,8 +518,9 @@ GfmAutoComplete.Emoji = {
};
// Team Members
GfmAutoComplete.Members = {
// eslint-disable-next-line no-template-curly-in-string
template: '<li>${avatarTag} ${username} <small>${title}</small></li>',
templateFunction({ avatarTag, username, title }) {
return `<li>${avatarTag} ${username} <small>${_.escape(title)}</small></li>`;
},
};
GfmAutoComplete.Labels = {
// eslint-disable-next-line no-template-curly-in-string
Loading
Loading
---
title: Escape user fullname while rendering autocomplete template to prevent XSS
merge_request:
author:
type: security
require 'rails_helper'
 
describe 'GFM autocomplete', :js do
let(:issue_xss_title) { 'This will execute alert<img src=x onerror=alert(2)&lt;img src=x onerror=alert(1)&gt;' }
let(:user_xss_title) { 'eve <img src=x onerror=alert(2)&lt;img src=x onerror=alert(1)&gt;' }
let(:user_xss) { create(:user, name: user_xss_title, username: 'xss.user') }
let(:user) { create(:user, name: '💃speciąl someone💃', username: 'someone.special') }
let(:project) { create(:project) }
let(:label) { create(:label, project: project, title: 'special+') }
Loading
Loading
@@ -8,6 +12,8 @@ describe 'GFM autocomplete', :js do
 
before do
project.add_maintainer(user)
project.add_maintainer(user_xss)
sign_in(user)
visit project_issue_path(project, issue)
 
Loading
Loading
@@ -34,9 +40,8 @@ describe 'GFM autocomplete', :js do
expect(page).to have_selector('.atwho-container')
end
 
it 'opens autocomplete menu when field starts with text with item escaping HTML characters' do
alert_title = 'This will execute alert<img src=x onerror=alert(2)&lt;img src=x onerror=alert(1)&gt;'
create(:issue, project: project, title: alert_title)
it 'opens autocomplete menu for Issues when field starts with text with item escaping HTML characters' do
create(:issue, project: project, title: issue_xss_title)
 
page.within '.timeline-content-form' do
find('#note-body').native.send_keys('#')
Loading
Loading
@@ -45,7 +50,19 @@ describe 'GFM autocomplete', :js do
expect(page).to have_selector('.atwho-container')
 
page.within '.atwho-container #at-view-issues' do
expect(page.all('li').first.text).to include(alert_title)
expect(page.all('li').first.text).to include(issue_xss_title)
end
end
it 'opens autocomplete menu for Username when field starts with text with item escaping HTML characters' do
page.within '.timeline-content-form' do
find('#note-body').native.send_keys('@ev')
end
expect(page).to have_selector('.atwho-container')
page.within '.atwho-container #at-view-users' do
expect(find('li').text).to have_content(user_xss.username)
end
end
 
Loading
Loading
@@ -106,7 +123,7 @@ describe 'GFM autocomplete', :js do
 
wait_for_requests
 
expect(find('#at-view-64')).to have_selector('.cur:first-of-type')
expect(find('#at-view-users')).to have_selector('.cur:first-of-type')
end
 
it 'includes items for assignee dropdowns with non-ASCII characters in name' do
Loading
Loading
@@ -119,7 +136,7 @@ describe 'GFM autocomplete', :js do
 
wait_for_requests
 
expect(find('#at-view-64')).to have_content(user.name)
expect(find('#at-view-users')).to have_content(user.name)
end
 
it 'selects the first item for non-assignee dropdowns if a query is entered' do
Loading
Loading
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment