Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
李少辉-开发者
gitlab-foss
提交
116d8cfc
G
gitlab-foss
项目概览
李少辉-开发者
/
gitlab-foss
通知
15
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
gitlab-foss
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
116d8cfc
编写于
12月 03, 2017
作者:
E
Eric Eastwood
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix new personal access token showing up in a flash message
上级
e0f84130
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
52 addition
and
5 deletion
+52
-5
app/controllers/profiles/personal_access_tokens_controller.rb
...controllers/profiles/personal_access_tokens_controller.rb
+3
-1
app/models/personal_access_token.rb
app/models/personal_access_token.rb
+21
-0
app/views/profiles/personal_access_tokens/index.html.haml
app/views/profiles/personal_access_tokens/index.html.haml
+3
-4
spec/models/personal_access_token_spec.rb
spec/models/personal_access_token_spec.rb
+25
-0
未找到文件。
app/controllers/profiles/personal_access_tokens_controller.rb
浏览文件 @
116d8cfc
...
...
@@ -8,7 +8,7 @@ class Profiles::PersonalAccessTokensController < Profiles::ApplicationController
@personal_access_token
=
finder
.
build
(
personal_access_token_params
)
if
@personal_access_token
.
save
flash
[
:personal_access_token
]
=
@personal_access_token
.
token
PersonalAccessToken
.
redis_store!
(
current_user
.
id
,
@personal_access_token
.
token
)
redirect_to
profile_personal_access_tokens_path
,
notice:
"Your new personal access token has been created."
else
set_index_vars
...
...
@@ -43,5 +43,7 @@ class Profiles::PersonalAccessTokensController < Profiles::ApplicationController
@inactive_personal_access_tokens
=
finder
(
state:
'inactive'
).
execute
@active_personal_access_tokens
=
finder
(
state:
'active'
).
execute
.
order
(
:expires_at
)
@new_personal_access_token
=
PersonalAccessToken
.
redis_getdel
(
current_user
.
id
)
end
end
app/models/personal_access_token.rb
浏览文件 @
116d8cfc
...
...
@@ -3,6 +3,8 @@ class PersonalAccessToken < ActiveRecord::Base
include
TokenAuthenticatable
add_authentication_token_field
:token
REDIS_EXPIRY_TIME
=
3
.
minutes
serialize
:scopes
,
Array
# rubocop:disable Cop/ActiveRecordSerialize
belongs_to
:user
...
...
@@ -27,6 +29,21 @@ class PersonalAccessToken < ActiveRecord::Base
!
revoked?
&&
!
expired?
end
def
self
.
redis_getdel
(
user_id
)
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
token
=
redis
.
get
(
redis_shared_state_key
(
user_id
))
redis
.
del
(
redis_shared_state_key
(
user_id
))
token
end
end
def
self
.
redis_store!
(
user_id
,
token
)
Gitlab
::
Redis
::
SharedState
.
with
do
|
redis
|
redis
.
set
(
redis_shared_state_key
(
user_id
),
token
,
ex:
REDIS_EXPIRY_TIME
)
token
end
end
protected
def
validate_scopes
...
...
@@ -38,4 +55,8 @@ class PersonalAccessToken < ActiveRecord::Base
def
set_default_scopes
self
.
scopes
=
Gitlab
::
Auth
::
DEFAULT_SCOPES
if
self
.
scopes
.
empty?
end
def
self
.
redis_shared_state_key
(
user_id
)
"gitlab:personal_access_token:
#{
user_id
}
"
end
end
app/views/profiles/personal_access_tokens/index.html.haml
浏览文件 @
116d8cfc
...
...
@@ -15,14 +15,13 @@
They are the only accepted password when you have Two-Factor Authentication (2FA) enabled.
.col-lg-8
-
if
flash
[
:personal_access_token
]
-
if
@new_personal_access_token
.created-personal-access-token-container
%h5
.prepend-top-0
Your New Personal Access Token
.form-group
=
text_field_tag
'created-personal-access-token'
,
flash
[
:personal_access_token
]
,
readonly:
true
,
class:
"form-control js-select-on-focus"
,
'aria-describedby'
=>
"created-personal-access-token-help-block"
=
clipboard_button
(
text:
flash
[
:personal_access_token
]
,
title:
"Copy personal access token to clipboard"
,
placement:
"left"
)
=
text_field_tag
'created-personal-access-token'
,
@new_personal_access_token
,
readonly:
true
,
class:
"form-control js-select-on-focus"
,
'aria-describedby'
=>
"created-personal-access-token-help-block"
=
clipboard_button
(
text:
@new_personal_access_token
,
title:
"Copy personal access token to clipboard"
,
placement:
"left"
)
%span
#created-personal-access-token-help-block
.help-block.text-danger
Make sure you save it - you won't be able to access it again.
%hr
...
...
spec/models/personal_access_token_spec.rb
浏览文件 @
116d8cfc
require
'spec_helper'
describe
PersonalAccessToken
do
subject
{
described_class
}
describe
'.build'
do
let
(
:personal_access_token
)
{
build
(
:personal_access_token
)
}
let
(
:invalid_personal_access_token
)
{
build
(
:personal_access_token
,
:invalid
)
}
...
...
@@ -45,6 +47,29 @@ describe PersonalAccessToken do
end
end
describe
'Redis storage'
do
let
(
:user_id
)
{
123
}
let
(
:token
)
{
'abc000foo'
}
before
do
subject
.
redis_store!
(
user_id
,
token
)
end
it
'returns stored data'
do
expect
(
subject
.
redis_getdel
(
user_id
)).
to
eq
(
token
)
end
context
'after deletion'
do
before
do
expect
(
subject
.
redis_getdel
(
user_id
)).
to
eq
(
token
)
end
it
'token is removed'
do
expect
(
subject
.
redis_getdel
(
user_id
)).
to
be_nil
end
end
end
context
"validations"
do
let
(
:personal_access_token
)
{
build
(
:personal_access_token
)
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录