Commit e29ccece332e57c9fb6c532a3680e3b457e3a301
1 parent
ced242a2
Exists in
master
and in
4 other branches
Namespace model added. Migration to convert exit project/groups
Showing
6 changed files
with
60 additions
and
31 deletions
Show diff stats
app/models/group.rb
... | ... | @@ -10,26 +10,7 @@ |
10 | 10 | # updated_at :datetime not null |
11 | 11 | # |
12 | 12 | |
13 | -class Group < ActiveRecord::Base | |
14 | - attr_accessible :code, :name, :owner_id | |
15 | - | |
16 | - has_many :projects | |
17 | - belongs_to :owner, class_name: "User" | |
18 | - | |
19 | - validates :name, presence: true, uniqueness: true | |
20 | - validates :code, presence: true, uniqueness: true | |
21 | - validates :owner, presence: true | |
22 | - | |
23 | - delegate :name, to: :owner, allow_nil: true, prefix: true | |
24 | - | |
25 | - def self.search query | |
26 | - where("name LIKE :query OR code LIKE :query", query: "%#{query}%") | |
27 | - end | |
28 | - | |
29 | - def to_param | |
30 | - code | |
31 | - end | |
32 | - | |
13 | +class Group < Namespace | |
33 | 14 | def users |
34 | 15 | User.joins(:users_projects).where(users_projects: {project_id: project_ids}).uniq |
35 | 16 | end | ... | ... |
... | ... | @@ -0,0 +1,20 @@ |
1 | +class Namespace < ActiveRecord::Base | |
2 | + attr_accessible :code, :name, :owner_id | |
3 | + | |
4 | + has_many :projects | |
5 | + belongs_to :owner, class_name: "User" | |
6 | + | |
7 | + validates :name, presence: true, uniqueness: true | |
8 | + validates :code, presence: true, uniqueness: true | |
9 | + validates :owner, presence: true | |
10 | + | |
11 | + delegate :name, to: :owner, allow_nil: true, prefix: true | |
12 | + | |
13 | + def self.search query | |
14 | + where("name LIKE :query OR code LIKE :query", query: "%#{query}%") | |
15 | + end | |
16 | + | |
17 | + def to_param | |
18 | + code | |
19 | + end | |
20 | +end | ... | ... |
app/models/project.rb
... | ... | @@ -32,7 +32,8 @@ class Project < ActiveRecord::Base |
32 | 32 | attr_accessor :error_code |
33 | 33 | |
34 | 34 | # Relations |
35 | - belongs_to :group | |
35 | + belongs_to :group, foreign_key: "namespace_id", conditions: 'type = Group' | |
36 | + belongs_to :namespace | |
36 | 37 | belongs_to :owner, class_name: "User" |
37 | 38 | has_many :users, through: :users_projects |
38 | 39 | has_many :events, dependent: :destroy |
... | ... | @@ -192,4 +193,12 @@ class Project < ActiveRecord::Base |
192 | 193 | def gitlab_ci? |
193 | 194 | gitlab_ci_service && gitlab_ci_service.active |
194 | 195 | end |
196 | + | |
197 | + def path_with_namespace | |
198 | + if namespace | |
199 | + namespace.code + '/' + path | |
200 | + else | |
201 | + path | |
202 | + end | |
203 | + end | |
195 | 204 | end | ... | ... |
... | ... | @@ -0,0 +1,13 @@ |
1 | +class ConvertGroupToNamespace < ActiveRecord::Migration | |
2 | + def up | |
3 | + rename_table 'groups', 'namespaces' | |
4 | + add_column :namespaces, :type, :string, null: true | |
5 | + | |
6 | + # Migrate old groups | |
7 | + Namespace.update_all(type: 'Group') | |
8 | + end | |
9 | + | |
10 | + def down | |
11 | + raise 'Rollback is not allowed' | |
12 | + end | |
13 | +end | ... | ... |
db/migrate/20121122150932_add_namespace_id_to_project.rb
0 → 100644
db/schema.rb
... | ... | @@ -11,7 +11,7 @@ |
11 | 11 | # |
12 | 12 | # It's strongly recommended to check this file into your version control system. |
13 | 13 | |
14 | -ActiveRecord::Schema.define(:version => 20121120113838) do | |
14 | +ActiveRecord::Schema.define(:version => 20121122150932) do | |
15 | 15 | |
16 | 16 | create_table "events", :force => true do |t| |
17 | 17 | t.string "target_type" |
... | ... | @@ -25,14 +25,6 @@ ActiveRecord::Schema.define(:version => 20121120113838) do |
25 | 25 | t.integer "author_id" |
26 | 26 | end |
27 | 27 | |
28 | - create_table "groups", :force => true do |t| | |
29 | - t.string "name", :null => false | |
30 | - t.string "code", :null => false | |
31 | - t.integer "owner_id", :null => false | |
32 | - t.datetime "created_at", :null => false | |
33 | - t.datetime "updated_at", :null => false | |
34 | - end | |
35 | - | |
36 | 28 | create_table "issues", :force => true do |t| |
37 | 29 | t.string "title" |
38 | 30 | t.integer "assignee_id" |
... | ... | @@ -88,6 +80,15 @@ ActiveRecord::Schema.define(:version => 20121120113838) do |
88 | 80 | t.datetime "updated_at", :null => false |
89 | 81 | end |
90 | 82 | |
83 | + create_table "namespaces", :force => true do |t| | |
84 | + t.string "name", :null => false | |
85 | + t.string "code", :null => false | |
86 | + t.integer "owner_id", :null => false | |
87 | + t.datetime "created_at", :null => false | |
88 | + t.datetime "updated_at", :null => false | |
89 | + t.string "type" | |
90 | + end | |
91 | + | |
91 | 92 | create_table "notes", :force => true do |t| |
92 | 93 | t.text "note" |
93 | 94 | t.string "noteable_id" |
... | ... | @@ -117,7 +118,7 @@ ActiveRecord::Schema.define(:version => 20121120113838) do |
117 | 118 | t.boolean "wall_enabled", :default => true, :null => false |
118 | 119 | t.boolean "merge_requests_enabled", :default => true, :null => false |
119 | 120 | t.boolean "wiki_enabled", :default => true, :null => false |
120 | - t.integer "group_id" | |
121 | + t.integer "namespace_id" | |
121 | 122 | end |
122 | 123 | |
123 | 124 | create_table "protected_branches", :force => true do |t| | ... | ... |