summaryrefslogtreecommitdiffstats
path: root/lib/puppet/rails/database
diff options
context:
space:
mode:
authorNick Lewis <nick@puppetlabs.com>2011-03-08 16:06:03 -0800
committerNick Lewis <nick@puppetlabs.com>2011-03-08 16:06:03 -0800
commite8763415627cf41cefece00bf4dbc48e9be81d1d (patch)
treef23dfd8c60020ad511e5fd5c49cf6fae973710ab /lib/puppet/rails/database
parent7c768c4a6b85788aabc431e01febee00d4c3d3e5 (diff)
parent880d0c6cbd20758e02848d1fa61966402dc44dc0 (diff)
downloadpuppet-e8763415627cf41cefece00bf4dbc48e9be81d1d.tar.gz
puppet-e8763415627cf41cefece00bf4dbc48e9be81d1d.tar.xz
puppet-e8763415627cf41cefece00bf4dbc48e9be81d1d.zip
Merge branch 'ticket/2.6.next/6338' into 2.6.next
Diffstat (limited to 'lib/puppet/rails/database')
-rw-r--r--lib/puppet/rails/database/004_add_inventory_service_tables.rb36
-rw-r--r--lib/puppet/rails/database/schema.rb17
2 files changed, 53 insertions, 0 deletions
diff --git a/lib/puppet/rails/database/004_add_inventory_service_tables.rb b/lib/puppet/rails/database/004_add_inventory_service_tables.rb
new file mode 100644
index 000000000..22298437a
--- /dev/null
+++ b/lib/puppet/rails/database/004_add_inventory_service_tables.rb
@@ -0,0 +1,36 @@
+class AddInventoryServiceTables < ActiveRecord::Migration
+ def self.up
+ unless ActiveRecord::Base.connection.tables.include?("inventory_hosts")
+ create_table :inventory_hosts do |t|
+ t.column :name, :string, :null => false
+ t.column :timestamp, :datetime, :null => false
+ t.column :updated_at, :datetime
+ t.column :created_at, :datetime
+ end
+
+ add_index :inventory_hosts, :name, :unique => true
+ end
+
+ unless ActiveRecord::Base.connection.tables.include?("inventory_facts")
+ create_table :inventory_facts, :id => false do |t|
+ t.column :inventory_host_id, :integer, :null => false
+ t.column :name, :string, :null => false
+ t.column :value, :text, :null => false
+ end
+
+ add_index :inventory_facts, [:inventory_host_id, :name], :unique => true
+ end
+ end
+
+ def self.down
+ unless ActiveRecord::Base.connection.tables.include?("inventory_hosts")
+ remove_index :inventory_hosts, :name
+ drop_table :inventory_hosts
+ end
+
+ if ActiveRecord::Base.connection.tables.include?("inventory_facts")
+ remove_index :inventory_facts, [:inventory_host_id, :name]
+ drop_table :inventory_facts
+ end
+ end
+end
diff --git a/lib/puppet/rails/database/schema.rb b/lib/puppet/rails/database/schema.rb
index 8b389d773..5e455d6c0 100644
--- a/lib/puppet/rails/database/schema.rb
+++ b/lib/puppet/rails/database/schema.rb
@@ -103,6 +103,23 @@ class Puppet::Rails::Schema
t.column :created_at, :datetime
end
add_index :param_names, :name
+
+ create_table :inventory_hosts do |t|
+ t.column :name, :string, :null => false
+ t.column :timestamp, :datetime, :null => false
+ t.column :updated_at, :datetime
+ t.column :created_at, :datetime
+ end
+
+ add_index :inventory_hosts, :name, :unique => true
+
+ create_table :inventory_facts, :id => false do |t|
+ t.column :inventory_host_id, :integer, :null => false
+ t.column :name, :string, :null => false
+ t.column :value, :text, :null => false
+ end
+
+ add_index :inventory_facts, [:inventory_host_id, :name], :unique => true
end
end
ensure