diff options
| author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2013-09-26 14:49:22 +0300 | 
|---|---|---|
| committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2013-09-26 14:49:22 +0300 | 
| commit | 65b9768ccfbdc3de682d66430601cf3af1b2a2f8 (patch) | |
| tree | b414c17b43b098b92b27cb1bb2cf1ffe40644f0c | |
| parent | edd2143d35d439e203d53b5e413f71e9f02db139 (diff) | |
| download | gitlab-ce-65b9768ccfbdc3de682d66430601cf3af1b2a2f8.tar.gz | |
Group ownership completely based on users_groups relation now
Before we have only owner_id to determine group owner
With multiple owners per group we should get rid of owner_id in group.
So from now @group.owner will always be nil but
@group.owners return an actual array of users who can admin this group
| -rw-r--r-- | app/controllers/admin/groups_controller.rb | 11 | ||||
| -rw-r--r-- | app/controllers/groups_controller.rb | 2 | ||||
| -rw-r--r-- | app/controllers/profiles/groups_controller.rb | 4 | ||||
| -rw-r--r-- | app/models/ability.rb | 4 | ||||
| -rw-r--r-- | app/models/group.rb | 25 | ||||
| -rw-r--r-- | app/models/namespace.rb | 2 | ||||
| -rw-r--r-- | app/models/project.rb | 10 | ||||
| -rw-r--r-- | app/models/user.rb | 2 | ||||
| -rw-r--r-- | app/services/system_hooks_service.rb | 6 | ||||
| -rw-r--r-- | app/views/admin/groups/index.html.haml | 7 | ||||
| -rw-r--r-- | app/views/admin/groups/show.html.haml | 23 | ||||
| -rw-r--r-- | app/views/admin/projects/show.html.haml | 2 | 
12 files changed, 32 insertions, 66 deletions
| diff --git a/app/controllers/admin/groups_controller.rb b/app/controllers/admin/groups_controller.rb index a2201f732e6..89b395786b3 100644 --- a/app/controllers/admin/groups_controller.rb +++ b/app/controllers/admin/groups_controller.rb @@ -20,9 +20,9 @@ class Admin::GroupsController < Admin::ApplicationController    def create      @group = Group.new(params[:group])      @group.path = @group.name.dup.parameterize if @group.name -    @group.owner = current_user      if @group.save +      @group.add_owner(current_user)        redirect_to [:admin, @group], notice: 'Group was successfully created.'      else        render "new" @@ -30,14 +30,7 @@ class Admin::GroupsController < Admin::ApplicationController    end    def update -    group_params = params[:group].dup -    owner_id =group_params.delete(:owner_id) - -    if owner_id -      @group.change_owner(User.find(owner_id)) -    end - -    if @group.update_attributes(group_params) +    if @group.update_attributes(params[:group])        redirect_to [:admin, @group], notice: 'Group was successfully updated.'      else        render "edit" diff --git a/app/controllers/groups_controller.rb b/app/controllers/groups_controller.rb index caf8ef85e87..f80167da4cb 100644 --- a/app/controllers/groups_controller.rb +++ b/app/controllers/groups_controller.rb @@ -21,9 +21,9 @@ class GroupsController < ApplicationController    def create      @group = Group.new(params[:group])      @group.path = @group.name.dup.parameterize if @group.name -    @group.owner = current_user      if @group.save +      @group.add_owner(current_user)        redirect_to @group, notice: 'Group was successfully created.'      else        render action: "new" diff --git a/app/controllers/profiles/groups_controller.rb b/app/controllers/profiles/groups_controller.rb index e276d07b489..378ff6bcf34 100644 --- a/app/controllers/profiles/groups_controller.rb +++ b/app/controllers/profiles/groups_controller.rb @@ -8,8 +8,8 @@ class Profiles::GroupsController < ApplicationController    def leave      @users_group = group.users_groups.where(user_id: current_user.id).first -    if group.owner == current_user -      redirect_to(profile_groups_path, alert: "You can't leave group. You must transfer it to another owner before leaving.") +    if group.last_owner?(current_user) +      redirect_to(profile_groups_path, alert: "You can't leave group. You must add at least one more owner to it.")      else        @users_group.destroy        redirect_to(profile_groups_path, info: "You left #{group.name} group.") diff --git a/app/models/ability.rb b/app/models/ability.rb index ad070dad296..85476089145 100644 --- a/app/models/ability.rb +++ b/app/models/ability.rb @@ -79,7 +79,7 @@ class Ability          rules << project_admin_rules        end -      if project.group && project.group.owners.include?(user) +      if project.group && project.group.has_owner?(user)          rules << project_admin_rules        end @@ -159,7 +159,7 @@ class Ability        end        # Only group owner and administrators can manage group -      if group.owners.include?(user) || user.admin? +      if group.has_owner?(user) || user.admin?          rules << [            :manage_group,            :manage_namespace diff --git a/app/models/group.rb b/app/models/group.rb index 0b36c934375..0cc3a3a0f41 100644 --- a/app/models/group.rb +++ b/app/models/group.rb @@ -16,14 +16,12 @@ class Group < Namespace    has_many :users_groups, dependent: :destroy    has_many :users, through: :users_groups -  after_create :add_owner -    def human_name      name    end    def owners -    @owners ||= (users_groups.owners.map(&:user) << owner).uniq +    @owners ||= users_groups.owners.map(&:user)    end    def add_users(user_ids, group_access) @@ -36,20 +34,19 @@ class Group < Namespace      self.users_groups.create(user_id: user.id, group_access: group_access)    end -  def change_owner(user) -    self.owner = user -    membership = users_groups.where(user_id: user.id).first +  def add_owner(user) +    self.add_user(user, UsersGroup::OWNER) +  end -    if membership -      membership.update_attributes(group_access: UsersGroup::OWNER) -    else -      add_owner -    end +  def has_owner?(user) +    owners.include?(user)    end -  private +  def last_owner?(user) +    has_owner?(user) && owners.size == 1 +  end -  def add_owner -    self.add_users([owner.id], UsersGroup::OWNER) +  def members +    users_groups    end  end diff --git a/app/models/namespace.rb b/app/models/namespace.rb index 18959166931..6ac94c06604 100644 --- a/app/models/namespace.rb +++ b/app/models/namespace.rb @@ -20,7 +20,7 @@ class Namespace < ActiveRecord::Base    has_many :projects, dependent: :destroy    belongs_to :owner, class_name: "User" -  validates :owner, presence: true +  validates :owner, presence: true, unless: ->(n) { n.type == "Group" }    validates :name, presence: true, uniqueness: true,              length: { within: 0..255 },              format: { with: Gitlab::Regex.name_regex, diff --git a/app/models/project.rb b/app/models/project.rb index 63cd3505ec4..c4f4b06713d 100644 --- a/app/models/project.rb +++ b/app/models/project.rb @@ -249,10 +249,10 @@ class Project < ActiveRecord::Base    end    def owner -    if namespace -      namespace_owner +    if group +      group      else -      creator +      namespace.try(:owner)      end    end @@ -276,10 +276,6 @@ class Project < ActiveRecord::Base                               end    end -  def namespace_owner -    namespace.try(:owner) -  end -    def path_with_namespace      if namespace        namespace.path + '/' + path diff --git a/app/models/user.rb b/app/models/user.rb index ea004e4c9a7..f1f93eadc1a 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -135,7 +135,7 @@ class User < ActiveRecord::Base        # Remove user from all groups        user.users_groups.find_each do |membership|          # skip owned resources -        next if membership.group.owners.include?(user) +        next if membership.group.last_owner?(user)          return false unless membership.destroy        end diff --git a/app/services/system_hooks_service.rb b/app/services/system_hooks_service.rb index c872b27ba39..39aec943f75 100644 --- a/app/services/system_hooks_service.rb +++ b/app/services/system_hooks_service.rb @@ -23,13 +23,15 @@ class SystemHooksService      case model      when Project +      owner = model.owner +        data.merge!({          name: model.name,          path: model.path,          path_with_namespace: model.path_with_namespace,          project_id: model.id, -        owner_name: model.owner.name, -        owner_email: model.owner.email +        owner_name: owner.name, +        owner_email: owner.respond_to?(:email) ?  owner.email : nil        })      when User        data.merge!({ diff --git a/app/views/admin/groups/index.html.haml b/app/views/admin/groups/index.html.haml index 8e45dc76ec6..c9d7c24f204 100644 --- a/app/views/admin/groups/index.html.haml +++ b/app/views/admin/groups/index.html.haml @@ -31,11 +31,8 @@        .clearfix.light.append-bottom-10          %span -          %b Owner: -          - if group.owner -            = link_to group.owner_name, admin_user_path(group.owner) -          - else -            (deleted) +          %b Members: +          %span.badge= group.members.size          \|          %span            %b Projects: diff --git a/app/views/admin/groups/show.html.haml b/app/views/admin/groups/show.html.haml index 5509811bae5..1566c345809 100644 --- a/app/views/admin/groups/show.html.haml +++ b/app/views/admin/groups/show.html.haml @@ -25,26 +25,6 @@              = @group.description          %li -          %span.light Owned by: -          %strong -            - if @group.owner -              = link_to @group.owner_name, admin_user_path(@group.owner) -            - else -              (deleted) -          .pull-right -            = link_to "#", class: "btn btn-small change-owner-link" do -              %i.icon-edit -              Change owner -        %li.change-owner-holder.hide.bgred -          .form-holder -            %strong.cred New Owner: -            = form_for [:admin, @group] do |f| -              = users_select_tag(:"group[owner_id]") -              .prepend-top-10 -                = f.submit 'Change Owner', class: "btn btn-remove" -                = link_to "Cancel", "#", class: "btn change-owner-cancel-link" - -        %li            %span.light Created at:            %strong              = @group.created_at.stamp("March 1, 1999") @@ -92,4 +72,5 @@                = link_to user.name, admin_user_path(user)              %span.pull-right.light                = member.human_access - +              = link_to group_users_group_path(@group, member), confirm: remove_user_from_group_message(@group, user), method: :delete, remote: true, class: "btn-tiny btn btn-remove", title: 'Remove user from group' do +                %i.icon-minus.icon-white diff --git a/app/views/admin/projects/show.html.haml b/app/views/admin/projects/show.html.haml index cecc84fe093..c8a87328207 100644 --- a/app/views/admin/projects/show.html.haml +++ b/app/views/admin/projects/show.html.haml @@ -25,7 +25,7 @@            %span.light Owned by:            %strong              - if @project.owner -              = link_to @project.owner_name, admin_user_path(@project.owner) +              = link_to @project.owner_name, [:admin, @project.owner]              - else                (deleted) | 
