bridgetown-activerecord 2.0.0 → 2.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +8 -0
- data/Gemfile +2 -2
- data/README.md +44 -5
- data/bridgetown.automation.rb +12 -13
- data/lib/bridgetown-activerecord/initializer.rb +8 -2
- data/lib/bridgetown-activerecord/version.rb +1 -1
- data/lib/tasks/database.rake +2 -2
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e1ec1ff457bbf992255599d52b2c8efa8708f80c97dd7c4e9e5b4497adc7edb9
|
4
|
+
data.tar.gz: b8dbab9b63c86433665feda57f3f316c6c01ca4418a17c0bc3bcb2768431d9b5
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f1ecfaec16724b1f609e6ea43b645afd1d8b08bc4d8a1332254d4f7ff32d599d52b7c3f8cfdcd0519cef550ddf61acc68e693290c78b3f2abf251aa7ca78cc30
|
7
|
+
data.tar.gz: c96065139c88134350b93e71109a9090355f2e6954b3be5ea437f106be18ac7f7473e23fe634798b8139227a5ace8a09ae4398166626614c95de6c784f1be77b
|
data/CHANGELOG.md
CHANGED
@@ -7,6 +7,14 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
7
7
|
|
8
8
|
## Unreleased
|
9
9
|
|
10
|
+
## [2.2.0] - 2023-03-13
|
11
|
+
|
12
|
+
- Add support for Sequel with shared DB connection
|
13
|
+
|
14
|
+
## [2.1.0] - 2022-10-10
|
15
|
+
|
16
|
+
- Allow customizing of the models dir
|
17
|
+
|
10
18
|
## [2.0.0] - 2022-10-08
|
11
19
|
|
12
20
|
- Upgrade to initializers system in Bridgetown 1.2
|
data/Gemfile
CHANGED
@@ -8,7 +8,7 @@ gem "bridgetown", ENV["BRIDGETOWN_VERSION"] if ENV["BRIDGETOWN_VERSION"]
|
|
8
8
|
group :test do
|
9
9
|
gem "minitest"
|
10
10
|
gem "minitest-reporters"
|
11
|
+
gem "pg", "~> 1.3"
|
12
|
+
gem "sequel-activerecord_connection", "~> 1.2"
|
11
13
|
gem "shoulda"
|
12
14
|
end
|
13
|
-
|
14
|
-
gem "pg", "~> 1.3", group: :test
|
data/README.md
CHANGED
@@ -1,10 +1,14 @@
|
|
1
|
-
# Bridgetown
|
1
|
+
# Bridgetown Active Record plugin
|
2
2
|
|
3
|
-
|
3
|
+
This plugin adds [Active Record](https://guides.rubyonrails.org/active_record_basics.html) support to Bridgetown sites (v1.2 or higher). You can pull data from a database (currently PostgreSQL is officially supported) during a static build or during server requests (or both!) and use many of the features you know and love from Active Record in Rails—including migrations!
|
4
|
+
|
5
|
+
In addition, if you also like using the [Sequel gem](https://github.com/jeremyevans/sequel) for your database access, this plugin can support instantiating Sequel with a shared DB connection via the [sequel-activerecord_connection](https://github.com/janko/sequel-activerecord_connection) extension ([see below](#using-with-sequel)).
|
4
6
|
|
5
7
|
## Installation
|
6
8
|
|
7
|
-
|
9
|
+
> **IMPORTANT NOTE:** there's currently a compatibilty issue between Rails 7 gems and Rack version 3. For now, please add `gem "rack", "~> 2.2"` to your Gemfile _before_ you install this plugin.
|
10
|
+
|
11
|
+
It's recommended you run our automation script to set up your project to support Active Record and DB models:
|
8
12
|
|
9
13
|
```shell
|
10
14
|
$ bin/bridgetown apply https://github.com/bridgetownrb/bridgetown-activerecord
|
@@ -13,7 +17,7 @@ $ bin/bridgetown apply https://github.com/bridgetownrb/bridgetown-activerecord
|
|
13
17
|
Or for a fully manual setup:
|
14
18
|
|
15
19
|
```shell
|
16
|
-
$ bundle add bridgetown-activerecord
|
20
|
+
$ bundle add bridgetown-activerecord
|
17
21
|
```
|
18
22
|
|
19
23
|
then replicate the individual steps outlined in the [automation script](https://github.com/bridgetownrb/bridgetown-activerecord/blob/main/bridgetown.automation.rb).
|
@@ -24,6 +28,8 @@ You will need to decide on your database adapter of choice. For a typical Postgr
|
|
24
28
|
$ bundle add pg
|
25
29
|
```
|
26
30
|
|
31
|
+
When deploying to production, the `DATABASE_URL` ENV var will need to be set with the appropriate connection string…many hosting services will do this for you automatically.
|
32
|
+
|
27
33
|
## Usage
|
28
34
|
|
29
35
|
Let's create a simple Movie model to load and save our favorite movies. Add the file `models/movie.rb`:
|
@@ -92,7 +98,40 @@ $ bin/bridgetown console
|
|
92
98
|
}
|
93
99
|
```
|
94
100
|
|
95
|
-
You're ready to roll to take full advantage of
|
101
|
+
You're ready to roll to take full advantage of Active Record database models in your Bridgetown site!
|
102
|
+
|
103
|
+
## Changing the Models Directory
|
104
|
+
|
105
|
+
If you'd prefer to set up your models folder elsewhere other than `./models`, you can move the files to another path and then update your Rakefile to pass in that path. For example, you could use the more familiar `app/models`:
|
106
|
+
|
107
|
+
```ruby
|
108
|
+
require "bridgetown-activerecord"
|
109
|
+
BridgetownActiveRecord.load_tasks(models_dir: "app/models")
|
110
|
+
```
|
111
|
+
|
112
|
+
(Don't forget to update your autoload path in `config/initializers.rb` accordingly.)
|
113
|
+
|
114
|
+
## Using with Sequel
|
115
|
+
|
116
|
+
To set up [Sequel](https://github.com/jeremyevans/sequel) using the same database connection as Active Record, follow these steps:
|
117
|
+
|
118
|
+
First, install the sequel-activerecord_connection gem:
|
119
|
+
|
120
|
+
```sh
|
121
|
+
bundle add sequel-activerecord_connection
|
122
|
+
```
|
123
|
+
|
124
|
+
Next, update your configuration in `config/initializers.rb` as follows:
|
125
|
+
|
126
|
+
```ruby
|
127
|
+
init :"bridgetown-activerecord", sequel_support: :postgres # or mysql2 or sqlite3
|
128
|
+
```
|
129
|
+
|
130
|
+
Now you should be able to call `DB` to access the Sequel API anywhere in your Bridgetown or Roda code:
|
131
|
+
|
132
|
+
```ruby
|
133
|
+
DB.tables # => [:ar_internal_metadata, :schema_migrations, etc.]
|
134
|
+
```
|
96
135
|
|
97
136
|
## Testing
|
98
137
|
|
data/bridgetown.automation.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
|
2
|
-
|
1
|
+
add_gem "bridgetown-activerecord"
|
2
|
+
add_gem "annotate", group: :development
|
3
3
|
|
4
4
|
# TODO:
|
5
5
|
#dboptions = ["postgresql", "mysql", "vanilla"]
|
@@ -50,21 +50,20 @@ create_file ".standalone_migrations" do
|
|
50
50
|
YML
|
51
51
|
end
|
52
52
|
|
53
|
-
|
54
|
-
<<~YML
|
53
|
+
insert_into_file "Rakefile", "require \"bridgetown-activerecord\"\nBridgetownActiveRecord.load_tasks\n", :after => "Bridgetown.load_tasks\n"
|
55
54
|
|
56
|
-
|
57
|
-
|
58
|
-
|
55
|
+
ruby_configure "Support for autoloading models" do
|
56
|
+
<<~RUBY
|
57
|
+
config.autoload_paths << {
|
58
|
+
path: "models",
|
59
|
+
eager: true
|
60
|
+
}
|
59
61
|
|
60
|
-
autoloader_collapsed_paths
|
61
|
-
|
62
|
-
YML
|
62
|
+
config.autoloader_collapsed_paths << "models/concerns"
|
63
|
+
RUBY
|
63
64
|
end
|
64
65
|
|
65
|
-
|
66
|
-
|
67
|
-
# TODO: add to initializer !!!
|
66
|
+
add_initializer :"bridgetown-activerecord"
|
68
67
|
|
69
68
|
say_status :active_record, "The plugin has been configured. For usage help visit:"
|
70
69
|
say_status :active_record, "https://github.com/bridgetownrb/bridgetown-activerecord/blob/main/README.md"
|
@@ -6,7 +6,8 @@ require "active_record"
|
|
6
6
|
require "active_support/configuration_file"
|
7
7
|
|
8
8
|
module BridgetownActiveRecord
|
9
|
-
def self.load_tasks
|
9
|
+
def self.load_tasks(models_dir: "models")
|
10
|
+
ENV["BRIDGETOWN_ACTIVERECORD_MODELS_DIR"] ||= models_dir
|
10
11
|
load File.expand_path("../tasks/database.rake", __dir__)
|
11
12
|
end
|
12
13
|
|
@@ -19,9 +20,14 @@ module BridgetownActiveRecord
|
|
19
20
|
end
|
20
21
|
end
|
21
22
|
|
22
|
-
Bridgetown.initializer :"bridgetown-activerecord" do |config|
|
23
|
+
Bridgetown.initializer :"bridgetown-activerecord" do |config, sequel_support: nil|
|
23
24
|
ActiveRecord::Base.establish_connection(
|
24
25
|
BridgetownActiveRecord.db_configuration(config)[Bridgetown.environment]
|
25
26
|
)
|
26
27
|
ActiveRecord::Base.logger = BridgetownActiveRecord.log_writer
|
28
|
+
|
29
|
+
next unless sequel_support
|
30
|
+
|
31
|
+
require "sequel"
|
32
|
+
DB = Sequel.send(sequel_support, extensions: :activerecord_connection) # rubocop:disable Lint/ConstantDefinitionInBlock
|
27
33
|
end
|
data/lib/tasks/database.rake
CHANGED
@@ -5,12 +5,12 @@ ENV["SCHEMA"] = File.join(Dir.pwd, "db", "schema.rb")
|
|
5
5
|
require "standalone_migrations"
|
6
6
|
StandaloneMigrations::Tasks.load_tasks
|
7
7
|
|
8
|
-
require "
|
8
|
+
require "./#{ENV.fetch("BRIDGETOWN_ACTIVERECORD_MODELS_DIR", "models")}/application_record"
|
9
9
|
|
10
10
|
# Setup Annotate so it runs on db:migrate, etc.
|
11
11
|
if Bridgetown.environment.development?
|
12
12
|
require "annotate"
|
13
|
-
ENV["model_dir"] = "models"
|
13
|
+
ENV["model_dir"] = ENV.fetch("BRIDGETOWN_ACTIVERECORD_MODELS_DIR", "models")
|
14
14
|
Annotate::Helpers.class_eval do
|
15
15
|
# We need to redefine this because our custom model_dir shortcircuits the migration task enhancement
|
16
16
|
def self.include_models?
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: bridgetown-activerecord
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Bridgetown Team
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-03-13 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bridgetown
|