summaryrefslogtreecommitdiff
path: root/lib/api/internal.rb
diff options
context:
space:
mode:
authorPatricio Cano <suprnova32@gmail.com>2016-08-29 13:05:07 -0500
committerPatricio Cano <suprnova32@gmail.com>2016-09-15 12:21:00 -0500
commitcb85cf1f0a7047c485d7b29b2792b8965e270898 (patch)
treec681b20e379478042e718afa1473af209af126a0 /lib/api/internal.rb
parent372be2d2e8fe8d607011aa7e2b2fca99eeea007d (diff)
downloadgitlab-ce-cb85cf1f0a7047c485d7b29b2792b8965e270898.tar.gz
Refactor LFS token logic to use a Redis key instead of a DB field, making it a 1 use only token.
Diffstat (limited to 'lib/api/internal.rb')
-rw-r--r--lib/api/internal.rb9
1 files changed, 5 insertions, 4 deletions
diff --git a/lib/api/internal.rb b/lib/api/internal.rb
index 7c0a6eaa652..760f69663ab 100644
--- a/lib/api/internal.rb
+++ b/lib/api/internal.rb
@@ -88,12 +88,13 @@ module API
get "/discover" do
key = Key.find(params[:key_id])
user = key.user
+
if user
- user.ensure_lfs_token!
- present user, with: Entities::UserSafe
+ token = Gitlab::LfsToken.new(user).set_token
+ { name: user.name, username: user.username, lfs_token: token }
else
- key.ensure_lfs_token!
- { username: 'lfs-deploy-key', lfs_token: key.lfs_token }
+ token = Gitlab::LfsToken.new(key).set_token
+ { username: "lfs-deploy-key-#{key.id}", lfs_token: token }
end
end