summaryrefslogtreecommitdiff
path: root/lib/api/v3
Commit message (Collapse)AuthorAgeFilesLines
* Move line code generation into Gitlab::Gitconflict-resolution-refactorAlejandro Rodríguez2017-10-121-1/+1
| | | | Having a distinct class just for that was a bit overkill
* Create a Gitlab::Git submodule for conlict-related filesAlejandro Rodríguez2017-10-121-1/+1
| | | | Rename classes to (hopefully) clearer names while we're doing that.
* Move Gitlab::Diff::LineCode to module Gitlab::GitAlejandro Rodríguez2017-10-121-1/+1
|
* Remove 'Repo' prefix from API entitesVitaliy @blackst0ne Klachkov2017-10-057-24/+24
|
* Merge branch '23079-remove-default-scope-in-sortable' into 'master'Douwe Maan2017-09-073-2/+3
|\ | | | | | | | | | | | | Removes default scope from sortable Closes #23079 See merge request !13558
| * Removes default scope from sortable23079-remove-default-scope-in-sortableTiago Botelho2017-09-073-2/+3
| |
* | Merge branch 'events-migration-cleanup' into 'master'Sean McGivern2017-09-071-1/+1
|\ \ | | | | | | | | | | | | | | | | | | Finish migration to the new events setup Closes #37241 See merge request !13932
| * | Finish migration to the new events setupevents-migration-cleanupYorick Peterse2017-09-061-1/+1
| |/ | | | | | | | | | | | | | | | | | | | | | | | | This finishes the procedure for migrating events from the old format into the new format. Code no longer uses the old setup and the database tables used during the migration process are swapped, with the old table being dropped. While the database migration can be reversed this will 1) take a lot of time as data has to be coped around 2) won't restore data in the "events.data" column as we have no way of restoring this. Fixes https://gitlab.com/gitlab-org/gitlab-ce/issues/37241
* | change collapse to resolve and comments to discussionsAshley Dumaine2017-09-062-3/+3
| |
* | Add functionality to collapse outdated diff comments regardless of ↵Ashley Dumaine2017-09-062-3/+5
|/ | | | discussion resolution
* Use pipeline.trigger_requests.lastfix/sm/35650-remove-createtriggerrequestservice-and-forbid-to-persist-variables-on-ci-triggerrequestShinya Maeda2017-09-051-1/+1
|
* Fix trigger_request.variablesShinya Maeda2017-09-041-4/+2
|
* Fix specShinya Maeda2017-09-041-2/+3
|
* Revert autheticate! in Trigger APIShinya Maeda2017-09-041-4/+4
|
* Remove CreateTriggerRequestService and forbit to save variables on ↵Shinya Maeda2017-09-041-12/+19
| | | | Ci::TriggerRequest
* Upgrade grape to 1.0Zeger-Jan van de Weg2017-08-162-4/+4
| | | | | Main feature was the deprication of the Hashie stuff, so the access by calling keys as method is gone now.
* Merge branch 'rs-more-public-send-whitelists' into 'master'Rémy Coutable2017-08-161-3/+3
|\ | | | | | | | | Whitelist or fix additional `Gitlab/PublicSend` cop violations See merge request !13467
| * Whitelist or fix additional `Gitlab/PublicSend` cop violationsrs-more-public-send-whitelistsRobert Speicher2017-08-141-3/+3
| | | | | | | | | | An upcoming update to rubocop-gitlab-security added additional violations.
* | Cache the number of forks of a projectforks-count-cacheYorick Peterse2017-08-141-0/+2
|/ | | | | | | | | | | The number of forks of a project doesn't change very frequently and running a COUNT(*) every time this information is requested can be quite expensive. We also end up running such a COUNT(*) query at least twice on the homepage of a project. By caching this data and refreshing it when necessary we can reduce project homepage loading times by around 60 milliseconds (based on the timings of https://gitlab.com/gitlab-org/gitlab-ce).
* Migrate events into a new formatYorick Peterse2017-08-101-1/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit migrates events data in such a way that push events are stored much more efficiently. This is done by creating a shadow table called "events_for_migration", and a table called "push_event_payloads" which is used for storing push data of push events. The background migration in this commit will copy events from the "events" table into the "events_for_migration" table, push events in will also have a row created in "push_event_payloads". This approach allows us to reclaim space in the next release by simply swapping the "events" and "events_for_migration" tables, then dropping the old events (now "events_for_migration") table. The new table structure is also optimised for storage space, and does not include the unused "title" column nor the "data" column (since this data is moved to "push_event_payloads"). == Newly Created Events Newly created events are inserted into both "events" and "events_for_migration", both using the exact same primary key value. The table "push_event_payloads" in turn has a foreign key to the _shadow_ table. This removes the need for recreating and validating the foreign key after swapping the tables. Since the shadow table also has a foreign key to "projects.id" we also don't have to worry about orphaned rows. This approach however does require some additional storage as we're duplicating a portion of the events data for at least 1 release. The exact amount is hard to estimate, but for GitLab.com this is expected to be between 10 and 20 GB at most. The background migration in this commit deliberately does _not_ update the "events" table as doing so would put a lot of pressure on PostgreSQL's auto vacuuming system. == Supporting Both Old And New Events Application code has also been adjusted to support push events using both the old and new data formats. This is done by creating a PushEvent class which extends the regular Event class. Using Rails' Single Table Inheritance system we can ensure the right class is used for the right data, which in this case is based on the value of `events.action`. To support displaying old and new data at the same time the PushEvent class re-defines a few methods of the Event class, falling back to their original implementations for push events in the old format. Once all existing events have been migrated the various push event related methods can be removed from the Event model, and the calls to `super` can be removed from the methods in the PushEvent model. The UI and event atom feed have also been slightly changed to better handle this new setup, fortunately only a few changes were necessary to make this work. == API Changes The API only displays push data of events in the new format. Supporting both formats in the API is a bit more difficult compared to the UI. Since the old push data was not really well documented (apart from one example that used an incorrect "action" nmae) I decided that supporting both was not worth the effort, especially since events will be migrated in a few days _and_ new events are created in the correct format.
* Enable the Layout/SpaceBeforeBlockBraces coprc/enable-the-Layout/SpaceBeforeBlockBraces-copRémy Coutable2017-08-091-1/+1
| | | | Signed-off-by: Rémy Coutable <remy@rymai.me>
* Avoid plucking Todo ids and use sub-queries insteadToon Claes2017-08-031-3/+3
| | | | | | | | TodoService should not call `.select(&:id)` on todos, because this is bad performance. So instead use sub-queries, which will result in a single SQL query to the database. https://docs.gitlab.com/ee/development/sql.html#plucking-ids
* Fixup POST /v3/:id/hooks and PUT /v3/:id/hooks/:hook_idRichard Clamp2017-07-281-2/+6
|
* Merge branch '30634-protected-pipeline' into 'master'Kamil Trzciński2017-07-251-5/+6
|\ | | | | | | | | | | | | Implement "Block pipelines on protected branches" Closes #30634, #34616, and #33130 See merge request !11910
| * Use struct instead of hashLin Jen-Shin2017-07-201-2/+2
| |
| * Use hash to return multiple objectsLin Jen-Shin2017-07-201-3/+3
| |
| * Merge remote-tracking branch 'upstream/master' into 30634-protected-pipelineLin Jen-Shin2017-07-173-5/+16
| |\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * upstream/master: (638 commits) Simplify background migrations stealing code Expire cached user IDs that can see the performance after 5 minutes Promote visibility level helpers from Group to Namespace Fix off-by-one error in background migration retries Recover from all exceptions when stealing bg migration Fix label creation from new list for subgroup projects move click handler to button. when on the icon it wasn't triggered in firefox Fix incorrect AWS ELB metrics. Fix wrong link to docs in docs styleguide Update issue-related docs Refactor groups docs Add subgroups limitations to Pages docs Update Google launcher details Split docs on IP whitelist for monitoring access Update health check docs Bump fog-core to 1.44.3 and fog providers' plugins to latest Introduce have_gitlab_http_status Remove Repository#search_files Update Pipeline's badge count in Merge Request and Commits view to match real-time content Fixes the user order being overriden in the autocomplete controller ...
| * \ Merge remote-tracking branch 'upstream/master' into 30634-protected-pipelineLin Jen-Shin2017-06-299-27/+30
| |\ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * upstream/master: (1168 commits) Job details won't scroll horizontally to show long lines Bring back branches badge to main project page Limit OpenGraph image size to 64x64 Improve changelog Split up MergeRequestsController Add parent_id back to the tests Make changelog more descriptive Improve tests text Rename members_count to members_count_with_descendants and expose only to group admins Fix a bug where an invalid sort param value was passed to Gitaly Drop default ORDER scope when calling a find method on a Sortable model Add tests for project import state transition: [:started] => [:finished] Add CHANGELOG Perform housekeeping only when an import of a fresh project is completed Strip trailing whitespace in relative submodule URL Adjust projects spec on namespace fields Add "members_count" and "parent_id" data on namespaces API Removes redundant pending delete checks Fix gitaly ref encoding bugs Add ProjectWiki#ensure_repository ...
| * | | Try to report why it's failing and fix testsLin Jen-Shin2017-06-061-3/+4
| | | |
* | | | Resolve "More RESTful API: include resource URLs in responses"Oswaldo Ferreira2017-07-251-1/+30
| |_|/ |/| |
* | | Fixes needed when GitLab sign-in is not enabledRobin Bobbitt2017-07-132-4/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | When sign-in is disabled: - skip password expiration checks - prevent password reset requests - don’t show Password tab in User Settings - don’t allow login with username/password for Git over HTTP requests - render 404 on requests to Profiles::PasswordsController
* | | Initial attempt at refactoring API scope declarations.Timothy Andrew2017-06-281-1/+3
| |/ |/| | | | | | | | | | | | | | | | | - Declaring an endpoint's scopes in a `before` block has proved to be unreliable. For example, if we're accessing the `API::Users` endpoint - code in a `before` block in `API::API` wouldn't be able to see the scopes set in `API::Users` since the `API::API` `before` block runs first. - This commit moves these declarations to the class level, since they don't need to change once set.
* | Filter archived project in API v3 only if param presentvanadium232017-06-212-2/+5
| |
* | Enable Style/DotPosition Rubocop :cop:Grzegorz Bizon2017-06-215-22/+22
| |
* | Rename "Slash commands" to "Quick actions"Eric Eastwood2017-06-151-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | Fix https://gitlab.com/gitlab-org/gitlab-ce/issues/27070 Deprecate "chat commands" in favor of "slash commands" We looked for things like: - `slash commmand` - `slash_command` - `slash-command` - `SlashCommand`
* | Blob#load_all_data! doesn’t need an argumentblob-load-all-dataDouwe Maan2017-06-071-1/+1
|/
* Enable the Style/PreferredHashMethods coprc/enable-PreferredHashMethods-copRémy Coutable2017-06-022-2/+2
| | | | Signed-off-by: Rémy Coutable <remy@rymai.me>
* Merge branch 'migrate-old-artifacts' into 'master'Grzegorz Bizon2017-06-011-10/+0
|\ | | | | | | | | | | | | Fix data inconsistency issue for old artifacts by moving them to a currently used path Closes #32036 See merge request !11824
| * Add missing specsKamil Trzcinski2017-06-011-10/+0
| |
| * Fix data inconsistency issue for old artifacts by moving them to a currently ↵Kamil Trzcinski2017-06-011-1/+1
| | | | | | | | used path
* | Merge branch 'bugfix/deploy_keys__can_push__usage_in_api' into 'master'Rémy Coutable2017-06-011-0/+1
|\ \ | |/ |/| | | | | Add missing `can_push` parameter to POST /v3/deploy_keys See merge request !11607
| * Add missing `can_push` parameter to POST /v3/deploy_keysRichard Clamp2017-05-221-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | The v3 API documentation claims that `can_push` is supported when adding a deploy_key. https://gitlab.com/gitlab-org/gitlab-ce/blob/8-16-stable/doc/api/deploy_keys.md#add-deploy-key Here we make good on this promise by adding `can_push` as an optional parameter so grape can route it. This was copied from the v4 API.
* | Merge branch 'dm-collapsed-blob' into 'master'Sean McGivern2017-06-012-2/+2
|\ \ | | | | | | | | | | | | Consistent diff and blob size limit names See merge request !11776
| * | Change no_limits to limitsdm-collapsed-blobDouwe Maan2017-05-312-2/+2
| | |
| * | Consistent diff and blob size limit namesDouwe Maan2017-05-292-2/+2
| | |
* | | Remove some deprecated methodstc-improve-project-api-perfToon Claes2017-05-302-2/+2
| | | | | | | | | | | | | | | To avoid the use of slow queries, remove some deprecated methods and encourage the use of ProjectFinder to find projects.
* | | Copy `filter_projects` helper to V3Toon Claes2017-05-301-0/+27
|/ / | | | | | | | | The helper will be modified in V4, so copy the original to V4 to keep the current behavior in V3.
* | Merge branch 'rework-authorizations-performance' into 'master'Douwe Maan2017-05-292-2/+9
|\ \ | | | | | | | | | | | | Rework project authorizations and nested groups for better performance See merge request !10885
| * | Hide nested group UI/API support for MySQLYorick Peterse2017-05-172-2/+9
| | | | | | | | | | | | | | | | | | This hides/disables some UI elements and API parameters related to nested groups when MySQL is used, since nested groups are not supported for MySQL.
* | | Revert "Remove changes that are not absolutely necessary"Douwe Maan2017-05-241-1/+1
| |/ |/| | | This reverts commit b0498c176fa134761d899c9b369be12f1ca789c5