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
Léo-Paul Géneau
gitlab-ce
Commits
cbd78922
Commit
cbd78922
authored
Jan 14, 2012
by
Dmitriy Zaporozhets
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'deploy_keys'
Conflicts: app/views/layouts/project.html.haml db/schema.rb
parents
09b877ef
dda6b0ab
Changes
19
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
234 additions
and
8 deletions
+234
-8
app/controllers/deploy_keys_controller.rb
app/controllers/deploy_keys_controller.rb
+44
-0
app/models/key.rb
app/models/key.rb
+15
-2
app/models/project.rb
app/models/project.rb
+2
-1
app/views/deploy_keys/_form.html.haml
app/views/deploy_keys/_form.html.haml
+16
-0
app/views/deploy_keys/_show.html.haml
app/views/deploy_keys/_show.html.haml
+7
-0
app/views/deploy_keys/create.js.haml
app/views/deploy_keys/create.js.haml
+9
-0
app/views/deploy_keys/edit.html.haml
app/views/deploy_keys/edit.html.haml
+7
-0
app/views/deploy_keys/index.html.haml
app/views/deploy_keys/index.html.haml
+11
-0
app/views/deploy_keys/new.html.haml
app/views/deploy_keys/new.html.haml
+5
-0
app/views/deploy_keys/new.js.haml
app/views/deploy_keys/new.js.haml
+11
-0
app/views/deploy_keys/show.html.haml
app/views/deploy_keys/show.html.haml
+10
-0
app/views/layouts/project.html.haml
app/views/layouts/project.html.haml
+1
-0
app/views/repositories/_head.html.haml
app/views/repositories/_head.html.haml
+8
-3
config/routes.rb
config/routes.rb
+2
-0
db/migrate/20111231111825_add_project_id_to_key.rb
db/migrate/20111231111825_add_project_id_to_key.rb
+6
-0
db/schema.rb
db/schema.rb
+2
-1
spec/models/key_spec.rb
spec/models/key_spec.rb
+1
-1
spec/requests/projects_deploy_keys_spec.rb
spec/requests/projects_deploy_keys_spec.rb
+68
-0
spec/requests/projects_security_spec.rb
spec/requests/projects_security_spec.rb
+9
-0
No files found.
app/controllers/deploy_keys_controller.rb
0 → 100644
View file @
cbd78922
class
DeployKeysController
<
ApplicationController
respond_to
:js
,
:html
layout
"project"
before_filter
:project
# Authorize
before_filter
:add_project_abilities
before_filter
:authorize_admin_project!
def
project
@project
||=
Project
.
find_by_code
(
params
[
:project_id
])
end
def
index
@keys
=
@project
.
deploy_keys
.
all
end
def
show
@key
=
@project
.
deploy_keys
.
find
(
params
[
:id
])
end
def
new
@key
=
@project
.
deploy_keys
.
new
respond_with
(
@key
)
end
def
create
@key
=
@project
.
deploy_keys
.
new
(
params
[
:key
])
@key
.
save
respond_with
(
@key
)
end
def
destroy
@key
=
@project
.
deploy_keys
.
find
(
params
[
:id
])
@key
.
destroy
respond_to
do
|
format
|
format
.
html
{
redirect_to
project_deploy_keys_url
}
format
.
js
{
render
:nothing
=>
true
}
end
end
end
app/models/key.rb
View file @
cbd78922
class
Key
<
ActiveRecord
::
Base
class
Key
<
ActiveRecord
::
Base
belongs_to
:user
belongs_to
:user
belongs_to
:project
validates
:title
,
validates
:title
,
:presence
=>
true
,
:presence
=>
true
,
...
@@ -15,8 +16,12 @@ class Key < ActiveRecord::Base
...
@@ -15,8 +16,12 @@ class Key < ActiveRecord::Base
after_destroy
:repository_delete_key
after_destroy
:repository_delete_key
def
set_identifier
def
set_identifier
if
is_deploy_key
self
.
identifier
=
"deploy_
#{
project
.
code
}
_
#{
Time
.
now
.
to_i
}
"
else
self
.
identifier
=
"
#{
user
.
identifier
}
_
#{
Time
.
now
.
to_i
}
"
self
.
identifier
=
"
#{
user
.
identifier
}
_
#{
Time
.
now
.
to_i
}
"
end
end
end
def
update_repository
def
update_repository
Gitlabhq
::
GitHost
.
system
.
new
.
configure
do
|
c
|
Gitlabhq
::
GitHost
.
system
.
new
.
configure
do
|
c
|
...
@@ -32,10 +37,18 @@ class Key < ActiveRecord::Base
...
@@ -32,10 +37,18 @@ class Key < ActiveRecord::Base
end
end
end
end
def
is_deploy_key
true
if
project_id
end
#projects that has this key
#projects that has this key
def
projects
def
projects
if
is_deploy_key
[
project
]
else
user
.
projects
user
.
projects
end
end
end
end
end
# == Schema Information
# == Schema Information
#
#
...
...
app/models/project.rb
View file @
cbd78922
...
@@ -14,6 +14,7 @@ class Project < ActiveRecord::Base
...
@@ -14,6 +14,7 @@ class Project < ActiveRecord::Base
has_many
:users
,
:through
=>
:users_projects
has_many
:users
,
:through
=>
:users_projects
has_many
:notes
,
:dependent
=>
:destroy
has_many
:notes
,
:dependent
=>
:destroy
has_many
:snippets
,
:dependent
=>
:destroy
has_many
:snippets
,
:dependent
=>
:destroy
has_many
:deploy_keys
,
:dependent
=>
:destroy
,
:foreign_key
=>
"project_id"
,
:class_name
=>
"Key"
has_many
:web_hooks
,
:dependent
=>
:destroy
has_many
:web_hooks
,
:dependent
=>
:destroy
acts_as_taggable
acts_as_taggable
...
@@ -199,7 +200,7 @@ class Project < ActiveRecord::Base
...
@@ -199,7 +200,7 @@ class Project < ActiveRecord::Base
def
repository_readers
def
repository_readers
keys
=
Key
.
joins
({
:user
=>
:users_projects
}).
keys
=
Key
.
joins
({
:user
=>
:users_projects
}).
where
(
"users_projects.project_id = ? AND users_projects.repo_access = ?"
,
id
,
Repository
::
REPO_R
)
where
(
"users_projects.project_id = ? AND users_projects.repo_access = ?"
,
id
,
Repository
::
REPO_R
)
keys
.
map
(
&
:identifier
)
keys
.
map
(
&
:identifier
)
+
deploy_keys
.
map
(
&
:identifier
)
end
end
def
repository_writers
def
repository_writers
...
...
app/views/deploy_keys/_form.html.haml
0 → 100644
View file @
cbd78922
%div
=
form_for
[
@project
,
@key
],
:url
=>
project_deploy_keys_path
,
:remote
=>
true
do
|
f
|
-
if
@key
.
errors
.
any?
%ul
-
@key
.
errors
.
full_messages
.
each
do
|
msg
|
%li
=
msg
.form-row
=
f
.
label
:title
=
f
.
text_field
:title
,
:style
=>
"width:300px"
.form-row
=
f
.
label
:key
=
f
.
text_area
:key
,
:style
=>
"width:300px; height:130px"
.form-row
=
f
.
submit
'Save'
,
:class
=>
"grey-button"
app/views/deploy_keys/_show.html.haml
0 → 100644
View file @
cbd78922
%a
.update-item
{
:href
=>
project_deploy_key_path
(
key
.
project
,
key
)}
%span
.update-title
=
key
.
title
%span
.update-author
Added
=
time_ago_in_words
(
key
.
created_at
)
ago
app/views/deploy_keys/create.js.haml
0 → 100644
View file @
cbd78922
-
if
@key
.
valid?
:plain
$("#new_key_dialog").dialog("close");
$("#keys-table .data").append("
#{
escape_javascript
(
render
(
:partial
=>
'show'
,
:locals
=>
{
:key
=>
@key
}
))
}
");
$("#no_ssh_key_defined").hide();
-
else
:plain
$("#new_key_dialog").empty();
$("#new_key_dialog").append("
#{
escape_javascript
(
render
(
'form'
))
}
");
app/views/deploy_keys/edit.html.haml
0 → 100644
View file @
cbd78922
%h1
Editing key
=
render
'form'
=
link_to
'Show'
,
@key
\|
=
link_to
'Back'
,
project_deploy_keys_path
app/views/deploy_keys/index.html.haml
0 → 100644
View file @
cbd78922
=
render
"repositories/head"
%div
#keys-table
{
:class
=>
"update-data ui-box ui-box-small ui-box-big"
}
.data
-
@keys
.
each
do
|
key
|
=
render
(
:partial
=>
'show'
,
:locals
=>
{
:key
=>
key
})
:javascript
$
(
'
.delete-key
'
).
live
(
'
ajax:success
'
,
function
()
{
$
(
this
).
closest
(
'
.update-item
'
).
fadeOut
();
});
app/views/deploy_keys/new.html.haml
0 → 100644
View file @
cbd78922
%h1
New key
=
render
'form'
=
link_to
'Back'
,
project_deploy_keys_path
app/views/deploy_keys/new.js.haml
0 → 100644
View file @
cbd78922
:plain
var new_key_dialog = $("<div id='new_key_dialog'></div>");
new_key_dialog.html("
#{
escape_javascript
(
render
(
'form'
))
}
");
$(new_key_dialog).dialog({
width: 350,
resizable: false,
draggable: false,
title: "Add new public key",
close: function(event, ui) { $("#new_key_dialog").remove();},
modal: true
});
app/views/deploy_keys/show.html.haml
0 → 100644
View file @
cbd78922
.ui-box.width-100p
%h3
=
@key
.
title
.data
%pre
=
@key
.
key
.clear
.buttons
=
link_to
'Remove'
,
project_deploy_key_path
(
@key
.
project
,
@key
),
:confirm
=>
'Are you sure?'
,
:method
=>
:delete
,
:class
=>
"red-button delete-key right"
.clear
app/views/layouts/project.html.haml
View file @
cbd78922
...
@@ -44,5 +44,6 @@
...
@@ -44,5 +44,6 @@
%span{ :class => "number" }= @project.merge_requests.opened.count
%span{ :class => "number" }= @project.merge_requests.opened.count
.project-content
.project-content
=
yield
=
yield
app/views/repositories/_head.html.haml
View file @
cbd78922
...
@@ -11,7 +11,8 @@
...
@@ -11,7 +11,8 @@
=
link_to
project_hooks_path
,
:class
=>
"tab
#{
'active'
if
controller
.
controller_name
==
"hooks"
}
"
do
=
link_to
project_hooks_path
,
:class
=>
"tab
#{
'active'
if
controller
.
controller_name
==
"hooks"
}
"
do
%span
%span
Hooks
Hooks
-#= link_to "#", :class => "tab" do
-
if
can?
current_user
,
:admin_project
,
@project
=
link_to
project_deploy_keys_path
(
@project
),
:class
=>
"tab
#{
'active'
if
controller
.
controller_name
==
"deploy_keys"
}
"
do
%span
%span
Deploy Keys
Deploy Keys
...
@@ -20,4 +21,8 @@
...
@@ -20,4 +21,8 @@
=
link_to
new_project_hook_path
(
@project
),
:class
=>
"add_new"
,
:title
=>
"New Web Hook"
do
=
link_to
new_project_hook_path
(
@project
),
:class
=>
"add_new"
,
:title
=>
"New Web Hook"
do
=
image_tag
"add_new.png"
,
:width
=>
14
=
image_tag
"add_new.png"
,
:width
=>
14
-
if
current_page?
(
project_deploy_keys_path
(
@project
))
-
if
can?
current_user
,
:admin_project
,
@project
=
link_to
new_project_deploy_key_path
(
@project
),
:class
=>
"add_new"
,
:title
=>
"New Deploy Key"
,
:remote
=>
true
do
=
image_tag
"add_new.png"
,
:width
=>
14
config/routes.rb
View file @
cbd78922
...
@@ -53,6 +53,8 @@ Gitlab::Application.routes.draw do
...
@@ -53,6 +53,8 @@ Gitlab::Application.routes.draw do
end
end
end
end
resources
:deploy_keys
resources
:refs
,
:only
=>
[],
:path
=>
"/"
do
resources
:refs
,
:only
=>
[],
:path
=>
"/"
do
collection
do
collection
do
get
"switch"
get
"switch"
...
...
db/migrate/20111231111825_add_project_id_to_key.rb
0 → 100644
View file @
cbd78922
class
AddProjectIdToKey
<
ActiveRecord
::
Migration
def
change
add_column
:keys
,
:project_id
,
:integer
,
:null
=>
true
change_column
:keys
,
:user_id
,
:integer
,
:null
=>
true
end
end
db/schema.rb
View file @
cbd78922
...
@@ -39,12 +39,13 @@ ActiveRecord::Schema.define(:version => 20120110180749) do
...
@@ -39,12 +39,13 @@ ActiveRecord::Schema.define(:version => 20120110180749) do
end
end
create_table
"keys"
,
:force
=>
true
do
|
t
|
create_table
"keys"
,
:force
=>
true
do
|
t
|
t
.
integer
"user_id"
,
:null
=>
false
t
.
integer
"user_id"
t
.
datetime
"created_at"
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
datetime
"updated_at"
t
.
text
"key"
t
.
text
"key"
t
.
string
"title"
t
.
string
"title"
t
.
string
"identifier"
t
.
string
"identifier"
t
.
integer
"project_id"
end
end
create_table
"merge_requests"
,
:force
=>
true
do
|
t
|
create_table
"merge_requests"
,
:force
=>
true
do
|
t
|
...
...
spec/models/key_spec.rb
View file @
cbd78922
...
@@ -2,7 +2,7 @@ require 'spec_helper'
...
@@ -2,7 +2,7 @@ require 'spec_helper'
describe
Key
do
describe
Key
do
describe
"Associations"
do
describe
"Associations"
do
it
{
should
belong_to
(
:user
)
}
it
{
should
belong_to
(
:user
)
or
belong_to
(
:project
)
}
end
end
describe
"Validation"
do
describe
"Validation"
do
...
...
spec/requests/projects_deploy_keys_spec.rb
0 → 100644
View file @
cbd78922
require
'spec_helper'
describe
"Projects"
,
"DeployKeys"
do
let
(
:project
)
{
Factory
:project
}
before
do
login_as
:user
project
.
add_access
(
@user
,
:read
,
:write
,
:admin
)
end
describe
"GET /keys"
do
before
do
@key
=
Factory
:key
,
:project
=>
project
visit
project_deploy_keys_path
(
project
)
end
subject
{
page
}
it
{
should
have_content
(
@key
.
title
)
}
describe
"Destroy"
do
before
{
visit
project_deploy_key_path
(
project
,
@key
)
}
it
"should remove entry"
do
expect
{
click_link
"Remove"
}.
to
change
{
project
.
deploy_keys
.
count
}.
by
(
-
1
)
end
end
end
describe
"New key"
,
:js
=>
true
do
before
do
visit
project_deploy_keys_path
(
project
)
click_link
"New Deploy Key"
end
it
"should open new key popup"
do
page
.
should
have_content
(
"Add new public key"
)
end
describe
"fill in"
do
before
do
fill_in
"key_title"
,
:with
=>
"laptop"
fill_in
"key_key"
,
:with
=>
"publickey234="
end
it
{
expect
{
click_button
"Save"
}.
to
change
{
Key
.
count
}.
by
(
1
)
}
it
"should add new key to table"
do
click_button
"Save"
page
.
should_not
have_content
(
"Add new public key"
)
page
.
should
have_content
"laptop"
end
end
end
describe
"Show page"
do
before
do
@key
=
Factory
:key
,
:project
=>
project
visit
project_deploy_key_path
(
project
,
@key
)
end
it
{
page
.
should
have_content
@key
.
title
}
it
{
page
.
should
have_content
@key
.
key
[
0
..
10
]
}
end
end
spec/requests/projects_security_spec.rb
View file @
cbd78922
...
@@ -105,6 +105,15 @@ describe "Projects" do
...
@@ -105,6 +105,15 @@ describe "Projects" do
it
{
edit_project_path
(
@project
).
should
be_denied_for
:visitor
}
it
{
edit_project_path
(
@project
).
should
be_denied_for
:visitor
}
end
end
describe
"GET /project_code/deploy_keys"
do
it
{
project_deploy_keys_path
(
@project
).
should
be_allowed_for
@u1
}
it
{
project_deploy_keys_path
(
@project
).
should
be_denied_for
@u3
}
it
{
project_deploy_keys_path
(
@project
).
should
be_denied_for
:admin
}
it
{
project_deploy_keys_path
(
@project
).
should
be_denied_for
@u2
}
it
{
project_deploy_keys_path
(
@project
).
should
be_denied_for
:user
}
it
{
project_deploy_keys_path
(
@project
).
should
be_denied_for
:visitor
}
end
describe
"GET /project_code/issues"
do
describe
"GET /project_code/issues"
do
it
{
project_issues_path
(
@project
).
should
be_allowed_for
@u1
}
it
{
project_issues_path
(
@project
).
should
be_allowed_for
@u1
}
it
{
project_issues_path
(
@project
).
should
be_allowed_for
@u3
}
it
{
project_issues_path
(
@project
).
should
be_allowed_for
@u3
}
...
...
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