topological_inventory-core 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (194) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE.txt +202 -0
  3. data/README.md +36 -0
  4. data/Rakefile +47 -0
  5. data/app/assets/config/topological_inventory_manifest.js +2 -0
  6. data/app/assets/javascripts/topological_inventory/application.js +13 -0
  7. data/app/assets/stylesheets/topological_inventory/application.css +15 -0
  8. data/app/controllers/topological_inventory/application_controller.rb +5 -0
  9. data/app/helpers/topological_inventory/application_helper.rb +4 -0
  10. data/app/jobs/topological_inventory/application_job.rb +4 -0
  11. data/app/mailers/topological_inventory/application_mailer.rb +6 -0
  12. data/app/models/application_record.rb +15 -0
  13. data/app/models/availability.rb +3 -0
  14. data/app/models/cluster.rb +14 -0
  15. data/app/models/cluster_tag.rb +7 -0
  16. data/app/models/concerns/act_as_taggable_on.rb +75 -0
  17. data/app/models/concerns/archived_concern.rb +16 -0
  18. data/app/models/container.rb +12 -0
  19. data/app/models/container_group.rb +16 -0
  20. data/app/models/container_group_tag.rb +7 -0
  21. data/app/models/container_image.rb +14 -0
  22. data/app/models/container_image_tag.rb +7 -0
  23. data/app/models/container_node.rb +14 -0
  24. data/app/models/container_node_tag.rb +7 -0
  25. data/app/models/container_project.rb +15 -0
  26. data/app/models/container_project_tag.rb +7 -0
  27. data/app/models/container_resource_quota.rb +14 -0
  28. data/app/models/container_template.rb +13 -0
  29. data/app/models/container_template_tag.rb +7 -0
  30. data/app/models/datastore.rb +15 -0
  31. data/app/models/datastore_mount.rb +6 -0
  32. data/app/models/datastore_tag.rb +7 -0
  33. data/app/models/flavor.rb +14 -0
  34. data/app/models/host.rb +20 -0
  35. data/app/models/host_tag.rb +7 -0
  36. data/app/models/ipaddress.rb +18 -0
  37. data/app/models/ipaddress_tag.rb +7 -0
  38. data/app/models/network.rb +18 -0
  39. data/app/models/network_adapter.rb +19 -0
  40. data/app/models/network_adapter_tag.rb +7 -0
  41. data/app/models/network_tag.rb +7 -0
  42. data/app/models/orchestration_stack.rb +24 -0
  43. data/app/models/refresh_state.rb +7 -0
  44. data/app/models/refresh_state_part.rb +63 -0
  45. data/app/models/reservation.rb +15 -0
  46. data/app/models/reservation_tag.rb +7 -0
  47. data/app/models/security_group.rb +19 -0
  48. data/app/models/security_group_tag.rb +7 -0
  49. data/app/models/service_credential.rb +13 -0
  50. data/app/models/service_credential_type.rb +13 -0
  51. data/app/models/service_instance.rb +23 -0
  52. data/app/models/service_instance_node.rb +17 -0
  53. data/app/models/service_instance_node_service_credential.rb +8 -0
  54. data/app/models/service_instance_service_credential.rb +8 -0
  55. data/app/models/service_inventory.rb +18 -0
  56. data/app/models/service_inventory_tag.rb +7 -0
  57. data/app/models/service_offering.rb +25 -0
  58. data/app/models/service_offering_icon.rb +9 -0
  59. data/app/models/service_offering_node.rb +17 -0
  60. data/app/models/service_offering_node_service_credential.rb +8 -0
  61. data/app/models/service_offering_service_credential.rb +8 -0
  62. data/app/models/service_offering_tag.rb +7 -0
  63. data/app/models/service_plan.rb +16 -0
  64. data/app/models/source.rb +82 -0
  65. data/app/models/source_region.rb +24 -0
  66. data/app/models/subnet.rb +21 -0
  67. data/app/models/subnet_tag.rb +7 -0
  68. data/app/models/subscription.rb +25 -0
  69. data/app/models/tag.rb +67 -0
  70. data/app/models/task.rb +8 -0
  71. data/app/models/tenant.rb +47 -0
  72. data/app/models/vm.rb +27 -0
  73. data/app/models/vm_security_group.rb +8 -0
  74. data/app/models/vm_tag.rb +7 -0
  75. data/app/models/volume.rb +18 -0
  76. data/app/models/volume_attachment.rb +8 -0
  77. data/app/models/volume_type.rb +13 -0
  78. data/app/views/layouts/topological_inventory/application.html.erb +14 -0
  79. data/config/database.dev.yml +22 -0
  80. data/db/migrate/20180919170553_add_sources_and_endpoints.rb +19 -0
  81. data/db/migrate/20180927171624_add_container_models.rb +36 -0
  82. data/db/migrate/20180927205317_add_service_catalog_models.rb +38 -0
  83. data/db/migrate/20180928122710_add_authentications.rb +13 -0
  84. data/db/migrate/20180928130326_add_default_to_endpoints.rb +5 -0
  85. data/db/migrate/20181002195506_update_endpoints_uri_parts.rb +10 -0
  86. data/db/migrate/20181005182645_add_tenant_and_tenant_id_to_all_tables.rb +20 -0
  87. data/db/migrate/20181011164429_add_container_nodes.rb +18 -0
  88. data/db/migrate/20181011172858_add_source_created_and_deleted_at_timestamps.rb +19 -0
  89. data/db/migrate/20181015150921_add_missing_name_to_container_template.rb +5 -0
  90. data/db/migrate/20181016141948_add_json_spec_to_parameters_sets.rb +6 -0
  91. data/db/migrate/20181018082155_add_archived_on_timestamp_to_all_models.rb +19 -0
  92. data/db/migrate/20181018141423_rename_service_parameters_sets_to_service_plans.rb +6 -0
  93. data/db/migrate/20181018235055_add_foreign_keys_to_all_models.rb +37 -0
  94. data/db/migrate/20181023094055_add_not_null_constraints_to_all_models.rb +43 -0
  95. data/db/migrate/20181023102858_add_timestamps_for_parallel_saving.rb +27 -0
  96. data/db/migrate/20181023213355_add_tags_and_taggings.rb +28 -0
  97. data/db/migrate/20181023215716_change_column_defaults.rb +5 -0
  98. data/db/migrate/20181024163850_add_source_type.rb +13 -0
  99. data/db/migrate/20181026182144_add_tasks_table.rb +13 -0
  100. data/db/migrate/20181102141329_add_ssl_options_to_endpoints.rb +6 -0
  101. data/db/migrate/20181102145252_add_regions_and_subscriptions.rb +31 -0
  102. data/db/migrate/20181107211649_add_containers.rb +24 -0
  103. data/db/migrate/20181108113645_add_tenant_id_to_regions_and_subscriptions.rb +6 -0
  104. data/db/migrate/20181109170334_add_not_null_constraints_to_source_type.rb +7 -0
  105. data/db/migrate/20181113145803_add_indexes_on_name_column_to_node_and_namespace.rb +6 -0
  106. data/db/migrate/20181113182615_add_vms_table.rb +32 -0
  107. data/db/migrate/20181113190507_add_orchestration_stacks.rb +26 -0
  108. data/db/migrate/20181114094606_add_last_seen_at_to_all_tables.rb +36 -0
  109. data/db/migrate/20181114115416_add_refresh_states_and_refresh_state_parts.rb +26 -0
  110. data/db/migrate/20181119173228_add_lives_on_to_container_nodes.rb +5 -0
  111. data/db/migrate/20181127191451_add_container_images.rb +28 -0
  112. data/db/migrate/20181128101451_add_flavors.rb +25 -0
  113. data/db/migrate/20181128141221_add_json_schema_to_source_types.rb +5 -0
  114. data/db/migrate/20181129150215_rename_archived_on.rb +18 -0
  115. data/db/migrate/20181130111723_add_volumes.rb +57 -0
  116. data/db/migrate/20181205142648_add_unique_constraint_to_source_uid.rb +6 -0
  117. data/db/migrate/20181210164829_add_hardware_attributes_to_flavors.rb +8 -0
  118. data/db/migrate/20190102161242_remove_tags_and_taggings.rb +33 -0
  119. data/db/migrate/20190102161442_add_taggings_for_all_taggable_tables.rb +86 -0
  120. data/db/migrate/20190104213045_rename_authentication_userid_to_username.rb +5 -0
  121. data/db/migrate/20190111083026_change_sources_source_type_to_not_null.rb +5 -0
  122. data/db/migrate/20190111163026_change_sources_name_to_not_null.rb +5 -0
  123. data/db/migrate/20190116164905_add_extra_metadata_and_tags_for_service_offerings.rb +21 -0
  124. data/db/migrate/20190118110059_add_service_offering_icons.rb +16 -0
  125. data/db/migrate/20190122131958_add_missing_foreign_key_constraint_to_tasks.rb +5 -0
  126. data/db/migrate/20190122133424_index_foreign_keys_in_authentications.rb +5 -0
  127. data/db/migrate/20190122133425_index_foreign_keys_in_container_groups.rb +5 -0
  128. data/db/migrate/20190122133426_index_foreign_keys_in_container_projects.rb +5 -0
  129. data/db/migrate/20190122133427_index_foreign_keys_in_container_templates.rb +5 -0
  130. data/db/migrate/20190122133428_index_foreign_keys_in_endpoints.rb +5 -0
  131. data/db/migrate/20190122133429_index_foreign_keys_in_service_instances.rb +5 -0
  132. data/db/migrate/20190122133430_index_foreign_keys_in_service_offerings.rb +5 -0
  133. data/db/migrate/20190122133431_index_foreign_keys_in_service_plans.rb +5 -0
  134. data/db/migrate/20190122133432_index_foreign_keys_in_sources.rb +5 -0
  135. data/db/migrate/20190122153645_remove_extraneous_indexes.rb +17 -0
  136. data/db/migrate/20190124140942_add_missing_indexes_for_last_seen_at.rb +8 -0
  137. data/db/migrate/20190124154742_add_missing_not_null_constraints_to_source_ref.rb +21 -0
  138. data/db/migrate/20190205174227_add_version_to_sources.rb +5 -0
  139. data/db/migrate/20190208143909_add_availabilities_table.rb +15 -0
  140. data/db/migrate/20190213155142_add_resource_version_to_service_plans.rb +5 -0
  141. data/db/migrate/20190218180413_move_tag_value_to_tags.rb +40 -0
  142. data/db/migrate/20190218203848_remove_extra_columns_from_tagging_join_tables.rb +33 -0
  143. data/db/migrate/20190222171042_add_mac_addresses_and_host_inventory_id_to_vms.rb +8 -0
  144. data/db/migrate/20190228103842_add_unique_indexes_to_tag_mapping_tables.rb +21 -0
  145. data/db/migrate/20190308144237_add_application_types.rb +9 -0
  146. data/db/migrate/20190308145549_add_applications.rb +10 -0
  147. data/db/migrate/20190313191654_add_application_type_display_name.rb +5 -0
  148. data/db/migrate/20190314123842_add_containers_resource_quotas_table.rb +30 -0
  149. data/db/migrate/20190314133842_add_columns_for_containers_capacity_planning_analytics.rb +13 -0
  150. data/db/migrate/20190314153151_extract_sources_to_new_service.rb +84 -0
  151. data/db/migrate/20190322122542_add_external_url_to_service_instances.rb +5 -0
  152. data/db/migrate/20190325115642_external_tenant_must_be_unique_and_not_null.rb +6 -0
  153. data/db/migrate/20190401134142_add_last_seen_at_to_all_ingress_exposed_tables.rb +36 -0
  154. data/db/migrate/20190514164916_add_clusters.rb +39 -0
  155. data/db/migrate/20190514165841_add_hosts.rb +45 -0
  156. data/db/migrate/20190522170940_add_datastores.rb +38 -0
  157. data/db/migrate/20190522172440_add_datastore_mounts.rb +17 -0
  158. data/db/migrate/20190724194551_add_network_adapters.rb +39 -0
  159. data/db/migrate/20190729194551_change_network_adapters.rb +27 -0
  160. data/db/migrate/20190729214242_add_ipaddresses_subnets_and_networks.rb +186 -0
  161. data/db/migrate/20190806112121_add_missing_relation_to_subscription_region_and_stack.rb +14 -0
  162. data/db/migrate/20190807102142_add_missing_relation_to_subscription_and_region_to_network_adapter.rb +6 -0
  163. data/db/migrate/20190807183701_add_source_collector_status.rb +5 -0
  164. data/db/migrate/20190815194221_add_reservations_table.rb +43 -0
  165. data/db/migrate/20190926144242_add_service_inventories_table.rb +39 -0
  166. data/db/migrate/20190930112142_add_service_offering_and_instance_nodes_tables.rb +67 -0
  167. data/db/migrate/20190930162142_add_inventory_relation_to_service_offerings_and_instances.rb +6 -0
  168. data/db/migrate/20191002132112_add_root_service_instance_to_service_instances.rb +6 -0
  169. data/db/migrate/20191108135108_add_service_credential_tables.rb +33 -0
  170. data/db/migrate/20191118181501_add_host_to_vm.rb +5 -0
  171. data/db/migrate/20200122181811_add_tenant_to_join_tables.rb +134 -0
  172. data/db/migrate/20200213135429_remove_service_credential_references.rb +8 -0
  173. data/db/migrate/20200213150314_create_service_credential_types.rb +30 -0
  174. data/db/migrate/20200213173958_add_service_credential_type_to_service_credentials.rb +5 -0
  175. data/db/migrate/20200214183108_create_join_table_service_offering_service_credentials.rb +18 -0
  176. data/db/migrate/20200214183117_create_join_table_service_instance_service_credentials.rb +19 -0
  177. data/db/migrate/20200218182928_create_join_table_service_offering_node_service_credentials.rb +18 -0
  178. data/db/migrate/20200218183046_create_join_table_service_instance_node_service_credentials.rb +18 -0
  179. data/db/migrate/20200313124806_remove_extraneous_index_from_service_credential_join_tables.rb +15 -0
  180. data/db/migrate/20200313141215_add_refresh_state_part_to_persisted_models.rb +66 -0
  181. data/db/migrate/20200317082640_add_tracking_timestamps_to_refresh_state.rb +6 -0
  182. data/db/schema.rb +1594 -0
  183. data/db/seeds.rb +0 -0
  184. data/lib/tasks/topological_inventory_tasks.rake +4 -0
  185. data/lib/topological_inventory-core.rb +7 -0
  186. data/lib/topological_inventory/core/ar_helper.rb +50 -0
  187. data/lib/topological_inventory/core/engine.rb +17 -0
  188. data/lib/topological_inventory/core/logging.rb +19 -0
  189. data/lib/topological_inventory/core/seed_loader.rb +9 -0
  190. data/lib/topological_inventory/core/version.rb +5 -0
  191. data/lib/topological_inventory/schema.rb +6 -0
  192. data/lib/topological_inventory/schema/base.rb +26 -0
  193. data/lib/topological_inventory/schema/default.rb +187 -0
  194. metadata +389 -0
@@ -0,0 +1,6 @@
1
+ class AddUniqueConstraintToSourceUid < ActiveRecord::Migration[5.1]
2
+ def change
3
+ add_index :sources, [:uid], :unique => true
4
+ change_column_null :sources, :uid, false
5
+ end
6
+ end
@@ -0,0 +1,8 @@
1
+ class AddHardwareAttributesToFlavors < ActiveRecord::Migration[5.1]
2
+ def change
3
+ add_column :flavors, :disk_size, :bigint
4
+ add_column :flavors, :memory, :bigint
5
+ add_column :flavors, :disk_count, :integer
6
+ add_column :flavors, :cpus, :integer
7
+ end
8
+ end
@@ -0,0 +1,33 @@
1
+ class RemoveTagsAndTaggings < ActiveRecord::Migration[5.1]
2
+ def up
3
+ drop_table "tags"
4
+ drop_table "taggings"
5
+ end
6
+
7
+ def down
8
+ create_table "taggings", :id => :serial, :force => :cascade do |t|
9
+ t.integer "tag_id"
10
+ t.string "taggable_type"
11
+ t.integer "taggable_id"
12
+ t.string "tagger_type"
13
+ t.integer "tagger_id"
14
+ t.string "context", :limit => 128
15
+ t.datetime "created_at"
16
+ t.index ["context"], :name => "index_taggings_on_context"
17
+ t.index ["tag_id", "taggable_id", "taggable_type", "context", "tagger_id", "tagger_type"], :name => "taggings_idx", :unique => true
18
+ t.index ["tag_id"], :name => "index_taggings_on_tag_id"
19
+ t.index ["taggable_id", "taggable_type", "context"], :name => "index_taggings_on_taggable_id_and_taggable_type_and_context"
20
+ t.index ["taggable_id", "taggable_type", "tagger_id", "context"], :name => "taggings_idy"
21
+ t.index ["taggable_id"], :name => "index_taggings_on_taggable_id"
22
+ t.index ["taggable_type"], :name => "index_taggings_on_taggable_type"
23
+ t.index ["tagger_id", "tagger_type"], :name => "index_taggings_on_tagger_id_and_tagger_type"
24
+ t.index ["tagger_id"], :name => "index_taggings_on_tagger_id"
25
+ end
26
+
27
+ create_table "tags", :id => :serial, :force => :cascade do |t|
28
+ t.string "name"
29
+ t.integer "taggings_count", :default => 0
30
+ t.index ["name"], :name => "index_tags_on_name", :unique => true
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,86 @@
1
+ class AddTaggingsForAllTaggableTables < ActiveRecord::Migration[5.1]
2
+ def change
3
+ create_table "tags", :id => :serial, :force => :cascade do |t|
4
+ t.references :tenant, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
5
+
6
+ t.string "name", :null => false
7
+ t.string "namespace", :default => '', :null => false
8
+ t.text "description"
9
+ t.datetime "created_at", :null => false
10
+
11
+ t.index ["tenant_id", "namespace", "name"], :unique => true
12
+ end
13
+
14
+ create_table "vm_tags", :id => :serial, :force => :cascade do |t|
15
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
16
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
17
+
18
+ t.string "value", :null => false, :default => ''
19
+ t.datetime "created_at", :null => false
20
+
21
+ t.references :vm, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
22
+
23
+ t.index ["vm_id", "tag_id", "value"], :name => "uniq_index_on_vm_id_tag_id_and_value", :unique => true
24
+ end
25
+
26
+ create_table "container_group_tags", :id => :serial, :force => :cascade do |t|
27
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
28
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
29
+
30
+ t.string "value", :null => false, :default => ''
31
+ t.datetime "created_at", :null => false
32
+
33
+ t.references :container_group, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
34
+
35
+ t.index ["container_group_id", "tag_id", "value"], :name => "uniq_index_on_container_group_id_tag_id_and_value", :unique => true
36
+ end
37
+
38
+ create_table "container_image_tags", :id => :serial, :force => :cascade do |t|
39
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
40
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
41
+
42
+ t.string "value", :null => false, :default => ''
43
+ t.datetime "created_at", :null => false
44
+
45
+ t.references :container_image, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
46
+
47
+ t.index ["container_image_id", "tag_id", "value"], :name => "uniq_index_on_container_image_id_tag_id_and_value", :unique => true
48
+ end
49
+
50
+ create_table "container_node_tags", :id => :serial, :force => :cascade do |t|
51
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
52
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
53
+
54
+ t.string "value", :null => false, :default => ''
55
+ t.datetime "created_at", :null => false
56
+
57
+ t.references :container_node, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
58
+
59
+ t.index ["container_node_id", "tag_id", "value"], :name => "uniq_index_on_container_node_id_tag_id_and_value", :unique => true
60
+ end
61
+
62
+ create_table "container_project_tags", :id => :serial, :force => :cascade do |t|
63
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
64
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
65
+
66
+ t.string "value", :null => false, :default => ''
67
+ t.datetime "created_at", :null => false
68
+
69
+ t.references :container_project, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
70
+
71
+ t.index ["container_project_id", "tag_id", "value"], :name => "uniq_index_on_container_project_id_tag_id_and_value", :unique => true
72
+ end
73
+
74
+ create_table "container_template_tags", :id => :serial, :force => :cascade do |t|
75
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
76
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
77
+
78
+ t.string "value", :null => false, :default => ''
79
+ t.datetime "created_at", :null => false
80
+
81
+ t.references :container_template, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
82
+
83
+ t.index ["container_template_id", "tag_id", "value"], :name => "uniq_index_on_container_template_id_tag_id_and_value", :unique => true
84
+ end
85
+ end
86
+ end
@@ -0,0 +1,5 @@
1
+ class RenameAuthenticationUseridToUsername < ActiveRecord::Migration[5.2]
2
+ def change
3
+ rename_column :authentications, :userid, :username
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class ChangeSourcesSourceTypeToNotNull < ActiveRecord::Migration[5.1]
2
+ def change
3
+ change_column_null(:sources, :source_type_id, false)
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class ChangeSourcesNameToNotNull < ActiveRecord::Migration[5.1]
2
+ def change
3
+ change_column_null(:sources, :name, false, "")
4
+ end
5
+ end
@@ -0,0 +1,21 @@
1
+ class AddExtraMetadataAndTagsForServiceOfferings < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_column :service_offerings, :display_name, :string
4
+ add_column :service_offerings, :documentation_url, :string
5
+ add_column :service_offerings, :long_description, :text
6
+ add_column :service_offerings, :distributor, :string
7
+ add_column :service_offerings, :support_url, :string
8
+
9
+ create_table "service_offering_tags", :id => :serial, :force => :cascade do |t|
10
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
11
+ t.references :tag, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
12
+
13
+ t.string "value", :null => false, :default => ''
14
+ t.datetime "created_at", :null => false
15
+
16
+ t.references :service_offering, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
17
+
18
+ t.index ["service_offering_id", "tag_id", "value"], :name => "uniq_index_on_service_offering_id_tag_id_and_value", :unique => true
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,16 @@
1
+ class AddServiceOfferingIcons < ActiveRecord::Migration[5.2]
2
+ def change
3
+ create_table "service_offering_icons", :id => :serial, :force => :cascade do |t|
4
+ t.references :tenant, :type => :bigint, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
5
+ t.references :source, :type => :bigint, :index => false, :null => false, :foreign_key => {:on_delete => :cascade}
6
+
7
+ t.string "source_ref", :null => false
8
+ t.binary "data"
9
+ t.timestamps
10
+
11
+ t.index %i(source_id source_ref), :unique => true
12
+ end
13
+
14
+ add_reference :service_offerings, :service_offering_icon, :type => :bigint, :index => true, :foreign_key => {:on_delete => :nullify}
15
+ end
16
+ end
@@ -0,0 +1,5 @@
1
+ class AddMissingForeignKeyConstraintToTasks < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_foreign_key :tasks, :tenants, on_delete: :cascade
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInAuthentications < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :authentications, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInContainerGroups < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :container_groups, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInContainerProjects < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :container_projects, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInContainerTemplates < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :container_templates, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInEndpoints < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :endpoints, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInServiceInstances < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :service_instances, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInServiceOfferings < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :service_offerings, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInServicePlans < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :service_plans, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,5 @@
1
+ class IndexForeignKeysInSources < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :sources, :tenant_id
4
+ end
5
+ end
@@ -0,0 +1,17 @@
1
+ class RemoveExtraneousIndexes < ActiveRecord::Migration[5.2]
2
+ def change
3
+ remove_index :service_offerings, :source_id
4
+ remove_index :subscriptions, :source_id
5
+ remove_index :source_regions, :source_id
6
+ remove_index :vms, :source_id
7
+ remove_index :flavors, :source_id
8
+ remove_index :orchestration_stacks, :source_id
9
+ remove_index :container_groups, :source_id
10
+ remove_index :container_images, :source_id
11
+ remove_index :container_nodes, :source_id
12
+ remove_index :container_projects, :source_id
13
+ remove_index :service_instances, :source_id
14
+ remove_index :service_plans, :source_id
15
+ remove_index :container_templates, :source_id
16
+ end
17
+ end
@@ -0,0 +1,8 @@
1
+ class AddMissingIndexesForLastSeenAt < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :container_images, :last_seen_at
4
+ add_index :flavors, :last_seen_at
5
+ add_index :volume_types, :last_seen_at
6
+ add_index :volumes, :last_seen_at
7
+ end
8
+ end
@@ -0,0 +1,21 @@
1
+ class AddMissingNotNullConstraintsToSourceRef < ActiveRecord::Migration[5.2]
2
+ def change
3
+ change_column_null :container_images, :source_ref, false
4
+ change_column_null :orchestration_stacks, :source_ref, false
5
+ change_column_null :flavors, :source_ref, false
6
+ change_column_null :vms, :source_ref, false
7
+ change_column_null :volume_types, :source_ref, false
8
+ change_column_null :container_groups, :source_ref, false
9
+ change_column_null :container_projects, :source_ref, false
10
+ change_column_null :container_templates, :source_ref, false
11
+ change_column_null :source_regions, :source_ref, false
12
+ change_column_null :service_instances, :source_ref, false
13
+ change_column_null :service_plans, :source_ref, false
14
+ change_column_null :service_offerings, :source_ref, false
15
+ change_column_null :volumes, :source_ref, false
16
+ change_column_null :container_nodes, :source_ref, false
17
+ change_column_null :subscriptions, :source_ref, false
18
+
19
+ change_column_null :containers, :name, false
20
+ end
21
+ end
@@ -0,0 +1,5 @@
1
+ class AddVersionToSources < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_column :sources, :version, :string
4
+ end
5
+ end
@@ -0,0 +1,15 @@
1
+ class AddAvailabilitiesTable < ActiveRecord::Migration[5.2]
2
+ def change
3
+ create_table :availabilities, :id => :bigserial, :force => :cascade do |t|
4
+ t.references :resource, :polymorphic => true, :index => false, :null => false
5
+ t.string :action, :null => false
6
+ t.string :identifier, :null => false
7
+ t.string :availability, :null => false
8
+ t.datetime :last_checked_at
9
+ t.datetime :last_valid_at
10
+ t.timestamps
11
+ t.index [:resource_type, :resource_id, :action, :identifier], :unique => true,
12
+ :name => :index_on_resource_action_identifier
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,5 @@
1
+ class AddResourceVersionToServicePlans < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_column :service_plans, :resource_version, :string
4
+ end
5
+ end
@@ -0,0 +1,40 @@
1
+ class MoveTagValueToTags < ActiveRecord::Migration[5.2]
2
+ def up
3
+ add_column :tags, :value, :string, :null => false, :default => ""
4
+
5
+ remove_column :container_group_tags, :value
6
+ remove_column :container_image_tags, :value
7
+ remove_column :container_node_tags, :value
8
+ remove_column :container_project_tags, :value
9
+ remove_column :container_template_tags, :value
10
+ remove_column :service_offering_tags, :value
11
+ remove_column :vm_tags, :value
12
+ end
13
+
14
+ def down
15
+ remove_column :tags, :value
16
+
17
+ add_column :container_group_tags, :value, :string, :default => "", :null => false
18
+ add_column :container_image_tags, :value, :string, :default => "", :null => false
19
+ add_column :container_node_tags, :value, :string, :default => "", :null => false
20
+ add_column :container_project_tags, :value, :string, :default => "", :null => false
21
+ add_column :container_template_tags, :value, :string, :default => "", :null => false
22
+ add_column :service_offering_tags, :value, :string, :default => "", :null => false
23
+ add_column :vm_tags, :value, :string, :default => "", :null => false
24
+
25
+ add_index :container_group_tags, [:container_group_id, :tag_id, :value],
26
+ :name => "uniq_index_on_container_group_id_tag_id_and_value", :unique => true
27
+ add_index :container_image_tags, [:container_image_id, :tag_id, :value],
28
+ :name => "uniq_index_on_container_image_id_tag_id_and_value", :unique => true
29
+ add_index :container_node_tags, [:container_node_id, :tag_id, :value],
30
+ :name => "uniq_index_on_container_node_id_tag_id_and_value", :unique => true
31
+ add_index :container_project_tags, [:container_project_id, :tag_id, :value],
32
+ :name => "uniq_index_on_container_project_id_tag_id_and_value", :unique => true
33
+ add_index :container_template_tags, [:container_template_id, :tag_id, :value],
34
+ :name => "uniq_index_on_container_template_id_tag_id_and_value", :unique => true
35
+ add_index :service_offering_tags, [:service_offering_id, :tag_id, :value],
36
+ :name => "uniq_index_on_service_offering_id_tag_id_and_value", :unique => true
37
+ add_index :vm_tags, [:vm_id, :tag_id, :value],
38
+ :name => "uniq_index_on_vm_id_tag_id_and_value", :unique => true
39
+ end
40
+ end
@@ -0,0 +1,33 @@
1
+ class RemoveExtraColumnsFromTaggingJoinTables < ActiveRecord::Migration[5.2]
2
+ def change
3
+ remove_column :container_group_tags, :created_at, :datetime
4
+ remove_column :container_image_tags, :created_at, :datetime
5
+ remove_column :container_node_tags, :created_at, :datetime
6
+ remove_column :container_project_tags, :created_at, :datetime
7
+ remove_column :container_template_tags, :created_at, :datetime
8
+ remove_column :service_offering_tags, :created_at, :datetime
9
+ remove_column :vm_tags, :created_at, :datetime
10
+
11
+ reversible do |change|
12
+ change.up do
13
+ remove_reference :container_group_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
14
+ remove_reference :container_image_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
15
+ remove_reference :container_node_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
16
+ remove_reference :container_project_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
17
+ remove_reference :container_template_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
18
+ remove_reference :service_offering_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
19
+ remove_reference :vm_tags, :tenant, :index => true, :null => false, :foreign_key => {:on_delete => :cascade}
20
+ end
21
+
22
+ change.down do
23
+ add_reference :container_group_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
24
+ add_reference :container_image_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
25
+ add_reference :container_node_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
26
+ add_reference :container_project_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
27
+ add_reference :container_template_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
28
+ add_reference :service_offering_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
29
+ add_reference :vm_tags, :tenant, :index => true, :null => true, :foreign_key => {:on_delete => :cascade}
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,8 @@
1
+ class AddMacAddressesAndHostInventoryIdToVms < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_column :vms, :host_inventory_uuid, :uuid
4
+ add_column :vms, :mac_addresses, :jsonb
5
+
6
+ add_index :vms, :host_inventory_uuid
7
+ end
8
+ end
@@ -0,0 +1,21 @@
1
+ class AddUniqueIndexesToTagMappingTables < ActiveRecord::Migration[5.2]
2
+ def change
3
+ add_index :container_group_tags, [:container_group_id, :tag_id],
4
+ :name => "uniq_index_on_container_group_id_tag_id", :unique => true
5
+ add_index :container_image_tags, [:container_image_id, :tag_id],
6
+ :name => "uniq_index_on_container_image_id_tag_id", :unique => true
7
+ add_index :container_node_tags, [:container_node_id, :tag_id],
8
+ :name => "uniq_index_on_container_node_id_tag_id", :unique => true
9
+ add_index :container_project_tags, [:container_project_id, :tag_id],
10
+ :name => "uniq_index_on_container_project_id_tag_id", :unique => true
11
+ add_index :container_template_tags, [:container_template_id, :tag_id],
12
+ :name => "uniq_index_on_container_template_id_tag_id", :unique => true
13
+ add_index :service_offering_tags, [:service_offering_id, :tag_id],
14
+ :name => "uniq_index_on_service_offering_id_tag_id", :unique => true
15
+ add_index :vm_tags, [:vm_id, :tag_id],
16
+ :name => "uniq_index_on_vm_id_tag_id", :unique => true
17
+
18
+ remove_index :tags, :column => ["tenant_id", "namespace", "name"], :unique => true
19
+ add_index :tags, ["tenant_id", "namespace", "name", "value"], :unique => true
20
+ end
21
+ end