diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-02-18 09:45:46 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-02-18 09:45:46 +0000 |
commit | a7b3560714b4d9cc4ab32dffcd1f74a284b93580 (patch) | |
tree | 7452bd5c3545c2fa67a28aa013835fb4fa071baf /app/services/groups | |
parent | ee9173579ae56a3dbfe5afe9f9410c65bb327ca7 (diff) | |
download | gitlab-ce-a7b3560714b4d9cc4ab32dffcd1f74a284b93580.tar.gz |
Add latest changes from gitlab-org/gitlab@14-8-stable-eev14.8.0-rc42
Diffstat (limited to 'app/services/groups')
-rw-r--r-- | app/services/groups/create_service.rb | 11 | ||||
-rw-r--r-- | app/services/groups/update_statistics_service.rb | 28 |
2 files changed, 39 insertions, 0 deletions
diff --git a/app/services/groups/create_service.rb b/app/services/groups/create_service.rb index da3cebc2e6d..67cbbaf84f6 100644 --- a/app/services/groups/create_service.rb +++ b/app/services/groups/create_service.rb @@ -61,6 +61,8 @@ module Groups delay = Namespaces::InviteTeamEmailService::DELIVERY_DELAY_IN_MINUTES Namespaces::InviteTeamEmailWorker.perform_in(delay, group.id, current_user.id) end + + track_experiment_event end def remove_unallowed_params @@ -112,6 +114,15 @@ module Groups @group.shared_runners_enabled = @group.parent.shared_runners_enabled @group.allow_descendants_override_disabled_shared_runners = @group.parent.allow_descendants_override_disabled_shared_runners end + + def track_experiment_event + return unless group.persisted? + + # Track namespace created events to relate them with signed up events for + # the same experiment. This will let us associate created namespaces to + # users that signed up from the experimental logged out header. + experiment(:logged_out_marketing_header, actor: current_user).track(:namespace_created, namespace: group) + end end end diff --git a/app/services/groups/update_statistics_service.rb b/app/services/groups/update_statistics_service.rb new file mode 100644 index 00000000000..9efce79ef42 --- /dev/null +++ b/app/services/groups/update_statistics_service.rb @@ -0,0 +1,28 @@ +# frozen_string_literal: true + +module Groups + class UpdateStatisticsService + attr_reader :group, :statistics + + def initialize(group, statistics: []) + @group = group + @statistics = statistics + end + + def execute + unless group + return ServiceResponse.error(message: 'Invalid group', http_status: 400) + end + + namespace_statistics.refresh!(only: statistics.map(&:to_sym)) + + ServiceResponse.success(message: 'Group statistics successfully updated.') + end + + private + + def namespace_statistics + @namespace_statistics ||= group.namespace_statistics || group.build_namespace_statistics + end + end +end |