active_record_proxy_adapters 0.3.2 → 0.4.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.
Files changed (34) hide show
  1. checksums.yaml +4 -4
  2. data/.rspec +4 -0
  3. data/.rubocop.yml +18 -0
  4. data/Appraisals +25 -0
  5. data/CHANGELOG.md +49 -0
  6. data/CODE_OF_CONDUCT.md +132 -0
  7. data/Dockerfile +21 -0
  8. data/db/mysql_structure.sql +41 -0
  9. data/db/postgresql_structure.sql +86 -0
  10. data/docker/postgres_replica/cmd.sh +9 -0
  11. data/docker-compose.yml +98 -0
  12. data/gemfiles/rails_7.0.gemfile +25 -0
  13. data/gemfiles/rails_7.0.gemfile.lock +122 -0
  14. data/gemfiles/rails_7.1.gemfile +21 -0
  15. data/gemfiles/rails_7.1.gemfile.lock +131 -0
  16. data/gemfiles/rails_7.2.gemfile +21 -0
  17. data/gemfiles/rails_7.2.gemfile.lock +129 -0
  18. data/gemfiles/rails_8.0.gemfile +21 -0
  19. data/gemfiles/rails_8.0.gemfile.lock +131 -0
  20. data/lib/active_record/connection_adapters/mysql2_proxy_adapter.rb +2 -0
  21. data/lib/active_record/connection_adapters/postgresql_proxy_adapter.rb +3 -0
  22. data/lib/active_record/connection_adapters/trilogy_proxy_adapter.rb +41 -0
  23. data/lib/active_record/tasks/trilogy_proxy_database_tasks.rb +19 -0
  24. data/lib/active_record_proxy_adapters/connection_handling/mysql2.rb +29 -23
  25. data/lib/active_record_proxy_adapters/connection_handling/postgresql.rb +27 -21
  26. data/lib/active_record_proxy_adapters/connection_handling/trilogy.rb +44 -0
  27. data/lib/active_record_proxy_adapters/connection_handling.rb +1 -7
  28. data/lib/active_record_proxy_adapters/railtie.rb +1 -4
  29. data/lib/active_record_proxy_adapters/trilogy_proxy.rb +9 -0
  30. data/lib/active_record_proxy_adapters/version.rb +1 -1
  31. data/postgres_primary.dockerfile +34 -0
  32. data/postgres_replica.dockerfile +15 -0
  33. data/sig/active_record_proxy_adapters.rbs +4 -0
  34. metadata +27 -4
@@ -5,10 +5,7 @@ require "active_support"
5
5
  module ActiveRecordProxyAdapters
6
6
  # Hooks into rails boot process to extend ActiveRecord with the proxy adapter.
7
7
  class Railtie < Rails::Railtie
8
- ActiveSupport.on_load :active_record do
9
- require "active_record_proxy_adapters/connection_handling"
10
- ActiveRecord::Base.extend(ActiveRecordProxyAdapters::ConnectionHandling)
11
- end
8
+ require "active_record_proxy_adapters/connection_handling"
12
9
 
13
10
  config.to_prepare do
14
11
  Rails.autoloaders.each do |autoloader|
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "active_record_proxy_adapters/mysql2_proxy"
4
+
5
+ module ActiveRecordProxyAdapters
6
+ # Proxy to the Mysql2Proxy, allowing the use of the ActiveRecordProxyAdapters::PrimaryReplicaProxy.
7
+ class TrilogyProxy < Mysql2Proxy
8
+ end
9
+ end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module ActiveRecordProxyAdapters
4
- VERSION = "0.3.2"
4
+ VERSION = "0.4.0"
5
5
  end
@@ -0,0 +1,34 @@
1
+ FROM docker.io/postgres:17-alpine
2
+
3
+ ARG REPLICA_USER=replicator
4
+ ARG REPLICA_PASSWORD=replicator
5
+ ARG REPLICATION_SLOT_NAME=replication_slot
6
+ ARG INIT_SQL=00_init.sql
7
+ ARG POSTGRES_LOGGING_COLLECTOR=
8
+ ARG POSTGRES_LOG_DESTINATION=
9
+ ARG POSTGRES_LOG_STATEMENT=
10
+ ENV CONF_SAMPLE="/usr/local/share/postgresql/postgresql.conf.sample"
11
+
12
+ WORKDIR /docker-entrypoint-initdb.d
13
+
14
+ USER root
15
+
16
+ RUN touch $INIT_SQL
17
+ RUN chown -R postgres:postgres $INIT_SQL
18
+ RUN echo "CREATE USER ${REPLICA_USER} WITH REPLICATION ENCRYPTED PASSWORD '${REPLICA_PASSWORD}';" > $INIT_SQL
19
+ RUN echo "SELECT pg_create_physical_replication_slot('${REPLICATION_SLOT_NAME}');" >> $INIT_SQL
20
+
21
+ # Enable logging collector if given
22
+ RUN if [[ ! -z "${POSTGRES_LOGGING_COLLECTOR}" ]]; then sed -i "s/#\(logging_collector = \)off\(.*\)/\1${POSTGRES_LOGGING_COLLECTOR}\2/" ${CONF_SAMPLE}; fi
23
+
24
+ # Override default log destination if given
25
+ RUN if [[ ! -z "${POSTGRES_LOG_DESTINATION}" ]]; then sed -i "s/#\(log_destination = \)'stderr'\(.*\)/\1'${POSTGRES_LOG_DESTINATION}'\2/" ${CONF_SAMPLE}; fi
26
+
27
+ # Override log statement if given
28
+ RUN if [[ ! -z "${POSTGRES_LOG_STATEMENT}" ]]; then sed -i "s/#\(log_statement = \)'none'\(.*\)/\1'${POSTGRES_LOG_STATEMENT}'\2/" ${CONF_SAMPLE}; fi
29
+
30
+ WORKDIR /
31
+
32
+ USER postgres
33
+
34
+ CMD ["postgres", "-c", "wal_level=replica", "-c", "hot_standby=on", "-c", "max_wal_senders=10", "-c", "max_replication_slots=10", "-c", "hot_standby_feedback=on" ]
@@ -0,0 +1,15 @@
1
+ FROM docker.io/postgres:17-alpine
2
+
3
+ ENV PRIMARY_DATABASE_HOST=localhost
4
+ ENV PRIMARY_DATABASE_PORT=5432
5
+ ENV PRIMARY_REPLICATION_SLOT=replication_slot
6
+
7
+
8
+ COPY docker/postgres_replica/cmd.sh cmd.sh
9
+
10
+ USER root
11
+ RUN chown -R postgres:postgres cmd.sh
12
+ USER postgres
13
+ RUN chmod u+x cmd.sh
14
+
15
+ CMD [ "./cmd.sh" ]
@@ -0,0 +1,4 @@
1
+ module ActiveRecordProxyAdapters
2
+ VERSION: String
3
+ # See the writing guide of rbs: https://github.com/ruby/rbs#guides
4
+ end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: active_record_proxy_adapters
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.2
4
+ version: 0.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Matt Cruz
@@ -57,22 +57,41 @@ email:
57
57
  - matt.cruz@nasdaq.com
58
58
  executables: []
59
59
  extensions: []
60
- extra_rdoc_files:
61
- - README.md
62
- - LICENSE.txt
60
+ extra_rdoc_files: []
63
61
  files:
62
+ - ".rspec"
63
+ - ".rubocop.yml"
64
+ - Appraisals
65
+ - CHANGELOG.md
66
+ - CODE_OF_CONDUCT.md
67
+ - Dockerfile
64
68
  - LICENSE.txt
65
69
  - README.md
70
+ - db/mysql_structure.sql
71
+ - db/postgresql_structure.sql
72
+ - docker-compose.yml
73
+ - docker/postgres_replica/cmd.sh
74
+ - gemfiles/rails_7.0.gemfile
75
+ - gemfiles/rails_7.0.gemfile.lock
76
+ - gemfiles/rails_7.1.gemfile
77
+ - gemfiles/rails_7.1.gemfile.lock
78
+ - gemfiles/rails_7.2.gemfile
79
+ - gemfiles/rails_7.2.gemfile.lock
80
+ - gemfiles/rails_8.0.gemfile
81
+ - gemfiles/rails_8.0.gemfile.lock
66
82
  - lib/active_record/connection_adapters/mysql2_proxy_adapter.rb
67
83
  - lib/active_record/connection_adapters/postgresql_proxy_adapter.rb
84
+ - lib/active_record/connection_adapters/trilogy_proxy_adapter.rb
68
85
  - lib/active_record/tasks/mysql2_proxy_database_tasks.rb
69
86
  - lib/active_record/tasks/postgresql_proxy_database_tasks.rb
87
+ - lib/active_record/tasks/trilogy_proxy_database_tasks.rb
70
88
  - lib/active_record_proxy_adapters.rb
71
89
  - lib/active_record_proxy_adapters/active_record_context.rb
72
90
  - lib/active_record_proxy_adapters/configuration.rb
73
91
  - lib/active_record_proxy_adapters/connection_handling.rb
74
92
  - lib/active_record_proxy_adapters/connection_handling/mysql2.rb
75
93
  - lib/active_record_proxy_adapters/connection_handling/postgresql.rb
94
+ - lib/active_record_proxy_adapters/connection_handling/trilogy.rb
76
95
  - lib/active_record_proxy_adapters/database_tasks.rb
77
96
  - lib/active_record_proxy_adapters/hijackable.rb
78
97
  - lib/active_record_proxy_adapters/log_subscriber.rb
@@ -80,7 +99,11 @@ files:
80
99
  - lib/active_record_proxy_adapters/postgresql_proxy.rb
81
100
  - lib/active_record_proxy_adapters/primary_replica_proxy.rb
82
101
  - lib/active_record_proxy_adapters/railtie.rb
102
+ - lib/active_record_proxy_adapters/trilogy_proxy.rb
83
103
  - lib/active_record_proxy_adapters/version.rb
104
+ - postgres_primary.dockerfile
105
+ - postgres_replica.dockerfile
106
+ - sig/active_record_proxy_adapters.rbs
84
107
  homepage: https://github.com/Nasdaq/active_record_proxy_adapters
85
108
  licenses:
86
109
  - MIT