| Commit message (Collapse) | Author | Age | Files | Lines |
| |
|
|
|
|
|
|
| |
We can't do a lot with classes without names as we can't filter by them,
have no idea where they come from, etc. As such it's best to just ignore
these.
|
|\
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| | |
Allow users to request access to projects and groups
#### TODO:
- [x] Factorize the projects & groups members list
- [x] Factorize `request_access` and `approve` controller methods into a concern
- [x] Factorize the project & group dropdowns
- [x] Factorize access request routes
- [x] Factorize mailers
#### Will be done in separate MRs
- [ ] Documentation
- [ ] API
#### Access request to project
- [x] Design project access request button to spec (defined in #13948)
- [x] Request access to a project as a logged in user
- [x] Withdraw access request to a project as a logged in user
- [x] Do not treat project member request as actual membership (done partly in Ability)
- [x] Display access requests on project's members page (+ allow to change level, approve, and deny request)
- [x] Email requesting user at notification email address when accepted/denied
- [x] Email all project admins at notification email addresses when new access request
- [x] Unit specs to cover new functionality: `AccessRequestable` is missing specs
- [x] Controller specs to cover new functionality
- [x] Mailer specs to cover new functionality
- [x] Features specs to cover new UI and interactions
- [x] Regression specs still passing
#### Access request to group
- [x] Design group access request button to spec (defined in #13948)
- [x] Request access to a group as a logged in user
- [x] Withdraw access request to a group as a logged in user
- [x] Do not treat group member request as actual membership
- [x] Display access requests on group's members page (+ allow to change level, approve, and deny request)
- [x] Email requesting user at notification email address when accepted/denied
- [x] Email all project admins at notification email addresses when new access request
- [x] Unit specs to cover new functionality
- [x] Controller specs to cover new functionality
- [x] Mailer specs to cover new functionality
- [x] Features specs to cover new UI and interactions
- [x] Regression specs still passing
Closes #13948.
### Requesting access to a project
#### Responsive UI
data:image/s3,"s3://crabby-images/c6045/c60452e95be376df7ad431c980f5776d2a69b3c4" alt="request-access-to-project"
#### Request access link
data:image/s3,"s3://crabby-images/85f1d/85f1dc308cdb7542cc222a3ebec217d3d1156d8e" alt="1-project-request-access-link"
#### Flash once access is requested
data:image/s3,"s3://crabby-images/ad2a4/ad2a4eaacbda4b8706cc1ff76d816477c3ead800" alt="2-project-request-access-flash"
#### Email sent to project admins on new access requests
##### HTML Email
data:image/s3,"s3://crabby-images/2d4c1/2d4c153d3a1451e12bdc17e182c52074b208dc1f" alt="3-project-request-access-email-html"
##### Plain Email
data:image/s3,"s3://crabby-images/32142/3214235f6721d8bf8d4533a05504dd06ade3bfc3" alt="4-project-request-access-email-plain"
### Withdrawing access request to a project
#### Withdraw access request link
data:image/s3,"s3://crabby-images/b493c/b493cbe5c295cd0ad91c0202776724a7455008ed" alt="5-project-withdraw-request-link"
#### Withdraw access request confirmation dialog box
data:image/s3,"s3://crabby-images/4d003/4d0033c3f07ae85bb9cfd742125456c990c4449e" alt="6-project-withdraw-request-confirm"
#### Flash once access has been withdrawn
data:image/s3,"s3://crabby-images/2f4fd/2f4fdf34079ea673a20cb633e8df9f3ea68519bc" alt="6-2-project-withdraw-request-confirm"
### Access requests management page
data:image/s3,"s3://crabby-images/bf160/bf160c767f9187d1760ff2ee32c112db4443e504" alt="7-project-access-requests"
#### Deny access request confirmation dialog box
data:image/s3,"s3://crabby-images/a517a/a517a5ef7e23c5a4818f1647ac14140781a74965" alt="8-project-access-request-deny-confirm"
#### Email sent to requester on denied access requests
##### HTML Email
data:image/s3,"s3://crabby-images/6e7df/6e7df2a83394c61bb685f61e48d97a89ccad8943" alt="9-project-request-access-denied-email-html"
##### Plain Email
data:image/s3,"s3://crabby-images/33c64/33c64e4bf6c3997ce0b7218642531246a0cbe06d" alt="10-project-request-access-denied-email-plain"
#### Email sent to requester on granted access requests
##### HTML Email
data:image/s3,"s3://crabby-images/7dc17/7dc179e9ec050cee164eaabd57aef10b1d8435f9" alt="11-project-request-access-granted-email-html"
##### Plain Email
data:image/s3,"s3://crabby-images/7a4db/7a4dbc2bf62de59d20b8ffc7c0838a4600d64642" alt="12-project-request-access-granted-email-plain"
----------------------------------
----------------------------------
### Requesting access to a group
#### Responsive UI
data:image/s3,"s3://crabby-images/fd136/fd1365f3cea6ea1e3d233eb84c0cf7ca0425a8fe" alt="request-access-to-group"
#### Request access link
data:image/s3,"s3://crabby-images/b44ec/b44ecc6eec9da407b2cfce0a967c22d0639b6362" alt="1-group-request-access-link"
#### Flash once access is requested
data:image/s3,"s3://crabby-images/fdfb7/fdfb72419a6b624cd3a437740bd440c6ad340337" alt="2-group-request-access-flash"
#### Email sent to project admins on new access requests
##### HTML Email
data:image/s3,"s3://crabby-images/5040c/5040c3ada5824bb489cd9a9ddb75561d61d82700" alt="3-group-request-access-email-html"
##### Plain Email
data:image/s3,"s3://crabby-images/57bc4/57bc4736d9e8a2a55bbbd5cbf5663ec309968afa" alt="4-group-request-access-email-plain"
### Withdrawing access request to a project
#### Withdraw access request link
data:image/s3,"s3://crabby-images/3a47c/3a47c2361f7088c0eb06b462090bf6aea984f1f0" alt="5-group-withdraw-request-link"
#### Withdraw access request confirmation dialog box
data:image/s3,"s3://crabby-images/e4bad/e4bad8c6968b793cf4892f13d7d94853ee2ef405" alt="6-group-withdraw-request-confirm"
#### Flash once access has been withdrawn
data:image/s3,"s3://crabby-images/aaf1d/aaf1d7dad823d205cf390547b64b4691e1cd375d" alt="6-2-group-withdraw-request-confirm"
### Access requests management page
data:image/s3,"s3://crabby-images/ab707/ab707f623bcfd86f571d945d33fbb7a72e6075b0" alt="7-group-access-requests"
#### Deny access request confirmation dialog box
data:image/s3,"s3://crabby-images/e39c5/e39c5b9a91948dc083393c281becce6b3ccb5209" alt="8-group-access-request-deny-confirm"
#### Email sent to requester on denied access requests
##### HTML Email
data:image/s3,"s3://crabby-images/7c376/7c3766348efe01aff280077c1527d0bca781ef22" alt="9-group-request-access-denied-email-html"
##### Plain Email
data:image/s3,"s3://crabby-images/2a332/2a33269ba7bd10ab726d9734cdbc589a226a7666" alt="10-group-request-access-denied-email-plain"
#### Email sent to requester on granted access requests
##### HTML Email
data:image/s3,"s3://crabby-images/8a6c9/8a6c9847423697b5f43034cbcb4b24b492cf7b01" alt="11-group-request-access-granted-email-html"
##### Plain Email
data:image/s3,"s3://crabby-images/1662b/1662b5ec671475ae711324f1355e92e68d83b454" alt="12-group-request-access-granted-email-plain"
See merge request !3798
|
| |\
| | |
| | |
| | |
| | | |
# Conflicts:
# app/views/layouts/nav/_project.html.haml
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | | |
+ Move 'Edit Project/Group' out of membership-related partial
+ Show the access request buttons only to logged-in users
+ Put the request access buttons out of in a more visible button
+ Improve the copy in the #remove_member_message helper
Signed-off-by: Rémy Coutable <remy@rymai.me>
|
| | |
| | |
| | |
| | | |
Signed-off-by: Rémy Coutable <remy@rymai.me>
|
|\ \ \
| | | |
| | | |
| | | |
| | | | |
Instrument Grape API endpoints
See merge request !4587
|
| |/ /
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | | |
Generating the following tags
Grape#GET /projects/:id/archive
from Grape::Route objects like
{ :path => /:version/projects/:id/archive(.:format)
:version => “v3”,
:method => “GET” }
Use an instance variable to cache raw_path transformations.
This variable is only going to growth to the number of
endpoints of the API, not with exact different requests
We can store this cache as an instance variable because
middleware are initialised only once
|
|\ \ \
| |_|/
|/| |
| | |
| | | |
Instrument private methods and instance private methods
See merge request !4639
|
| | |
| | |
| | |
| | |
| | |
| | |
| | | |
By default instrumentation will instrument public,
protected and private methods, because usually
heavy work is done on private method or at least
that’s what facts is showing
|
|\ \ \
| |/ / |
|
| |\ \
| | | |
| | | |
| | | |
| | | | |
Measure CPU time for instrumented methods
See merge request !4640
|
| | |/ |
|
| |\ \
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
Add global entry with before script to new CI config
## What does this MR do?
This MR adds a new entries to a new CI config class. It is next refactoring step after !4462.
See #15060
See merge request !4482
|
| | | | |
|
| | | | |
|
| | |\ \
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | |
| | | | | |
* master: (59 commits)
Improved SVG sanitizer specs to include smoke tests for clean.
Refactored SVG sanitizer
Added SVG sanitizer fix to the changelog
Refactor SVG sanitizer and prevent `xlink:href` to refer to external resources
Fix SVG whitelisting to allow namespaced attributes
Fix Error 500 when using closes_issues API with an external issue tracker
Center layout navigation and remove icons
Fix preferences_spec test
Add back sidebar counters and username
Only create the backup directory if it is local
Fix safari logo loading animation safari bug
Revert side nav to full width; remove border under nav; remove tooltips on nav links; stop page content shifting with side nav; put project nav in container
Update media queries
Fix profile test
Fix logo at all screen widths, update sidebar text
Move tanuki icon to center of nav bar; keep nav closed by default; remove collapsed nav cookie
Remove unused MergeRequest#gitlab_merge_status method
Add CHANGELOG item for labels/milestones navigation change
Render issues link on issues subnav unless you visit merge request controller
Render only issues/mr in subnav depends on context
...
|
| | | | | |
|
| | | | | |
|
| | | | | |
|
| | | | | |
|
| | | | | |
|
| | | | | |
|
| | |\ \ \
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | |
| | | | | | |
* master: (147 commits)
Minor MR comment fixes.
Update CHANGELOG for 8.8.4 and 8.8.5
Properly quote table name in Rake task for MySQL and PostgreSQL compatibility
Checks based on whether data is loaded not undefined
Checks for undefined when inserting autocomplete into textarea
Ignore frequent emojis in search.
Fixed tests
CHANGELOG
Improved the UX of issue & milestone date picker
Change date format to be non zero padded in order to fix failing test
Update method name for better understanding
Add tests for dates on tooltips
Fix local timeago on user dashboard
Update CHANGELOG
Toggling a task in a description with mentions doesn't creates a Todo
Update CHANGELOG
Fixed failing label subscribe test
Tests update
Updated subscribe icon
Fixed failing tests
...
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | | | | | |
|
| | |\ \ \ \
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | | |
* master: (285 commits)
Bump recaptcha gem to 3.0.0 to remove deprecated stoken support
Load knapsack in Rakefile only when is bundled
Add License Finder information to contribution acceptance criteria.
Add LGPLv2 to license whiltelist
Instrument `RepositoryCheck::SingleRepositoryWorker` manually
Bump nokogiri to 1.6.8
Fix alignment of wiki top area
Update charcoal theme colors
Update nav link font size and spacing; fix hamburger icon
Fix control btn position
Remove todos count tests in nav
Test impersonation using img data attribute instead of username
Implement compact side nav
Fix knapsack for master
Align links and tabs
Add scrolling tabs to code subnav
Finish styling sub nav
Updated colors
Fixed failing tests
CHANGELOG item
...
Conflicts:
lib/gitlab/ci/config.rb
spec/lib/gitlab/ci/config_spec.rb
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| | | | | | | |
|
| |\ \ \ \ \ \
| | |_|_|_|_|/
| |/| | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | |
| | | | | | | |
Add whitelisted elements correctly in sanitization
Add whitelisted elements correctly in sanitization
Consider this command:
bundle exec rails r "include GitlabMarkdownHelper
puts markdown('<span>this is a span</span>', pipeline: :description)
puts markdown('<span>this is a span</span>')"
And the same in the opposite order:
bundle exec rails r "include GitlabMarkdownHelper
puts markdown('<span>this is a span</span>')
puts markdown('<span>this is a span</span>', pipeline: :description)"
Before this change, they would both output:
<p><span>this is a span</span></p>
<p>this is a span</p>
That's because `span` is added to the list of whitelisted elements in
the `SanitizationFilter`, but this method tries not to make the same
changes multiple times. Unfortunately,
`HTML::Pipeline::SanitizationFilter::LIMITED`, which is used by the
`DescriptionPipeline`, uses the same Ruby objects for all of its hash
values _except_ `:elements`.
That means that whichever of `DescriptionPipeline` and `GfmPipeline` is
called first would have `span` in its whitelisted elements, and the
second wouldn't.
Fix this by adding a special check for modifying `:elements` twice, then
checking `:transformers` as before.
See merge request !4588
|