activerecord-referential_integrity 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: d6ac2cbc77863e65e24222f60379683214e8e914
4
+ data.tar.gz: d6c9043d8d080abd16499431d0c3b7b2dbcfed14
5
+ SHA512:
6
+ metadata.gz: 3d20175adab2ba64911e5613c4d185a3182ec0c5f5207efc1c7dacb4d1e7633f30bf9bb3eff55617efb11c9fe495ceb2f2de068fb5c7c86705dc89c05be46592
7
+ data.tar.gz: aac8adca5abed2d1fda0dec2a73938e8a4f1fc5de7ffa159eb1b5b3e2ff3cacee0e908f4a6e8abdbc418041a2d60dabb219a63fa94bc7a0603a66913f0e8bd17
@@ -0,0 +1,17 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
data/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source 'https://rubygems.org'
2
+
3
+ gemspec
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2014 Orcas Net, Inc.
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,59 @@
1
+ # Referential Integrity for ActiveRecord
2
+
3
+ Adds as reversible `add_foreign_key` migration to Rails. `add_foreign_key`
4
+ creates a database level foreign key constraint, this ensures that records
5
+ cannot reference foreign keys in other tables that do not exist.
6
+
7
+ See [PostgreSQL foreign key constraint documentation](http://www.postgresql.org/docs/9.3/static/ddl-constraints.html#DDL-CONSTRAINTS-FK)
8
+ for more.
9
+
10
+ ## Limitations
11
+
12
+ Currently supports only PostgreSQL.
13
+ Currently is written against Rails/ActiveRecord 3.2.16.
14
+
15
+ ## Installation
16
+
17
+ Add this line to your application's Gemfile:
18
+
19
+ gem 'activerecord-referential_integrity'
20
+
21
+ And then execute:
22
+
23
+ $ bundle
24
+
25
+ Or install it yourself as:
26
+
27
+ $ gem install activerecord-referential_integrity
28
+
29
+ ## Usage
30
+
31
+ Inside your migrations, call `add_foreign_key`, passing in the table and a hash of column => table pairs.
32
+
33
+ For example:
34
+ ```ruby
35
+ class CreateUserSettings < ActiveRecord::Migration
36
+ def change
37
+ create_table :user_settings do |t|
38
+ t.references :user, null: false
39
+ # or t.integer :user_id, null: false
40
+ [...]
41
+ end
42
+
43
+ add_foreign_key :somethings, :user_id => :users
44
+ end
45
+ end
46
+ ```
47
+
48
+ TODO: Write usage instructions here
49
+
50
+ ## Versioning
51
+ Uses [Semantic Versioning](http://semver.org).
52
+
53
+ ## Contributing
54
+
55
+ 1. Fork it (http://github.com/orcasnet/activerecord-referential_integrity/fork)
56
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
57
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
58
+ 4. Push to the branch (`git push origin my-new-feature`)
59
+ 5. Create new Pull Request
@@ -0,0 +1 @@
1
+ require 'bundler/gem_tasks'
@@ -0,0 +1,24 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'activerecord/referential_integrity/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = 'activerecord-referential_integrity'
8
+ spec.version = ActiveRecord::ReferentialIntegrity::VERSION
9
+ spec.authors = ['Martin Tithonium', 'John Wulff']
10
+ spec.email = ['marty@orcasnet.com', 'johnw@orcasnet.com']
11
+ spec.summary = %q{Adds add_foreign_key to Rails migrations with relevant databases}
12
+ spec.description = %q{Adds as reversible add_foreign_key migration to Rails. Currently supports only PostgreSQL}
13
+ spec.homepage = 'https://github.com/orcasnet/activerecord-referential_integrity'
14
+ spec.license = 'MIT'
15
+
16
+ spec.files = `git ls-files`.split($/)
17
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
+ spec.require_paths = ['lib']
20
+
21
+ spec.add_dependency 'activerecord', '~> 3.2.16'
22
+ spec.add_development_dependency 'bundler', '~> 1.5'
23
+ spec.add_development_dependency 'rake'
24
+ end
@@ -0,0 +1,9 @@
1
+ require 'activerecord/referential_integrity/version'
2
+ require 'activerecord/referential_integrity/active_record/connection_adapters/abstract_adapter'
3
+ require 'activerecord/referential_integrity/active_record/connection_adapters/postgresql_adapter'
4
+ require 'activerecord/referential_integrity/active_record/migration/command_recorder'
5
+
6
+ module ActiveRecord
7
+ module ReferentialIntegrity
8
+ end
9
+ end
@@ -0,0 +1,9 @@
1
+ class ActiveRecord::ConnectionAdapters::AbstractAdapter
2
+ def add_foreign_key(table, keypairs)
3
+ raise NotImplementedError, 'add_foreign_key is not implemented'
4
+ end
5
+
6
+ def drop_foreign_key(table, keys)
7
+ raise NotImplementedError, 'drop_foreign_key is not implemented'
8
+ end
9
+ end
@@ -0,0 +1,19 @@
1
+ class ActiveRecord::ConnectionAdapters::PostgreSQLAdapter < ActiveRecord::ConnectionAdapters::AbstractAdapter
2
+ def add_foreign_key(table, keypairs)
3
+ keypairs.each_pair do |foreign_key, foreign_table|
4
+ sql = "ALTER TABLE #{table} "
5
+ sql << "ADD CONSTRAINT #{table}_fk_#{foreign_key} "
6
+ sql << "FOREIGN KEY (#{foreign_key}) "
7
+ sql << "REFERENCES #{foreign_table} (id)"
8
+ execute sql
9
+ end
10
+ end
11
+
12
+ def drop_foreign_key(table, keys)
13
+ keys.each do |foreign_key|
14
+ sql = "ALTER TABLE #{table} "
15
+ sql << "DROP CONSTRAINT IF EXISTS #{table}_fk_#{foreign_key} "
16
+ execute sql
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,11 @@
1
+ class ActiveRecord::Migration::CommandRecorder
2
+ def add_foreign_key(*args)
3
+ record(:add_foreign_key, args)
4
+ end
5
+
6
+ private
7
+
8
+ def invert_add_foreign_key(args)
9
+ [:drop_foreign_key, [args.first, args.last.keys]]
10
+ end
11
+ end
@@ -0,0 +1,5 @@
1
+ module ActiveRecord
2
+ module ReferentialIntegrity
3
+ VERSION = '1.0.0'
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,100 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: activerecord-referential_integrity
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Martin Tithonium
8
+ - John Wulff
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2014-03-11 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: activerecord
16
+ requirement: !ruby/object:Gem::Requirement
17
+ requirements:
18
+ - - "~>"
19
+ - !ruby/object:Gem::Version
20
+ version: 3.2.16
21
+ type: :runtime
22
+ prerelease: false
23
+ version_requirements: !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - "~>"
26
+ - !ruby/object:Gem::Version
27
+ version: 3.2.16
28
+ - !ruby/object:Gem::Dependency
29
+ name: bundler
30
+ requirement: !ruby/object:Gem::Requirement
31
+ requirements:
32
+ - - "~>"
33
+ - !ruby/object:Gem::Version
34
+ version: '1.5'
35
+ type: :development
36
+ prerelease: false
37
+ version_requirements: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - "~>"
40
+ - !ruby/object:Gem::Version
41
+ version: '1.5'
42
+ - !ruby/object:Gem::Dependency
43
+ name: rake
44
+ requirement: !ruby/object:Gem::Requirement
45
+ requirements:
46
+ - - ">="
47
+ - !ruby/object:Gem::Version
48
+ version: '0'
49
+ type: :development
50
+ prerelease: false
51
+ version_requirements: !ruby/object:Gem::Requirement
52
+ requirements:
53
+ - - ">="
54
+ - !ruby/object:Gem::Version
55
+ version: '0'
56
+ description: Adds as reversible add_foreign_key migration to Rails. Currently supports
57
+ only PostgreSQL
58
+ email:
59
+ - marty@orcasnet.com
60
+ - johnw@orcasnet.com
61
+ executables: []
62
+ extensions: []
63
+ extra_rdoc_files: []
64
+ files:
65
+ - ".gitignore"
66
+ - Gemfile
67
+ - LICENSE.txt
68
+ - README.md
69
+ - Rakefile
70
+ - activerecord-referential_integrity.gemspec
71
+ - lib/activerecord-referential_integrity.rb
72
+ - lib/activerecord/referential_integrity/active_record/connection_adapters/abstract_adapter.rb
73
+ - lib/activerecord/referential_integrity/active_record/connection_adapters/postgresql_adapter.rb
74
+ - lib/activerecord/referential_integrity/active_record/migration/command_recorder.rb
75
+ - lib/activerecord/referential_integrity/version.rb
76
+ homepage: https://github.com/orcasnet/activerecord-referential_integrity
77
+ licenses:
78
+ - MIT
79
+ metadata: {}
80
+ post_install_message:
81
+ rdoc_options: []
82
+ require_paths:
83
+ - lib
84
+ required_ruby_version: !ruby/object:Gem::Requirement
85
+ requirements:
86
+ - - ">="
87
+ - !ruby/object:Gem::Version
88
+ version: '0'
89
+ required_rubygems_version: !ruby/object:Gem::Requirement
90
+ requirements:
91
+ - - ">="
92
+ - !ruby/object:Gem::Version
93
+ version: '0'
94
+ requirements: []
95
+ rubyforge_project:
96
+ rubygems_version: 2.2.0.rc.1
97
+ signing_key:
98
+ specification_version: 4
99
+ summary: Adds add_foreign_key to Rails migrations with relevant databases
100
+ test_files: []