personal_access_tokens_controller.rb 1.4 KB
Newer Older
1
class Profiles::PersonalAccessTokensController < Profiles::ApplicationController
2
  def index
3
    set_index_vars
4 5 6
  end

  def create
7
    @personal_access_token = finder.build(personal_access_token_params)
8 9

    if @personal_access_token.save
10
      flash[:personal_access_token] = @personal_access_token.token
T
Timothy Andrew 已提交
11
      redirect_to profile_personal_access_tokens_path, notice: "Your new personal access token has been created."
12
    else
13
      set_index_vars
14 15 16 17
      render :index
    end
  end

18
  def revoke
19
    @personal_access_token = finder.find(params[:id])
20 21

    if @personal_access_token.revoke!
T
Timothy Andrew 已提交
22
      flash[:notice] = "Revoked personal access token #{@personal_access_token.name}!"
23
    else
T
Timothy Andrew 已提交
24
      flash[:alert] = "Could not revoke personal access token #{@personal_access_token.name}."
25
    end
T
Timothy Andrew 已提交
26 27

    redirect_to profile_personal_access_tokens_path
28 29
  end

30 31
  private

32 33
  def finder(options = {})
    PersonalAccessTokensFinder.new({ user: current_user, impersonation: false }.merge(options))
34 35
  end

36
  def personal_access_token_params
37
    params.require(:personal_access_token).permit(:name, :expires_at, scopes: [])
38
  end
39

40
  def set_index_vars
41
    @scopes = Gitlab::Auth.available_scopes
42 43 44 45

    @personal_access_token = finder.build
    @inactive_personal_access_tokens = finder(state: 'inactive').execute
    @active_personal_access_tokens = finder(state: 'active').execute.order(:expires_at)
46
  end
47
end