Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
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
Jérome Perrin
gitlab-ce
Commits
cd01e828
Commit
cd01e828
authored
Jul 13, 2017
by
Alexis Reigel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
store gpg user name and email on the signature
parent
506836a6
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
88 additions
and
22 deletions
+88
-22
app/models/gpg_key.rb
app/models/gpg_key.rb
+11
-5
db/migrate/20170713104235_add_gpg_key_user_info_to_gpg_signatures.rb
...20170713104235_add_gpg_key_user_info_to_gpg_signatures.rb
+11
-0
db/schema.rb
db/schema.rb
+2
-0
lib/gitlab/gpg.rb
lib/gitlab/gpg.rb
+4
-2
lib/gitlab/gpg/commit.rb
lib/gitlab/gpg/commit.rb
+15
-6
spec/lib/gitlab/gpg/commit_spec.rb
spec/lib/gitlab/gpg/commit_spec.rb
+6
-0
spec/lib/gitlab/gpg_spec.rb
spec/lib/gitlab/gpg_spec.rb
+8
-6
spec/models/gpg_key_spec.rb
spec/models/gpg_key_spec.rb
+23
-3
spec/support/gpg_helpers.rb
spec/support/gpg_helpers.rb
+8
-0
No files found.
app/models/gpg_key.rb
View file @
cd01e828
...
...
@@ -37,15 +37,21 @@ class GpgKey < ActiveRecord::Base
write_attribute
(
:key
,
value
)
end
def
emails
@emails
||=
Gitlab
::
Gpg
.
emails_from_key
(
key
)
def
user_infos
@user_infos
||=
Gitlab
::
Gpg
.
user_infos_from_key
(
key
)
end
def
verified_user_infos
user_infos
.
select
do
|
user_info
|
user_info
[
:email
]
==
user
.
email
end
end
def
emails_with_verified_status
emails
.
map
do
|
email
|
user_infos
.
map
do
|
user_info
|
[
email
,
email
==
user
.
email
user_info
[
:email
]
,
user_info
[
:email
]
==
user
.
email
]
end
.
to_h
end
...
...
db/migrate/20170713104235_add_gpg_key_user_info_to_gpg_signatures.rb
0 → 100644
View file @
cd01e828
# See http://doc.gitlab.com/ce/development/migration_style_guide.html
# for more information on how to write migrations for GitLab.
class
AddGpgKeyUserInfoToGpgSignatures
<
ActiveRecord
::
Migration
DOWNTIME
=
false
def
change
add_column
:gpg_signatures
,
:gpg_key_user_name
,
:string
add_column
:gpg_signatures
,
:gpg_key_user_email
,
:string
end
end
db/schema.rb
View file @
cd01e828
...
...
@@ -560,6 +560,8 @@ ActiveRecord::Schema.define(version: 20170725145659) do
t
.
boolean
"valid_signature"
t
.
datetime
"created_at"
,
null:
false
t
.
datetime
"updated_at"
,
null:
false
t
.
string
"gpg_key_user_name"
t
.
string
"gpg_key_user_email"
end
add_index
"gpg_signatures"
,
[
"commit_sha"
],
name:
"index_gpg_signatures_on_commit_sha"
,
using: :btree
...
...
lib/gitlab/gpg.rb
View file @
cd01e828
...
...
@@ -32,11 +32,13 @@ module Gitlab
end
end
def
email
s_from_key
(
key
)
def
user_info
s_from_key
(
key
)
using_tmp_keychain
do
fingerprints
=
CurrentKeyChain
.
fingerprints_from_key
(
key
)
GPGME
::
Key
.
find
(
:public
,
fingerprints
).
flat_map
{
|
raw_key
|
raw_key
.
uids
.
map
(
&
:email
)
}
GPGME
::
Key
.
find
(
:public
,
fingerprints
).
flat_map
do
|
raw_key
|
raw_key
.
uids
.
map
{
|
uid
|
{
name:
uid
.
name
,
email:
uid
.
email
}
}
end
end
end
...
...
lib/gitlab/gpg/commit.rb
View file @
cd01e828
...
...
@@ -26,10 +26,7 @@ module Gitlab
def
update_signature!
(
cached_signature
)
using_keychain
do
|
gpg_key
|
cached_signature
.
update_attributes!
(
valid_signature:
gpg_signature_valid_signature_value
(
gpg_key
),
gpg_key:
gpg_key
)
cached_signature
.
update_attributes!
(
attributes
(
gpg_key
))
end
end
...
...
@@ -59,18 +56,30 @@ module Gitlab
end
def
create_cached_signature!
(
gpg_key
)
GpgSignature
.
create!
(
GpgSignature
.
create!
(
attributes
(
gpg_key
))
end
def
attributes
(
gpg_key
)
user_infos
=
user_infos
(
gpg_key
)
{
commit_sha:
commit
.
sha
,
project:
commit
.
project
,
gpg_key:
gpg_key
,
gpg_key_primary_keyid:
gpg_key
&
.
primary_keyid
||
verified_signature
.
fingerprint
,
gpg_key_user_name:
user_infos
[
:name
],
gpg_key_user_email:
user_infos
[
:email
],
valid_signature:
gpg_signature_valid_signature_value
(
gpg_key
)
)
}
end
def
gpg_signature_valid_signature_value
(
gpg_key
)
!!
(
gpg_key
&&
gpg_key
.
verified?
&&
verified_signature
.
valid?
)
end
def
user_infos
(
gpg_key
)
gpg_key
&
.
verified_user_infos
&
.
first
||
gpg_key
&
.
user_infos
&
.
first
||
{}
end
end
end
end
spec/lib/gitlab/gpg/commit_spec.rb
View file @
cd01e828
...
...
@@ -32,6 +32,8 @@ RSpec.describe Gitlab::Gpg::Commit do
project:
project
,
gpg_key:
gpg_key
,
gpg_key_primary_keyid:
GpgHelpers
::
User1
.
primary_keyid
,
gpg_key_user_name:
GpgHelpers
::
User1
.
names
.
first
,
gpg_key_user_email:
GpgHelpers
::
User1
.
emails
.
first
,
valid_signature:
true
)
end
...
...
@@ -67,6 +69,8 @@ RSpec.describe Gitlab::Gpg::Commit do
project:
project
,
gpg_key:
gpg_key
,
gpg_key_primary_keyid:
GpgHelpers
::
User1
.
primary_keyid
,
gpg_key_user_name:
GpgHelpers
::
User1
.
names
.
first
,
gpg_key_user_email:
GpgHelpers
::
User1
.
emails
.
first
,
valid_signature:
false
)
end
...
...
@@ -102,6 +106,8 @@ RSpec.describe Gitlab::Gpg::Commit do
project:
project
,
gpg_key:
nil
,
gpg_key_primary_keyid:
GpgHelpers
::
User1
.
primary_keyid
,
gpg_key_user_name:
nil
,
gpg_key_user_email:
nil
,
valid_signature:
false
)
end
...
...
spec/lib/gitlab/gpg_spec.rb
View file @
cd01e828
...
...
@@ -28,16 +28,18 @@ describe Gitlab::Gpg do
end
end
describe
'.emails_from_key'
do
it
'returns the emails'
do
expect
(
described_class
.
emails_from_key
(
GpgHelpers
::
User1
.
public_key
)
).
to
eq
GpgHelpers
::
User1
.
emails
describe
'.user_infos_from_key'
do
it
'returns the names and emails'
do
user_infos
=
described_class
.
user_infos_from_key
(
GpgHelpers
::
User1
.
public_key
)
expect
(
user_infos
).
to
eq
([{
name:
GpgHelpers
::
User1
.
names
.
first
,
email:
GpgHelpers
::
User1
.
emails
.
first
}])
end
it
'returns an empty array when the key is invalid'
do
expect
(
described_class
.
email
s_from_key
(
'bogus'
)
described_class
.
user_info
s_from_key
(
'bogus'
)
).
to
eq
[]
end
end
...
...
spec/models/gpg_key_spec.rb
View file @
cd01e828
...
...
@@ -46,11 +46,31 @@ describe GpgKey do
end
end
describe
'#
email
s'
do
it
'returns the
email
s from the gpg key'
do
describe
'#
user_info
s'
do
it
'returns the
user info
s from the gpg key'
do
gpg_key
=
create
:gpg_key
,
key:
GpgHelpers
::
User1
.
public_key
expect
(
Gitlab
::
Gpg
).
to
receive
(
:user_infos_from_key
).
with
(
gpg_key
.
key
)
expect
(
gpg_key
.
emails
).
to
eq
GpgHelpers
::
User1
.
emails
gpg_key
.
user_infos
end
end
describe
'#verified_user_infos'
do
it
'returns the user infos if it is verified'
do
user
=
create
:user
,
email:
GpgHelpers
::
User1
.
emails
.
first
gpg_key
=
create
:gpg_key
,
key:
GpgHelpers
::
User1
.
public_key
,
user:
user
expect
(
gpg_key
.
verified_user_infos
).
to
eq
([{
name:
GpgHelpers
::
User1
.
names
.
first
,
email:
GpgHelpers
::
User1
.
emails
.
first
}])
end
it
'returns an empty array if the user info is not verified'
do
user
=
create
:user
,
email:
'unrelated@example.com'
gpg_key
=
create
:gpg_key
,
key:
GpgHelpers
::
User1
.
public_key
,
user:
user
expect
(
gpg_key
.
verified_user_infos
).
to
eq
([])
end
end
...
...
spec/support/gpg_helpers.rb
View file @
cd01e828
...
...
@@ -98,6 +98,10 @@ module GpgHelpers
'5F7EA3981A5845B141ABD522CCFBE19F00AC8B1D'
end
def
names
[
'Nannie Bernhard'
]
end
def
emails
[
'nannie.bernhard@example.com'
]
end
...
...
@@ -187,6 +191,10 @@ module GpgHelpers
'6D494CA6FC90C0CAE0910E42BF9D925F911EFD65'
end
def
names
[
'Bette Cartwright'
,
'Bette Cartwright'
]
end
def
emails
[
'bette.cartwright@example.com'
,
'bette.cartwright@example.net'
]
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