Module: PgSaurus::SchemaDumper::ForeignKeyMethods
- Included in:
- PgSaurus::SchemaDumper
- Defined in:
- lib/pg_saurus/schema_dumper/foreign_key_methods.rb
Overview
Provides methods to extend ActiveRecord::SchemaDumper to dump foreign keys.
Instance Method Summary collapse
-
#foreign_keys(table, stream) ⇒ Object
See activerecord/lib/active_record/schema_dumper.rb.
Instance Method Details
#foreign_keys(table, stream) ⇒ Object
See activerecord/lib/active_record/schema_dumper.rb
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/pg_saurus/schema_dumper/foreign_key_methods.rb', line 6 def foreign_keys(table, stream) if (foreign_keys = @connection.foreign_keys(table)).any? add_foreign_key_statements = foreign_keys.map do |foreign_key| from_table = if foreign_key.from_schema && foreign_key.from_schema != 'public' "#{foreign_key.from_schema}.#{remove_prefix_and_suffix(foreign_key.from_table)}" else remove_prefix_and_suffix(foreign_key.from_table) end parts = [ "add_foreign_key #{from_table.inspect}", remove_prefix_and_suffix(foreign_key.to_table).inspect, ] if foreign_key.column != @connection.foreign_key_column_for(foreign_key.to_table) parts << "column: #{foreign_key.column.inspect}" end if foreign_key.custom_primary_key? parts << "primary_key: #{foreign_key.primary_key.inspect}" end if foreign_key.name !~ /^fk_rails_[0-9a-f]{10}$/ parts << "name: #{foreign_key.name.inspect}" end parts << "on_update: #{foreign_key.on_update.inspect}" if foreign_key.on_update parts << "on_delete: #{foreign_key.on_delete.inspect}" if foreign_key.on_delete # Always exclude the index # If an index was created in a migration, it will get dumped to the schema # separately from the foreign key. This will raise an exception if # add_foreign_key is run without :exclude_index => true. parts << "exclude_index: true" " #{parts.join(', ')}" end stream.puts add_foreign_key_statements.sort.join("\n") end end |