Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-shell
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-shell
Commits
f980d8f5
Commit
f980d8f5
authored
Jun 27, 2017
by
Michael Kozono
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add list-key-ids command
parent
7e41e378
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
41 additions
and
2 deletions
+41
-2
lib/gitlab_keys.rb
lib/gitlab_keys.rb
+13
-0
spec/gitlab_keys_spec.rb
spec/gitlab_keys_spec.rb
+28
-2
No files found.
lib/gitlab_keys.rb
View file @
f980d8f5
...
@@ -39,6 +39,8 @@ class GitlabKeys
...
@@ -39,6 +39,8 @@ class GitlabKeys
rm_key
rm_key
when
'list-keys'
;
when
'list-keys'
;
list_keys
list_keys
when
'list-key-ids'
;
list_key_ids
when
'clear'
;
when
'clear'
;
clear
clear
when
'check-permissions'
;
when
'check-permissions'
;
...
@@ -75,6 +77,17 @@ class GitlabKeys
...
@@ -75,6 +77,17 @@ class GitlabKeys
keys
keys
end
end
def
list_key_ids
$logger
.
info
'Listing all key IDs'
open_auth_file
(
'r'
)
do
|
f
|
f
.
each_line
do
|
line
|
matchd
=
line
.
match
(
/key-(\d+)/
)
next
unless
matchd
puts
matchd
[
1
]
end
end
end
def
batch_add_keys
def
batch_add_keys
lock
(
300
)
do
# Allow 300 seconds (5 minutes) for batch_add_keys
lock
(
300
)
do
# Allow 300 seconds (5 minutes) for batch_add_keys
open_auth_file
(
'a'
)
do
|
file
|
open_auth_file
(
'a'
)
do
|
file
|
...
...
spec/gitlab_keys_spec.rb
View file @
f980d8f5
...
@@ -80,6 +80,23 @@ describe GitlabKeys do
...
@@ -80,6 +80,23 @@ describe GitlabKeys do
end
end
end
end
describe
:list_key_ids
do
let
(
:gitlab_keys
)
{
build_gitlab_keys
(
'list-key-ids'
)
}
before
do
create_authorized_keys_fixture
(
existing_content:
"key-1
\t
ssh-dsa AAA
\n
key-2
\t
ssh-rsa BBB
\n
key-3
\t
ssh-rsa CCC
\n
key-9000
\t
ssh-rsa DDD
\n
"
)
end
it
'outputs the key IDs, separated by newlines'
do
output
=
capture_stdout
do
gitlab_keys
.
send
(
:list_key_ids
)
end
output
.
should
match
"1
\n
2
\n
3
\n
9000"
end
end
describe
:batch_add_keys
do
describe
:batch_add_keys
do
let
(
:gitlab_keys
)
{
build_gitlab_keys
(
'batch-add-keys'
)
}
let
(
:gitlab_keys
)
{
build_gitlab_keys
(
'batch-add-keys'
)
}
let
(
:fake_stdin
)
{
StringIO
.
new
(
"key-12
\t
ssh-dsa ASDFASGADG
\n
key-123
\t
ssh-rsa GFDGDFSGSDFG
\n
"
,
'r'
)
}
let
(
:fake_stdin
)
{
StringIO
.
new
(
"key-12
\t
ssh-dsa ASDFASGADG
\n
key-123
\t
ssh-rsa GFDGDFSGSDFG
\n
"
,
'r'
)
}
...
@@ -288,9 +305,9 @@ describe GitlabKeys do
...
@@ -288,9 +305,9 @@ describe GitlabKeys do
end
end
end
end
def
create_authorized_keys_fixture
def
create_authorized_keys_fixture
(
existing_content:
'existing content'
)
FileUtils
.
mkdir_p
(
File
.
dirname
(
tmp_authorized_keys_path
))
FileUtils
.
mkdir_p
(
File
.
dirname
(
tmp_authorized_keys_path
))
open
(
tmp_authorized_keys_path
,
'w'
)
{
|
file
|
file
.
puts
(
'existing content'
)
}
open
(
tmp_authorized_keys_path
,
'w'
)
{
|
file
|
file
.
puts
(
existing_content
)
}
gitlab_keys
.
stub
(
auth_file:
tmp_authorized_keys_path
)
gitlab_keys
.
stub
(
auth_file:
tmp_authorized_keys_path
)
end
end
...
@@ -301,4 +318,13 @@ describe GitlabKeys do
...
@@ -301,4 +318,13 @@ describe GitlabKeys do
def
tmp_lock_file_path
def
tmp_lock_file_path
tmp_authorized_keys_path
+
'.lock'
tmp_authorized_keys_path
+
'.lock'
end
end
def
capture_stdout
(
&
blk
)
old
=
$stdout
$stdout
=
fake
=
StringIO
.
new
blk
.
call
fake
.
string
ensure
$stdout
=
old
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment