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
326d3cb1
Commit
326d3cb1
authored
Feb 15, 2018
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'upstream/master' into ce-to-ee-2018-02-15
parents
84cad03a
efdde042
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
74 additions
and
66 deletions
+74
-66
app/assets/javascripts/commits.js
app/assets/javascripts/commits.js
+27
-45
app/assets/javascripts/dispatcher.js
app/assets/javascripts/dispatcher.js
+5
-0
app/assets/javascripts/pages/projects/commits/show/index.js
app/assets/javascripts/pages/projects/commits/show/index.js
+1
-1
app/assets/javascripts/pages/projects/services/edit/index.js
app/assets/javascripts/pages/projects/services/edit/index.js
+3
-4
app/views/projects/services/_form.html.haml
app/views/projects/services/_form.html.haml
+0
-3
app/views/shared/groups/_dropdown.html.haml
app/views/shared/groups/_dropdown.html.haml
+3
-3
changelogs/unreleased/40623-fix-404-when-listing-archived-projects-in-a-group-where-all-projects-have-been-archived.yml
...ects-in-a-group-where-all-projects-have-been-archived.yml
+4
-0
changelogs/unreleased/fj-42910-unauthenticated-limit-via-ssh.yml
...ogs/unreleased/fj-42910-unauthenticated-limit-via-ssh.yml
+5
-0
config/initializers/rack_attack_global.rb
config/initializers/rack_attack_global.rb
+5
-0
config/webpack.config.js
config/webpack.config.js
+0
-1
spec/javascripts/commits_spec.js
spec/javascripts/commits_spec.js
+11
-9
spec/requests/rack_attack_global_spec.rb
spec/requests/rack_attack_global_spec.rb
+10
-0
No files found.
app/assets/javascripts/commits.js
View file @
326d3cb1
/* eslint-disable func-names, wrap-iife, consistent-return,
no-return-assign, no-param-reassign, one-var-declaration-per-line, no-unused-vars,
prefer-template, object-shorthand, prefer-arrow-callback */
import
{
pluralize
}
from
'
./lib/utils/text_utility
'
;
import
{
localTimeAgo
}
from
'
./lib/utils/datetime_utility
'
;
import
Pager
from
'
./pager
'
;
import
axios
from
'
./lib/utils/axios_utils
'
;
export
default
(
function
()
{
const
CommitsList
=
{};
CommitsList
.
timer
=
null
;
export
default
class
CommitsList
{
constructor
(
limit
=
0
)
{
this
.
timer
=
null
;
CommitsList
.
init
=
function
(
limit
)
{
this
.
$contentList
=
$
(
'
.content_list
'
);
$
(
'
body
'
).
on
(
'
click
'
,
'
.day-commits-table li.commit
'
,
function
(
e
)
{
if
(
e
.
target
.
nodeName
!==
'
A
'
)
{
location
.
href
=
$
(
this
).
attr
(
'
url
'
);
e
.
stopPropagation
();
return
false
;
}
});
Pager
.
init
(
parseInt
(
limit
,
10
),
false
,
false
,
this
.
processCommits
);
Pager
.
init
(
parseInt
(
limit
,
10
),
false
,
false
,
this
.
processCommits
.
bind
(
this
));
this
.
content
=
$
(
'
#commits-list
'
);
this
.
searchField
=
$
(
'
#commits-search
'
);
this
.
lastSearch
=
this
.
searchField
.
val
();
return
this
.
initSearch
();
}
;
this
.
initSearch
();
}
CommitsList
.
initSearch
=
function
()
{
initSearch
()
{
this
.
timer
=
null
;
return
this
.
searchField
.
keyup
((
function
(
_this
)
{
return
function
()
{
clearTimeout
(
_this
.
timer
);
return
_this
.
timer
=
setTimeout
(
_this
.
filterResults
,
500
);
};
})(
this
));
};
this
.
searchField
.
on
(
'
keyup
'
,
()
=>
{
clearTimeout
(
this
.
timer
);
this
.
timer
=
setTimeout
(
this
.
filterResults
.
bind
(
this
),
500
);
});
}
CommitsList
.
filterResults
=
function
()
{
filterResults
()
{
const
form
=
$
(
'
.commits-search-form
'
);
const
search
=
CommitsList
.
searchField
.
val
();
if
(
search
===
CommitsList
.
lastSearch
)
return
Promise
.
resolve
();
const
commitsUrl
=
form
.
attr
(
'
action
'
)
+
'
?
'
+
form
.
serialize
()
;
CommitsList
.
content
.
fadeTo
(
'
fast
'
,
0.5
);
const
search
=
this
.
searchField
.
val
();
if
(
search
===
this
.
lastSearch
)
return
Promise
.
resolve
();
const
commitsUrl
=
`
${
form
.
attr
(
'
action
'
)}
?
${
form
.
serialize
()}
`
;
this
.
content
.
fadeTo
(
'
fast
'
,
0.5
);
const
params
=
form
.
serializeArray
().
reduce
((
acc
,
obj
)
=>
Object
.
assign
(
acc
,
{
[
obj
.
name
]:
obj
.
value
,
}),
{});
...
...
@@ -55,9 +39,9 @@ export default (function () {
params
,
})
.
then
(({
data
})
=>
{
CommitsList
.
lastSearch
=
search
;
CommitsList
.
content
.
html
(
data
.
html
);
CommitsList
.
content
.
fadeTo
(
'
fast
'
,
1.0
);
this
.
lastSearch
=
search
;
this
.
content
.
html
(
data
.
html
);
this
.
content
.
fadeTo
(
'
fast
'
,
1.0
);
// Change url so if user reload a page - search results are saved
history
.
replaceState
({
...
...
@@ -65,16 +49,16 @@ export default (function () {
},
document
.
title
,
commitsUrl
);
})
.
catch
(()
=>
{
CommitsList
.
content
.
fadeTo
(
'
fast
'
,
1.0
);
CommitsList
.
lastSearch
=
null
;
this
.
content
.
fadeTo
(
'
fast
'
,
1.0
);
this
.
lastSearch
=
null
;
});
}
;
}
// Prepare loaded data.
CommitsList
.
processCommits
=
(
data
)
=>
{
processCommits
(
data
)
{
let
processedData
=
data
;
const
$processedData
=
$
(
processedData
);
const
$commitsHeadersLast
=
CommitsList
.
$contentList
.
find
(
'
li.js-commit-header
'
).
last
();
const
$commitsHeadersLast
=
this
.
$contentList
.
find
(
'
li.js-commit-header
'
).
last
();
const
lastShownDay
=
$commitsHeadersLast
.
data
(
'
day
'
);
const
$loadedCommitsHeadersFirst
=
$processedData
.
filter
(
'
li.js-commit-header
'
).
first
();
const
loadedShownDayFirst
=
$loadedCommitsHeadersFirst
.
data
(
'
day
'
);
...
...
@@ -97,7 +81,5 @@ export default (function () {
localTimeAgo
(
$processedData
.
find
(
'
.js-timeago
'
));
return
processedData
;
};
return
CommitsList
;
})();
}
}
app/assets/javascripts/dispatcher.js
View file @
326d3cb1
...
...
@@ -234,6 +234,11 @@ var Dispatcher;
.
then
(
callDefault
)
.
catch
(
fail
);
break
;
case
'
projects:services:edit
'
:
import
(
'
./pages/projects/services/edit
'
)
.
then
(
callDefault
)
.
catch
(
fail
);
break
;
case
'
projects:snippets:edit
'
:
case
'
projects:snippets:update
'
:
import
(
'
./pages/projects/snippets/edit
'
)
...
...
app/assets/javascripts/pages/projects/commits/show/index.js
View file @
326d3cb1
...
...
@@ -3,7 +3,7 @@ import GpgBadges from '~/gpg_badges';
import
ShortcutsNavigation
from
'
~/shortcuts_navigation
'
;
export
default
()
=>
{
CommitsList
.
init
(
document
.
querySelector
(
'
.js-project-commits-show
'
).
dataset
.
commitsLimit
);
new
CommitsList
(
document
.
querySelector
(
'
.js-project-commits-show
'
).
dataset
.
commitsLimit
);
// eslint-disable-line no-new
new
ShortcutsNavigation
();
// eslint-disable-line no-new
GpgBadges
.
fetch
();
};
app/assets/javascripts/
integrations
/index.js
→
app/assets/javascripts/
pages/projects/services/edit
/index.js
View file @
326d3cb1
/* eslint-disable no-new */
import
IntegrationSettingsForm
from
'
./integration_settings_form
'
;
import
IntegrationSettingsForm
from
'
~/integrations/integration_settings_form
'
;
$
(
()
=>
{
export
default
()
=>
{
const
integrationSettingsForm
=
new
IntegrationSettingsForm
(
'
.js-integration-settings-form
'
);
integrationSettingsForm
.
init
();
}
)
;
};
app/views/projects/services/_form.html.haml
View file @
326d3cb1
-
content_for
:page_specific_javascripts
do
=
webpack_bundle_tag
(
'integrations'
)
.row.prepend-top-default.append-bottom-default
.col-lg-3
%h4
.prepend-top-0
...
...
app/views/shared/groups/_dropdown.html.haml
View file @
326d3cb1
...
...
@@ -23,11 +23,11 @@
-
if
show_archive_options
%li
.divider
%li
.js-filter-archived-projects
=
link_to
group_children_path
(
@group
,
archived:
nil
),
class:
(
"is-active"
unless
params
[
:archived
].
present?
)
do
=
link_to
filter_groups_path
(
archived:
nil
),
class:
(
"is-active"
unless
params
[
:archived
].
present?
)
do
Hide archived projects
%li
.js-filter-archived-projects
=
link_to
group_children_path
(
@group
,
archived:
true
),
class:
(
"is-active"
if
Gitlab
::
Utils
.
to_boolean
(
params
[
:archived
]))
do
=
link_to
filter_groups_path
(
archived:
true
),
class:
(
"is-active"
if
Gitlab
::
Utils
.
to_boolean
(
params
[
:archived
]))
do
Show archived projects
%li
.js-filter-archived-projects
=
link_to
group_children_path
(
@group
,
archived:
'only'
),
class:
(
"is-active"
if
params
[
:archived
]
==
'only'
)
do
=
link_to
filter_groups_path
(
archived:
'only'
),
class:
(
"is-active"
if
params
[
:archived
]
==
'only'
)
do
Show archived projects only
changelogs/unreleased/40623-fix-404-when-listing-archived-projects-in-a-group-where-all-projects-have-been-archived.yml
0 → 100644
View file @
326d3cb1
title
:
Fix 404 when listing archived projects in a group where all projects have been archived
merge_request
:
17077
author
:
Ashley Dumaine
type
:
fixed
changelogs/unreleased/fj-42910-unauthenticated-limit-via-ssh.yml
0 → 100644
View file @
326d3cb1
---
title
:
Fixed bug with unauthenticated requests through git ssh
merge_request
:
17149
author
:
type
:
fixed
config/initializers/rack_attack_global.rb
View file @
326d3cb1
...
...
@@ -26,6 +26,7 @@ class Rack::Attack
throttle
(
'throttle_unauthenticated'
,
Gitlab
::
Throttle
.
unauthenticated_options
)
do
|
req
|
Gitlab
::
Throttle
.
settings
.
throttle_unauthenticated_enabled
&&
req
.
unauthenticated?
&&
!
req
.
api_internal_request?
&&
req
.
ip
end
...
...
@@ -54,6 +55,10 @@ class Rack::Attack
path
.
start_with?
(
'/api'
)
end
def
api_internal_request?
path
=~
%r{^/api/v
\d
+/internal/}
end
def
web_request?
!
api_request?
end
...
...
config/webpack.config.js
View file @
326d3cb1
...
...
@@ -75,7 +75,6 @@ var config = {
issues
:
'
./issues/issues_bundle.js
'
,
how_to_merge
:
'
./how_to_merge.js
'
,
issue_show
:
'
./issue_show/index.js
'
,
integrations
:
'
./integrations
'
,
job_details
:
'
./jobs/job_details_bundle.js
'
,
ldap_group_links
:
'
./groups/ldap_group_links.js
'
,
locale
:
'
./locale/index.js
'
,
...
...
spec/javascripts/commits_spec.js
View file @
326d3cb1
...
...
@@ -4,6 +4,8 @@ import axios from '~/lib/utils/axios_utils';
import
CommitsList
from
'
~/commits
'
;
describe
(
'
Commits List
'
,
()
=>
{
let
commitsList
;
beforeEach
(()
=>
{
setFixtures
(
`
<form class="commits-search-form" action="/h5bp/html5-boilerplate/commits/master">
...
...
@@ -11,6 +13,7 @@ describe('Commits List', () => {
</form>
<ol id="commits-list"></ol>
`
);
commitsList
=
new
CommitsList
(
25
);
});
it
(
'
should be defined
'
,
()
=>
{
...
...
@@ -19,7 +22,7 @@ describe('Commits List', () => {
describe
(
'
processCommits
'
,
()
=>
{
it
(
'
should join commit headers
'
,
()
=>
{
C
ommitsList
.
$contentList
=
$
(
`
c
ommitsList
.
$contentList
=
$
(
`
<div>
<li class="commit-header" data-day="2016-09-20">
<span class="day">20 Sep, 2016</span>
...
...
@@ -39,7 +42,7 @@ describe('Commits List', () => {
// The last commit header should be removed
// since the previous one has the same data-day value.
expect
(
C
ommitsList
.
processCommits
(
data
).
find
(
'
li.commit-header
'
).
length
).
toBe
(
0
);
expect
(
c
ommitsList
.
processCommits
(
data
).
find
(
'
li.commit-header
'
).
length
).
toBe
(
0
);
});
});
...
...
@@ -48,8 +51,7 @@ describe('Commits List', () => {
let
mock
;
beforeEach
(()
=>
{
CommitsList
.
init
(
25
);
CommitsList
.
searchField
.
val
(
''
);
commitsList
.
searchField
.
val
(
''
);
spyOn
(
history
,
'
replaceState
'
).
and
.
stub
();
mock
=
new
MockAdapter
(
axios
);
...
...
@@ -66,11 +68,11 @@ describe('Commits List', () => {
});
it
(
'
should save the last search string
'
,
(
done
)
=>
{
C
ommitsList
.
searchField
.
val
(
'
GitLab
'
);
C
ommitsList
.
filterResults
()
c
ommitsList
.
searchField
.
val
(
'
GitLab
'
);
c
ommitsList
.
filterResults
()
.
then
(()
=>
{
expect
(
ajaxSpy
).
toHaveBeenCalled
();
expect
(
C
ommitsList
.
lastSearch
).
toEqual
(
'
GitLab
'
);
expect
(
c
ommitsList
.
lastSearch
).
toEqual
(
'
GitLab
'
);
done
();
})
...
...
@@ -78,10 +80,10 @@ describe('Commits List', () => {
});
it
(
'
should not make ajax call if the input does not change
'
,
(
done
)
=>
{
C
ommitsList
.
filterResults
()
c
ommitsList
.
filterResults
()
.
then
(()
=>
{
expect
(
ajaxSpy
).
not
.
toHaveBeenCalled
();
expect
(
C
ommitsList
.
lastSearch
).
toEqual
(
''
);
expect
(
c
ommitsList
.
lastSearch
).
toEqual
(
''
);
done
();
})
...
...
spec/requests/rack_attack_global_spec.rb
View file @
326d3cb1
...
...
@@ -22,6 +22,7 @@ describe 'Rack Attack global throttles' do
let
(
:url_that_does_not_require_authentication
)
{
'/users/sign_in'
}
let
(
:url_that_requires_authentication
)
{
'/dashboard/snippets'
}
let
(
:url_api_internal
)
{
'/api/v4/internal/check'
}
let
(
:api_partial_url
)
{
'/todos'
}
around
do
|
example
|
...
...
@@ -172,6 +173,15 @@ describe 'Rack Attack global throttles' do
get
url_that_does_not_require_authentication
expect
(
response
).
to
have_http_status
200
end
context
'when the request is to the api internal endpoints'
do
it
'allows requests over the rate limit'
do
(
1
+
requests_per_period
).
times
do
get
url_api_internal
,
secret_token:
Gitlab
::
Shell
.
secret_token
expect
(
response
).
to
have_http_status
200
end
end
end
end
context
'when the throttle is disabled'
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