Added sequel with example setup
This commit is contained in:
parent
1a3a4287b0
commit
bffbab8fbc
1
Gemfile
1
Gemfile
|
|
@ -5,6 +5,7 @@ gem 'rack-unreloader'
|
|||
gem 'tilt'
|
||||
gem 'erubi'
|
||||
gem 'sequel'
|
||||
gem 'rake'
|
||||
|
||||
# Change to whatever database you plan to use
|
||||
gem 'sqlite3'
|
||||
|
|
|
|||
|
|
@ -23,7 +23,7 @@ Will need ruby; install it via package manager or a ruby manager like rbenv/ruby
|
|||
With this example, will basically just ignore the project's Gemfile. Debian 12 has a pretty current ruby version so just using it.
|
||||
|
||||
```
|
||||
sudo apt install ruby ruby-rack puma ruby-erubi ruby-tilt ruby-sequel ruby-sqlite3
|
||||
sudo apt install ruby ruby-rack puma ruby-erubi ruby-tilt ruby-sequel ruby-sqlite3 rake
|
||||
sudo gem install roda rack-unreloader
|
||||
```
|
||||
|
||||
|
|
|
|||
33
Rakefile
Normal file
33
Rakefile
Normal file
|
|
@ -0,0 +1,33 @@
|
|||
namespace :db do
|
||||
|
||||
migrator = lambda do |version|
|
||||
require_relative 'db'
|
||||
Sequel.extension :migration
|
||||
Sequel::Migrator.apply(DB, 'migrate', version)
|
||||
end
|
||||
|
||||
namespace :migrate do
|
||||
|
||||
desc "Perform migration up to latest migration available"
|
||||
task :up do
|
||||
migrator.call(nil)
|
||||
end
|
||||
|
||||
desc "Perform migration all the way down (erase all data)"
|
||||
task :down do
|
||||
migrator.call(0)
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
desc "Erase all data, then bring back to latest migration"
|
||||
task :reset do
|
||||
migrator.call(0)
|
||||
Sequel::Migrator.apply(DB, 'migrate')
|
||||
end
|
||||
|
||||
#desc "Migrate to a specific version"
|
||||
#task :migrate do |version|
|
||||
#end
|
||||
|
||||
end
|
||||
|
|
@ -3,7 +3,8 @@ dev = ENV['RACK_ENV'] == 'development'
|
|||
|
||||
require 'rack/unreloader'
|
||||
|
||||
Unreloader = Rack::Unreloader.new(:subclasses=>%w'Roda', :reload=>dev){App}
|
||||
Unreloader = Rack::Unreloader.new(:subclasses=>%w'Roda Sequel::Model', reload: dev, autoload: dev){App}
|
||||
Unreloader.require './models.rb'
|
||||
Unreloader.require './app.rb'
|
||||
|
||||
run(dev ? Unreloader : App)
|
||||
|
|
|
|||
4
db.rb
Normal file
4
db.rb
Normal file
|
|
@ -0,0 +1,4 @@
|
|||
# frozen_string_literal: true
|
||||
require 'sequel/core'
|
||||
|
||||
DB = Sequel.connect('sqlite://temp.db')
|
||||
11
migrate/001_create_users_table.rb
Normal file
11
migrate/001_create_users_table.rb
Normal file
|
|
@ -0,0 +1,11 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
Sequel.migration do
|
||||
change do
|
||||
create_table(:users) do
|
||||
primary_key :id
|
||||
String :name, unique: true, null: false
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
14
models.rb
Normal file
14
models.rb
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
# frozen_string_literal: true
|
||||
require_relative 'db'
|
||||
require 'sequel/model'
|
||||
|
||||
if ENV['RACK_ENV'] == 'development'
|
||||
Sequel::Model.cache_associations = false
|
||||
end
|
||||
|
||||
unless defined?(Unreloader)
|
||||
require 'rack/unreloader'
|
||||
Unreloader = Rack::Unreloader.new(reload: false, autoload: !ENV['NO_AUTOLOAD'])
|
||||
end
|
||||
|
||||
Unreloader.autoload('models'){|f| Sequel::Model.send(:camelize, File.basename(f).sub(/\.rb\z/, ''))}
|
||||
3
models/user.rb
Normal file
3
models/user.rb
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
# frozen_string_literal: true
|
||||
class User < Sequel::Model
|
||||
end
|
||||
|
|
@ -1,3 +1,3 @@
|
|||
<p class="subtitle is-3">
|
||||
Welcome to my new page!
|
||||
Welcome to my new page! Running in <%= ENV['RACK_ENV'] %> mode!
|
||||
</p>
|
||||
|
|
|
|||
Loading…
Reference in a new issue