Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
李少辉-开发者
gitlab-foss
提交
a8b4756f
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,发现更多精彩内容 >>
提交
a8b4756f
编写于
2月 04, 2015
作者:
D
Dmitriy Zaporozhets
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'mwessel/gitlab-ce-configure-protection' into 'master'
Mwessel/gitlab ce configure protection See merge request !1467
上级
0bcd5ca4
490cf7bf
变更
12
显示空白变更内容
内联
并排
Showing
12 changed file
with
74 addition
and
15 deletion
+74
-15
CHANGELOG
CHANGELOG
+2
-0
app/controllers/admin/application_settings_controller.rb
app/controllers/admin/application_settings_controller.rb
+1
-0
app/models/application_setting.rb
app/models/application_setting.rb
+2
-0
app/services/git_push_service.rb
app/services/git_push_service.rb
+8
-2
app/views/admin/application_settings/_form.html.haml
app/views/admin/application_settings/_form.html.haml
+4
-0
config/initializers/1_settings.rb
config/initializers/1_settings.rb
+1
-0
db/migrate/20150125163100_add_default_branch_protection_setting.rb
...e/20150125163100_add_default_branch_protection_setting.rb
+5
-0
db/schema.rb
db/schema.rb
+4
-3
lib/gitlab/access.rb
lib/gitlab/access.rb
+17
-0
lib/gitlab/current_settings.rb
lib/gitlab/current_settings.rb
+1
-0
spec/models/application_setting_spec.rb
spec/models/application_setting_spec.rb
+10
-9
spec/services/git_push_service_spec.rb
spec/services/git_push_service_spec.rb
+19
-1
未找到文件。
CHANGELOG
浏览文件 @
a8b4756f
...
...
@@ -30,6 +30,8 @@ v 7.8.0
-
- Async load a branch information at the commit page
-
- Allow configuring protection of the default branch upon first push (Marco Wessel)
-
-
- Add a commit calendar to the user profile (Hannes Rosenögger)
-
...
...
app/controllers/admin/application_settings_controller.rb
浏览文件 @
a8b4756f
...
...
@@ -22,6 +22,7 @@ class Admin::ApplicationSettingsController < Admin::ApplicationController
def
application_setting_params
params
.
require
(
:application_setting
).
permit
(
:default_projects_limit
,
:default_branch_protection
,
:signup_enabled
,
:signin_enabled
,
:gravatar_enabled
,
...
...
app/models/application_setting.rb
浏览文件 @
a8b4756f
...
...
@@ -4,6 +4,7 @@
#
# id :integer not null, primary key
# default_projects_limit :integer
# default_branch_protection :integer
# signup_enabled :boolean
# signin_enabled :boolean
# gravatar_enabled :boolean
...
...
@@ -26,6 +27,7 @@ class ApplicationSetting < ActiveRecord::Base
def
self
.
create_from_defaults
create
(
default_projects_limit:
Settings
.
gitlab
[
'default_projects_limit'
],
default_branch_protection:
Settings
.
gitlab
[
'default_branch_protection'
],
signup_enabled:
Settings
.
gitlab
[
'signup_enabled'
],
signin_enabled:
Settings
.
gitlab
[
'signin_enabled'
],
gravatar_enabled:
Settings
.
gravatar
[
'enabled'
],
...
...
app/services/git_push_service.rb
浏览文件 @
a8b4756f
class
GitPushService
attr_accessor
:project
,
:user
,
:push_data
,
:push_commits
include
Gitlab
::
CurrentSettings
include
Gitlab
::
Access
# This method will be called after each git update
# and only if the provided user and project is present in GitLab.
...
...
@@ -29,8 +31,12 @@ class GitPushService
if
is_default_branch?
(
ref
)
# Initial push to the default branch. Take the full history of that branch as "newly pushed".
@push_commits
=
project
.
repository
.
commits
(
newrev
)
# Default branch is protected by default
project
.
protected_branches
.
create
({
name:
project
.
default_branch
})
# Set protection on the default branch if configured
if
(
current_application_settings
.
default_branch_protection
!=
PROTECTION_NONE
)
developers_can_push
=
current_application_settings
.
default_branch_protection
==
PROTECTION_DEV_CAN_PUSH
?
true
:
false
project
.
protected_branches
.
create
({
name:
project
.
default_branch
,
developers_can_push:
developers_can_push
})
end
else
# Use the pushed commits that aren't reachable by the default branch
# as a heuristic. This may include more commits than are actually pushed, but
...
...
app/views/admin/application_settings/_form.html.haml
浏览文件 @
a8b4756f
...
...
@@ -25,6 +25,10 @@
=
f
.
label
:default_projects_limit
,
class:
'control-label'
.col-sm-10
=
f
.
number_field
:default_projects_limit
,
class:
'form-control'
.form-group
=
f
.
label
:default_branch_protection
,
class:
'control-label'
.col-sm-10
=
f
.
select
:default_branch_protection
,
options_for_select
(
Gitlab
::
Access
.
protection_options
,
@application_setting
.
default_branch_protection
),
{},
class:
'form-control'
.form-group
=
f
.
label
:home_page_url
,
class:
'control-label'
.col-sm-10
...
...
config/initializers/1_settings.rb
浏览文件 @
a8b4756f
...
...
@@ -87,6 +87,7 @@ Settings['issues_tracker'] ||= {}
#
Settings
[
'gitlab'
]
||=
Settingslogic
.
new
({})
Settings
.
gitlab
[
'default_projects_limit'
]
||=
10
Settings
.
gitlab
[
'default_branch_protection'
]
||=
2
Settings
.
gitlab
[
'default_can_create_group'
]
=
true
if
Settings
.
gitlab
[
'default_can_create_group'
].
nil?
Settings
.
gitlab
[
'default_theme'
]
=
Gitlab
::
Theme
::
MARS
if
Settings
.
gitlab
[
'default_theme'
].
nil?
Settings
.
gitlab
[
'host'
]
||=
'localhost'
...
...
db/migrate/20150125163100_add_default_branch_protection_setting.rb
0 → 100644
浏览文件 @
a8b4756f
class
AddDefaultBranchProtectionSetting
<
ActiveRecord
::
Migration
def
change
add_column
:application_settings
,
:default_branch_protection
,
:integer
,
:default
=>
2
end
end
db/schema.rb
浏览文件 @
a8b4756f
...
...
@@ -11,7 +11,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord
::
Schema
.
define
(
version:
201501
16234545
)
do
ActiveRecord
::
Schema
.
define
(
version:
201501
25163100
)
do
# These are extensions that must be enabled in order to support this database
enable_extension
"plpgsql"
...
...
@@ -25,6 +25,7 @@ ActiveRecord::Schema.define(version: 20150116234545) do
t
.
datetime
"created_at"
t
.
datetime
"updated_at"
t
.
string
"home_page_url"
t
.
integer
"default_branch_protection"
,
default:
2
end
create_table
"broadcast_messages"
,
force:
true
do
|
t
|
...
...
@@ -322,12 +323,12 @@ ActiveRecord::Schema.define(version: 20150116234545) do
t
.
string
"import_url"
t
.
integer
"visibility_level"
,
default:
0
,
null:
false
t
.
boolean
"archived"
,
default:
false
,
null:
false
t
.
string
"avatar"
t
.
string
"import_status"
t
.
float
"repository_size"
,
default:
0.0
t
.
integer
"star_count"
,
default:
0
,
null:
false
t
.
string
"import_type"
t
.
string
"import_source"
t
.
string
"avatar"
end
add_index
"projects"
,
[
"creator_id"
],
name:
"index_projects_on_creator_id"
,
using: :btree
...
...
@@ -425,6 +426,7 @@ ActiveRecord::Schema.define(version: 20150116234545) do
t
.
integer
"notification_level"
,
default:
1
,
null:
false
t
.
datetime
"password_expires_at"
t
.
integer
"created_by_id"
t
.
datetime
"last_credential_check_at"
t
.
string
"avatar"
t
.
string
"confirmation_token"
t
.
datetime
"confirmed_at"
...
...
@@ -432,7 +434,6 @@ ActiveRecord::Schema.define(version: 20150116234545) do
t
.
string
"unconfirmed_email"
t
.
boolean
"hide_no_ssh_key"
,
default:
false
t
.
string
"website_url"
,
default:
""
,
null:
false
t
.
datetime
"last_credential_check_at"
t
.
string
"github_access_token"
t
.
string
"gitlab_access_token"
end
...
...
lib/gitlab/access.rb
浏览文件 @
a8b4756f
...
...
@@ -11,6 +11,11 @@ module Gitlab
MASTER
=
40
OWNER
=
50
# Branch protection settings
PROTECTION_NONE
=
0
PROTECTION_DEV_CAN_PUSH
=
1
PROTECTION_FULL
=
2
class
<<
self
def
values
options
.
values
...
...
@@ -43,6 +48,18 @@ module Gitlab
master:
MASTER
,
}
end
def
protection_options
{
"Not protected, developers and masters can (force) push and delete the branch"
=>
PROTECTION_NONE
,
"Partially protected, developers can also push but prevent all force pushes and deletion"
=>
PROTECTION_DEV_CAN_PUSH
,
"Fully protected, only masters can push and prevent all force pushes and deletion"
=>
PROTECTION_FULL
,
}
end
def
protection_values
protection_options
.
values
end
end
def
human_access
...
...
lib/gitlab/current_settings.rb
浏览文件 @
a8b4756f
...
...
@@ -12,6 +12,7 @@ module Gitlab
def
fake_application_settings
OpenStruct
.
new
(
default_projects_limit:
Settings
.
gitlab
[
'default_projects_limit'
],
default_branch_protection:
Settings
.
gitlab
[
'default_branch_protection'
],
signup_enabled:
Settings
.
gitlab
[
'signup_enabled'
],
signin_enabled:
Settings
.
gitlab
[
'signin_enabled'
],
gravatar_enabled:
Settings
.
gravatar
[
'enabled'
],
...
...
spec/models/application_setting_spec.rb
浏览文件 @
a8b4756f
...
...
@@ -4,6 +4,7 @@
#
# id :integer not null, primary key
# default_projects_limit :integer
# default_branch_protection :integer
# signup_enabled :boolean
# signin_enabled :boolean
# gravatar_enabled :boolean
...
...
spec/services/git_push_service_spec.rb
浏览文件 @
a8b4756f
...
...
@@ -106,7 +106,25 @@ describe GitPushService do
it
"when pushing a branch for the first time"
do
project
.
should_receive
(
:execute_hooks
)
project
.
default_branch
.
should
==
"master"
project
.
protected_branches
.
should_receive
(
:create
).
with
({
name:
"master"
})
project
.
protected_branches
.
should_receive
(
:create
).
with
({
name:
"master"
,
developers_can_push:
false
})
service
.
execute
(
project
,
user
,
@blankrev
,
'newrev'
,
'refs/heads/master'
)
end
it
"when pushing a branch for the first time with default branch protection disabled"
do
ApplicationSetting
.
any_instance
.
stub
(
default_branch_protection:
0
)
project
.
should_receive
(
:execute_hooks
)
project
.
default_branch
.
should
==
"master"
project
.
protected_branches
.
should_not_receive
(
:create
)
service
.
execute
(
project
,
user
,
@blankrev
,
'newrev'
,
'refs/heads/master'
)
end
it
"when pushing a branch for the first time with default branch protection set to 'developers can push'"
do
ApplicationSetting
.
any_instance
.
stub
(
default_branch_protection:
1
)
project
.
should_receive
(
:execute_hooks
)
project
.
default_branch
.
should
==
"master"
project
.
protected_branches
.
should_receive
(
:create
).
with
({
name:
"master"
,
developers_can_push:
true
})
service
.
execute
(
project
,
user
,
@blankrev
,
'newrev'
,
'refs/heads/master'
)
end
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录