parklife 0.2.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 (89) hide show
  1. checksums.yaml +7 -0
  2. data/.github/workflows/tests.yml +62 -0
  3. data/.gitignore +10 -0
  4. data/.rspec +2 -0
  5. data/CHANGELOG.md +9 -0
  6. data/CODE_OF_CONDUCT.md +74 -0
  7. data/Gemfile +6 -0
  8. data/LICENSE.txt +21 -0
  9. data/README.md +103 -0
  10. data/Rakefile +6 -0
  11. data/bin/console +14 -0
  12. data/bin/setup +8 -0
  13. data/examples/rack/.gitignore +1 -0
  14. data/examples/rack/Gemfile +4 -0
  15. data/examples/rack/Gemfile.lock +47 -0
  16. data/examples/rack/Parkfile +23 -0
  17. data/examples/rails/.gitignore +26 -0
  18. data/examples/rails/Gemfile +5 -0
  19. data/examples/rails/Gemfile.lock +150 -0
  20. data/examples/rails/Parkfile +6 -0
  21. data/examples/rails/Rakefile +6 -0
  22. data/examples/rails/app/assets/config/manifest.js +2 -0
  23. data/examples/rails/app/assets/stylesheets/application.css +15 -0
  24. data/examples/rails/app/assets/stylesheets/global.css +4 -0
  25. data/examples/rails/app/controllers/application_controller.rb +2 -0
  26. data/examples/rails/app/controllers/posts_controller.rb +9 -0
  27. data/examples/rails/app/helpers/application_helper.rb +2 -0
  28. data/examples/rails/app/jobs/application_job.rb +2 -0
  29. data/examples/rails/app/models/application_record.rb +3 -0
  30. data/examples/rails/app/models/post.rb +5 -0
  31. data/examples/rails/app/views/layouts/application.html.erb +14 -0
  32. data/examples/rails/app/views/posts/index.html.erb +7 -0
  33. data/examples/rails/app/views/posts/show.html.erb +3 -0
  34. data/examples/rails/bin/bundle +3 -0
  35. data/examples/rails/bin/rails +4 -0
  36. data/examples/rails/bin/rake +4 -0
  37. data/examples/rails/bin/setup +33 -0
  38. data/examples/rails/bin/update +28 -0
  39. data/examples/rails/config/application.rb +35 -0
  40. data/examples/rails/config/boot.rb +3 -0
  41. data/examples/rails/config/database.yml +25 -0
  42. data/examples/rails/config/environment.rb +5 -0
  43. data/examples/rails/config/environments/development.rb +53 -0
  44. data/examples/rails/config/environments/production.rb +79 -0
  45. data/examples/rails/config/environments/test.rb +36 -0
  46. data/examples/rails/config/initializers/application_controller_renderer.rb +8 -0
  47. data/examples/rails/config/initializers/assets.rb +12 -0
  48. data/examples/rails/config/initializers/backtrace_silencers.rb +7 -0
  49. data/examples/rails/config/initializers/content_security_policy.rb +25 -0
  50. data/examples/rails/config/initializers/cookies_serializer.rb +5 -0
  51. data/examples/rails/config/initializers/filter_parameter_logging.rb +4 -0
  52. data/examples/rails/config/initializers/inflections.rb +16 -0
  53. data/examples/rails/config/initializers/mime_types.rb +4 -0
  54. data/examples/rails/config/initializers/wrap_parameters.rb +14 -0
  55. data/examples/rails/config/locales/en.yml +33 -0
  56. data/examples/rails/config/routes.rb +5 -0
  57. data/examples/rails/config.ru +5 -0
  58. data/examples/rails/data/1-hello-from-parklife.txt +3 -0
  59. data/examples/rails/data/2-hello-again.txt +3 -0
  60. data/examples/rails/data/3-magic-number.txt +3 -0
  61. data/examples/rails/db/migrate/20190507172823_create_posts.rb +11 -0
  62. data/examples/rails/db/schema.rb +24 -0
  63. data/examples/rails/db/seeds.rb +10 -0
  64. data/examples/rails/parklife-build +24 -0
  65. data/examples/rails/public/404.html +67 -0
  66. data/examples/rails/public/422.html +67 -0
  67. data/examples/rails/public/500.html +66 -0
  68. data/examples/rails/public/apple-touch-icon-precomposed.png +0 -0
  69. data/examples/rails/public/apple-touch-icon.png +0 -0
  70. data/examples/rails/public/favicon.ico +0 -0
  71. data/examples/rails/public/robots.txt +1 -0
  72. data/examples/sinatra/.gitignore +1 -0
  73. data/examples/sinatra/Gemfile +4 -0
  74. data/examples/sinatra/Gemfile.lock +56 -0
  75. data/examples/sinatra/Parkfile +21 -0
  76. data/exe/parklife +3 -0
  77. data/lib/parklife/application.rb +39 -0
  78. data/lib/parklife/cli.rb +36 -0
  79. data/lib/parklife/config.rb +14 -0
  80. data/lib/parklife/crawler.rb +104 -0
  81. data/lib/parklife/errors.rb +25 -0
  82. data/lib/parklife/rails.rb +12 -0
  83. data/lib/parklife/route.rb +23 -0
  84. data/lib/parklife/route_set.rb +36 -0
  85. data/lib/parklife/utils.rb +20 -0
  86. data/lib/parklife/version.rb +3 -0
  87. data/lib/parklife.rb +8 -0
  88. data/parklife.gemspec +38 -0
  89. metadata +217 -0
@@ -0,0 +1,14 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Example</title>
5
+ <%= csrf_meta_tags %>
6
+ <%= csp_meta_tag %>
7
+
8
+ <%= stylesheet_link_tag 'application', media: 'all' %>
9
+ </head>
10
+
11
+ <body>
12
+ <%= yield %>
13
+ </body>
14
+ </html>
@@ -0,0 +1,7 @@
1
+ <h1>Rails Parklife example</h1>
2
+
3
+ <% @posts.each do |post| %>
4
+ <div>
5
+ <%= link_to post.title, post %>
6
+ </div>
7
+ <% end %>
@@ -0,0 +1,3 @@
1
+ <h1><%= @post.title %></h1>
2
+
3
+ <%= simple_format @post.body %>
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env ruby
2
+ ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../Gemfile', __dir__)
3
+ load Gem.bin_path('bundler', 'bundle')
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+ APP_PATH = File.expand_path('../config/application', __dir__)
3
+ require_relative '../config/boot'
4
+ require 'rails/commands'
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+ require_relative '../config/boot'
3
+ require 'rake'
4
+ Rake.application.run
@@ -0,0 +1,33 @@
1
+ #!/usr/bin/env ruby
2
+ require 'fileutils'
3
+ include FileUtils
4
+
5
+ # path to your application root.
6
+ APP_ROOT = File.expand_path('..', __dir__)
7
+
8
+ def system!(*args)
9
+ system(*args) || abort("\n== Command #{args} failed ==")
10
+ end
11
+
12
+ chdir APP_ROOT do
13
+ # This script is a starting point to setup your application.
14
+ # Add necessary setup steps to this file.
15
+
16
+ puts '== Installing dependencies =='
17
+ system! 'gem install bundler --conservative'
18
+ system('bundle check') || system!('bundle install')
19
+
20
+ # puts "\n== Copying sample files =="
21
+ # unless File.exist?('config/database.yml')
22
+ # cp 'config/database.yml.sample', 'config/database.yml'
23
+ # end
24
+
25
+ puts "\n== Preparing database =="
26
+ system! 'bin/rails db:setup'
27
+
28
+ puts "\n== Removing old logs and tempfiles =="
29
+ system! 'bin/rails log:clear tmp:clear'
30
+
31
+ puts "\n== Restarting application server =="
32
+ system! 'bin/rails restart'
33
+ end
@@ -0,0 +1,28 @@
1
+ #!/usr/bin/env ruby
2
+ require 'fileutils'
3
+ include FileUtils
4
+
5
+ # path to your application root.
6
+ APP_ROOT = File.expand_path('..', __dir__)
7
+
8
+ def system!(*args)
9
+ system(*args) || abort("\n== Command #{args} failed ==")
10
+ end
11
+
12
+ chdir APP_ROOT do
13
+ # This script is a way to update your development environment automatically.
14
+ # Add necessary update steps to this file.
15
+
16
+ puts '== Installing dependencies =='
17
+ system! 'gem install bundler --conservative'
18
+ system('bundle check') || system!('bundle install')
19
+
20
+ puts "\n== Updating database =="
21
+ system! 'bin/rails db:migrate'
22
+
23
+ puts "\n== Removing old logs and tempfiles =="
24
+ system! 'bin/rails log:clear tmp:clear'
25
+
26
+ puts "\n== Restarting application server =="
27
+ system! 'bin/rails restart'
28
+ end
@@ -0,0 +1,35 @@
1
+ require_relative 'boot'
2
+
3
+ require "rails"
4
+ # Pick the frameworks you want:
5
+ require "active_model/railtie"
6
+ require "active_job/railtie"
7
+ require "active_record/railtie"
8
+ # require "active_storage/engine"
9
+ require "action_controller/railtie"
10
+ # require "action_mailer/railtie"
11
+ require "action_view/railtie"
12
+ # require "action_cable/engine"
13
+ require "sprockets/railtie"
14
+ # require "rails/test_unit/railtie"
15
+
16
+ # Require the gems listed in Gemfile, including any gems
17
+ # you've limited to :test, :development, or :production.
18
+ Bundler.require(*Rails.groups)
19
+
20
+ module Example
21
+ class Application < Rails::Application
22
+ # Initialize configuration defaults for originally generated Rails version.
23
+ config.load_defaults 5.2
24
+
25
+ # Settings in config/environments/* take precedence over those specified here.
26
+ # Application configuration can go into files in config/initializers
27
+ # -- all .rb files in that directory are automatically loaded after loading
28
+ # the framework and any gems in your application.
29
+
30
+ # Don't generate system test files.
31
+ config.generators.system_tests = nil
32
+
33
+ config.secret_key_base = ENV['SECRET_KEY_BASE']
34
+ end
35
+ end
@@ -0,0 +1,3 @@
1
+ ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../Gemfile', __dir__)
2
+
3
+ require 'bundler/setup' # Set up gems listed in the Gemfile.
@@ -0,0 +1,25 @@
1
+ # SQLite version 3.x
2
+ # gem install sqlite3
3
+ #
4
+ # Ensure the SQLite 3 gem is defined in your Gemfile
5
+ # gem 'sqlite3'
6
+ #
7
+ default: &default
8
+ adapter: sqlite3
9
+ pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
10
+ timeout: 5000
11
+
12
+ development:
13
+ <<: *default
14
+ database: db/development.sqlite3
15
+
16
+ # Warning: The database defined as "test" will be erased and
17
+ # re-generated from your development database when you run "rake".
18
+ # Do not set this db to the same as development or production.
19
+ test:
20
+ <<: *default
21
+ database: db/test.sqlite3
22
+
23
+ production:
24
+ <<: *default
25
+ database: db/production.sqlite3
@@ -0,0 +1,5 @@
1
+ # Load the Rails application.
2
+ require_relative 'application'
3
+
4
+ # Initialize the Rails application.
5
+ Rails.application.initialize!
@@ -0,0 +1,53 @@
1
+ Rails.application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb.
3
+
4
+ # In the development environment your application's code is reloaded on
5
+ # every request. This slows down response time but is perfect for development
6
+ # since you don't have to restart the web server when you make code changes.
7
+ config.cache_classes = false
8
+
9
+ # Do not eager load code on boot.
10
+ config.eager_load = false
11
+
12
+ # Show full error reports.
13
+ config.consider_all_requests_local = true
14
+
15
+ # Enable/disable caching. By default caching is disabled.
16
+ # Run rails dev:cache to toggle caching.
17
+ if Rails.root.join('tmp', 'caching-dev.txt').exist?
18
+ config.action_controller.perform_caching = true
19
+
20
+ config.cache_store = :memory_store
21
+ config.public_file_server.headers = {
22
+ 'Cache-Control' => "public, max-age=#{2.days.to_i}"
23
+ }
24
+ else
25
+ config.action_controller.perform_caching = false
26
+
27
+ config.cache_store = :null_store
28
+ end
29
+
30
+ # Print deprecation notices to the Rails logger.
31
+ config.active_support.deprecation = :log
32
+
33
+ # Raise an error on page load if there are pending migrations.
34
+ config.active_record.migration_error = :page_load
35
+
36
+ # Highlight code that triggered database queries in logs.
37
+ config.active_record.verbose_query_logs = true
38
+
39
+ # Debug mode disables concatenation and preprocessing of assets.
40
+ # This option may cause significant delays in view rendering with a large
41
+ # number of complex assets.
42
+ config.assets.debug = true
43
+
44
+ # Suppress logger output for asset requests.
45
+ config.assets.quiet = true
46
+
47
+ # Raises error for missing translations
48
+ # config.action_view.raise_on_missing_translations = true
49
+
50
+ # Use an evented file watcher to asynchronously detect changes in source code,
51
+ # routes, locales, etc. This feature depends on the listen gem.
52
+ # config.file_watcher = ActiveSupport::EventedFileUpdateChecker
53
+ end
@@ -0,0 +1,79 @@
1
+ Rails.application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb.
3
+
4
+ # Code is not reloaded between requests.
5
+ config.cache_classes = true
6
+
7
+ # Eager load code on boot. This eager loads most of Rails and
8
+ # your application in memory, allowing both threaded web servers
9
+ # and those relying on copy on write to perform better.
10
+ # Rake tasks automatically ignore this option for performance.
11
+ config.eager_load = true
12
+
13
+ # Full error reports are disabled and caching is turned on.
14
+ config.consider_all_requests_local = false
15
+ config.action_controller.perform_caching = true
16
+
17
+ # Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"]
18
+ # or in config/master.key. This key is used to decrypt credentials (and other encrypted files).
19
+ # config.require_master_key = true
20
+
21
+ # Disable serving static files from the `/public` folder by default since
22
+ # Apache or NGINX already handles this.
23
+ config.public_file_server.enabled = ENV['RAILS_SERVE_STATIC_FILES'].present?
24
+
25
+ # Compress CSS.
26
+ # config.assets.css_compressor = :sass
27
+
28
+ # Do not fallback to assets pipeline if a precompiled asset is missed.
29
+ config.assets.compile = false
30
+
31
+ # `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb
32
+
33
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server.
34
+ # config.action_controller.asset_host = 'http://assets.example.com'
35
+
36
+ # Specifies the header that your server uses for sending files.
37
+ # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
38
+ # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
39
+
40
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
41
+ # config.force_ssl = true
42
+
43
+ # Use the lowest log level to ensure availability of diagnostic information
44
+ # when problems arise.
45
+ config.log_level = :debug
46
+
47
+ # Prepend all log lines with the following tags.
48
+ config.log_tags = [ :request_id ]
49
+
50
+ # Use a different cache store in production.
51
+ # config.cache_store = :mem_cache_store
52
+
53
+ # Use a real queuing backend for Active Job (and separate queues per environment)
54
+ # config.active_job.queue_adapter = :resque
55
+ # config.active_job.queue_name_prefix = "example_#{Rails.env}"
56
+
57
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
58
+ # the I18n.default_locale when a translation cannot be found).
59
+ config.i18n.fallbacks = true
60
+
61
+ # Send deprecation notices to registered listeners.
62
+ config.active_support.deprecation = :notify
63
+
64
+ # Use default logging formatter so that PID and timestamp are not suppressed.
65
+ config.log_formatter = ::Logger::Formatter.new
66
+
67
+ # Use a different logger for distributed setups.
68
+ # require 'syslog/logger'
69
+ # config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name')
70
+
71
+ if ENV["RAILS_LOG_TO_STDOUT"].present?
72
+ logger = ActiveSupport::Logger.new(STDOUT)
73
+ logger.formatter = config.log_formatter
74
+ config.logger = ActiveSupport::TaggedLogging.new(logger)
75
+ end
76
+
77
+ # Do not dump schema after migrations.
78
+ config.active_record.dump_schema_after_migration = false
79
+ end
@@ -0,0 +1,36 @@
1
+ Rails.application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb.
3
+
4
+ # The test environment is used exclusively to run your application's
5
+ # test suite. You never need to work with it otherwise. Remember that
6
+ # your test database is "scratch space" for the test suite and is wiped
7
+ # and recreated between test runs. Don't rely on the data there!
8
+ config.cache_classes = true
9
+
10
+ # Do not eager load code on boot. This avoids loading your whole application
11
+ # just for the purpose of running a single test. If you are using a tool that
12
+ # preloads Rails for running tests, you may have to set it to true.
13
+ config.eager_load = false
14
+
15
+ # Configure public file server for tests with Cache-Control for performance.
16
+ config.public_file_server.enabled = true
17
+ config.public_file_server.headers = {
18
+ 'Cache-Control' => "public, max-age=#{1.hour.to_i}"
19
+ }
20
+
21
+ # Show full error reports and disable caching.
22
+ config.consider_all_requests_local = true
23
+ config.action_controller.perform_caching = false
24
+
25
+ # Raise exceptions instead of rendering exception templates.
26
+ config.action_dispatch.show_exceptions = false
27
+
28
+ # Disable request forgery protection in test environment.
29
+ config.action_controller.allow_forgery_protection = false
30
+
31
+ # Print deprecation notices to the stderr.
32
+ config.active_support.deprecation = :stderr
33
+
34
+ # Raises error for missing translations
35
+ # config.action_view.raise_on_missing_translations = true
36
+ end
@@ -0,0 +1,8 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # ActiveSupport::Reloader.to_prepare do
4
+ # ApplicationController.renderer.defaults.merge!(
5
+ # http_host: 'example.org',
6
+ # https: false
7
+ # )
8
+ # end
@@ -0,0 +1,12 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Version of your assets, change this if you want to expire all your assets.
4
+ Rails.application.config.assets.version = '1.0'
5
+
6
+ # Add additional assets to the asset load path.
7
+ # Rails.application.config.assets.paths << Emoji.images_path
8
+
9
+ # Precompile additional assets.
10
+ # application.js, application.css, and all non-JS/CSS in the app/assets
11
+ # folder are already added.
12
+ # Rails.application.config.assets.precompile += %w( admin.js admin.css )
@@ -0,0 +1,7 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4
+ # Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
5
+
6
+ # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
7
+ # Rails.backtrace_cleaner.remove_silencers!
@@ -0,0 +1,25 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Define an application-wide content security policy
4
+ # For further information see the following documentation
5
+ # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy
6
+
7
+ # Rails.application.config.content_security_policy do |policy|
8
+ # policy.default_src :self, :https
9
+ # policy.font_src :self, :https, :data
10
+ # policy.img_src :self, :https, :data
11
+ # policy.object_src :none
12
+ # policy.script_src :self, :https
13
+ # policy.style_src :self, :https
14
+
15
+ # # Specify URI for violation reports
16
+ # # policy.report_uri "/csp-violation-report-endpoint"
17
+ # end
18
+
19
+ # If you are using UJS then enable automatic nonce generation
20
+ # Rails.application.config.content_security_policy_nonce_generator = -> request { SecureRandom.base64(16) }
21
+
22
+ # Report CSP violations to a specified URI
23
+ # For further information see the following documentation:
24
+ # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy-Report-Only
25
+ # Rails.application.config.content_security_policy_report_only = true
@@ -0,0 +1,5 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Specify a serializer for the signed and encrypted cookie jars.
4
+ # Valid options are :json, :marshal, and :hybrid.
5
+ Rails.application.config.action_dispatch.cookies_serializer = :json
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Configure sensitive parameters which will be filtered from the log file.
4
+ Rails.application.config.filter_parameters += [:password]
@@ -0,0 +1,16 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new inflection rules using the following format. Inflections
4
+ # are locale specific, and you may define rules for as many different
5
+ # locales as you wish. All of these examples are active by default:
6
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
7
+ # inflect.plural /^(ox)$/i, '\1en'
8
+ # inflect.singular /^(ox)en/i, '\1'
9
+ # inflect.irregular 'person', 'people'
10
+ # inflect.uncountable %w( fish sheep )
11
+ # end
12
+
13
+ # These inflection rules are supported but not enabled by default:
14
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
15
+ # inflect.acronym 'RESTful'
16
+ # end
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new mime types for use in respond_to blocks:
4
+ # Mime::Type.register "text/richtext", :rtf
@@ -0,0 +1,14 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # This file contains settings for ActionController::ParamsWrapper which
4
+ # is enabled by default.
5
+
6
+ # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7
+ ActiveSupport.on_load(:action_controller) do
8
+ wrap_parameters format: [:json]
9
+ end
10
+
11
+ # To enable root element in JSON for ActiveRecord objects.
12
+ # ActiveSupport.on_load(:active_record) do
13
+ # self.include_root_in_json = true
14
+ # end
@@ -0,0 +1,33 @@
1
+ # Files in the config/locales directory are used for internationalization
2
+ # and are automatically loaded by Rails. If you want to use locales other
3
+ # than English, add the necessary files in this directory.
4
+ #
5
+ # To use the locales, use `I18n.t`:
6
+ #
7
+ # I18n.t 'hello'
8
+ #
9
+ # In views, this is aliased to just `t`:
10
+ #
11
+ # <%= t('hello') %>
12
+ #
13
+ # To use a different locale, set it with `I18n.locale`:
14
+ #
15
+ # I18n.locale = :es
16
+ #
17
+ # This would use the information in config/locales/es.yml.
18
+ #
19
+ # The following keys must be escaped otherwise they will not be retrieved by
20
+ # the default I18n backend:
21
+ #
22
+ # true, false, on, off, yes, no
23
+ #
24
+ # Instead, surround them with single quotes.
25
+ #
26
+ # en:
27
+ # 'true': 'foo'
28
+ #
29
+ # To learn more, please read the Rails Internationalization guide
30
+ # available at http://guides.rubyonrails.org/i18n.html.
31
+
32
+ en:
33
+ hello: "Hello world"
@@ -0,0 +1,5 @@
1
+ Rails.application.routes.draw do
2
+ root to: 'posts#index'
3
+
4
+ resources :posts
5
+ end
@@ -0,0 +1,5 @@
1
+ # This file is used by Rack-based servers to start the application.
2
+
3
+ require_relative 'config/environment'
4
+
5
+ run Rails.application
@@ -0,0 +1,3 @@
1
+ Hello from Parklife
2
+
3
+ Some token body content.
@@ -0,0 +1,3 @@
1
+ Hello again!
2
+
3
+ Oops.
@@ -0,0 +1,3 @@
1
+ Three is the magic number
2
+
3
+ Yes it is.
@@ -0,0 +1,11 @@
1
+ class CreatePosts < ActiveRecord::Migration[5.2]
2
+ def change
3
+ create_table :posts do |t|
4
+ t.string :slug, null: false
5
+ t.string :title, null: false
6
+ t.text :body
7
+ t.timestamps
8
+ t.index :slug, unique: true
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,24 @@
1
+ # This file is auto-generated from the current state of the database. Instead
2
+ # of editing this file, please use the migrations feature of Active Record to
3
+ # incrementally modify your database, and then regenerate this schema definition.
4
+ #
5
+ # Note that this schema.rb definition is the authoritative source for your
6
+ # database schema. If you need to create the application database on another
7
+ # system, you should be using db:schema:load, not running all the migrations
8
+ # from scratch. The latter is a flawed and unsustainable approach (the more migrations
9
+ # you'll amass, the slower it'll run and the greater likelihood for issues).
10
+ #
11
+ # It's strongly recommended that you check this file into your version control system.
12
+
13
+ ActiveRecord::Schema.define(version: 2019_05_07_172823) do
14
+
15
+ create_table "posts", force: :cascade do |t|
16
+ t.string "slug", null: false
17
+ t.string "title", null: false
18
+ t.text "body"
19
+ t.datetime "created_at", null: false
20
+ t.datetime "updated_at", null: false
21
+ t.index ["slug"], name: "index_posts_on_slug", unique: true
22
+ end
23
+
24
+ end
@@ -0,0 +1,10 @@
1
+ Rails.root.join('data').children.each do |path|
2
+ id, slug = path.basename('.*').to_s.split('-', 2)
3
+ title, rest = path.read.split("\n", 2)
4
+
5
+ post = Post.find_or_initialize_by(id: id)
6
+ post.body = rest
7
+ post.slug = slug
8
+ post.title = title
9
+ post.save!
10
+ end
@@ -0,0 +1,24 @@
1
+ #!/usr/bin/env sh
2
+
3
+ set -eu
4
+
5
+ export RAILS_ENV=production
6
+
7
+ # Create a production SQLite database and populate it with the app's data (see
8
+ # db/seeds.rb for how).
9
+ bundle exec rails db:setup
10
+
11
+ # Generate production-optimised assets with Sprockets and friends. This must be
12
+ # done before generating the Parklife build as Rails will blow up if it detects
13
+ # missing assets at runtime.
14
+ bundle exec rails assets:precompile
15
+
16
+ # Generate the Parklife build.
17
+ bundle exec parklife build
18
+
19
+ # Copy everything in /public to the build directory -- this includes the newly
20
+ # generated sprockets assets and things like favicon.ico and robots.txt.
21
+ cp -R public/* build
22
+
23
+ # List everything in the final build -- useful debug output.
24
+ find build -type f | sort