Sha256: 40fb9ccc2230ef475b1e199432cc545027984be64ad99e5ffbe0b8c1f804b131

Contents?: true

Size: 1.91 KB

Versions: 17

Compression:

Stored size: 1.91 KB

Contents

# frozen_string_literal: true

module Decidim
  module Admin
    # A command with all the business logic to impersonate a managed user.
    class ImpersonateUser < Decidim::Command
      # Public: Initializes the command.
      #
      # form         - The form with the authorization info
      # user         - The user to impersonate
      def initialize(form)
        @form = form
      end

      # Executes the command. Broadcasts these events:
      #
      # - :ok when everything is valid.
      # - :invalid if the impersonation is not valid.
      #
      # Returns nothing.
      def call
        return broadcast(:invalid) unless form.valid?

        transaction do
          user.save! unless user.persisted?

          create_authorization

          impersonation_log = create_impersonation_log
          create_action_log(impersonation_log)
        end

        enqueue_expire_job

        broadcast(:ok)
      end

      private

      attr_reader :form

      def user
        form.user
      end

      def create_authorization
        Authorization.create_or_update_from(form.authorization)
      end

      def create_impersonation_log
        Decidim::ImpersonationLog.create!(
          admin: form.current_user,
          user:,
          reason: form.reason,
          started_at: Time.current
        )
      end

      def enqueue_expire_job
        Decidim::Admin::ExpireImpersonationJob
          .set(wait: Decidim::ImpersonationLog::SESSION_TIME_IN_MINUTES.minutes)
          .perform_later(user, form.current_user)
      end

      def create_action_log(impersonation_log)
        Decidim.traceability.perform_action!(
          "manage",
          impersonation_log,
          form.current_user,
          resource: {
            name: user.name,
            id: user.id,
            nickname: user.nickname
          },
          visibility: "admin-only",
          reason: form.reason
        )
      end
    end
  end
end

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
decidim-admin-0.30.0.rc2 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.30.0.rc1 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.2 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.5 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.1 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.4 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.0 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.3 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.0.rc4 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.0.rc3 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.0.rc2 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.29.0.rc1 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.2 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.1 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.0 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.0.rc5 app/commands/decidim/admin/impersonate_user.rb
decidim-admin-0.28.0.rc4 app/commands/decidim/admin/impersonate_user.rb