16387: Allow batch update to set is_active=false for a remote user.
authorTom Clegg <tom@tomclegg.ca>
Mon, 4 May 2020 14:53:21 +0000 (10:53 -0400)
committerTom Clegg <tom@tomclegg.ca>
Mon, 4 May 2020 14:53:21 +0000 (10:53 -0400)
Arvados-DCO-1.1-Signed-off-by: Tom Clegg <tom@tomclegg.ca>

services/api/app/controllers/arvados/v1/users_controller.rb
services/api/app/models/user.rb

index d9ab5556ffc9ac7826abda00bc18e3d4b700269c..62da35ae86a626486b37e2c0943e65e0b1dfb75f 100644 (file)
@@ -54,7 +54,10 @@ class Arvados::V1::UsersController < ApplicationController
       @object = current_user
     end
     if not @object.is_active
-      if not (current_user.is_admin or @object.is_invited)
+      if @object.uuid[0..4] != Rails.configuration.ClusterID
+        logger.warn "Remote user #{@object.uuid} called users.activate"
+        raise ArgumentError.new "cannot activate remote account"
+      elsif not (current_user.is_admin or @object.is_invited)
         logger.warn "User #{@object.uuid} called users.activate " +
           "but is not invited"
         raise ArgumentError.new "Cannot activate without being invited."
index dd447ca51a895fa2297d6860002a52ff7f360037..ba451eb1846b321598435aac82ca241d1fccbe59 100644 (file)
@@ -239,8 +239,9 @@ class User < ArvadosModel
 
   def must_unsetup_to_deactivate
     if self.is_active_changed? &&
-       self.is_active_was == true &&
-       !self.is_active
+       self.is_active_was &&
+       !self.is_active &&
+       self.uuid[0..4] == Rails.configuration.ClusterID
 
       group = Group.where(name: 'All users').select do |g|
         g[:uuid].match(/-f+$/)