Class: Decidim::Generators::InstallGenerator

Inherits:
Rails::Generators::Base
  • Object
show all
Defined in:
decidim-generators/lib/decidim/generators/install_generator.rb

Overview

Installs ‘decidim` to a Rails app by adding the needed lines of code automatically to important files in the Rails app.

Remember that, for how generators work, actions are executed based on the definition order of the public methods.

Instance Method Summary collapse

Instance Method Details

#add_seedsObject



41
42
43
44
45
46
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 41

def add_seeds
  append_file "db/seeds.rb", <<~RUBY
    # You can remove the 'faker' gem if you do not want Decidim seeds.
    Decidim.seed!
  RUBY
end

#build_api_docsObject



108
109
110
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 108

def build_api_docs
  rails "decidim_api:generate_docs"
end

#bundle_installObject



176
177
178
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 176

def bundle_install
  run "bundle install"
end

#copy_initializerObject



48
49
50
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 48

def copy_initializer
  copy_file "carrierwave.rb", "config/initializers/carrierwave.rb"
end

#copy_migrationsObject



134
135
136
137
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 134

def copy_migrations
  rails "decidim:choose_target_plugins", "railties:install:migrations"
  recreate_db if options[:recreate_db]
end

#installObject



37
38
39
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 37

def install
  route "mount Decidim::Core::Engine => '/'"
end

#install_decidim_webpackerObject



80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 80

def install_decidim_webpacker
  # Copy CSS file
  copy_file "decidim_application.scss", "app/packs/stylesheets/decidim/decidim_application.scss"

  # Copy JS application file
  copy_file "decidim_application.js", "app/packs/src/decidim/decidim_application.js"

  # Create empty directory for images
  empty_directory "app/packs/images"
  # Add a .keep file so directory is included in git when committing
  create_file "app/packs/images/.keep"

  # Regenerate webpacker binstubs
  remove_file "bin/yarn"
  bundle_install
  rails "shakapacker:binstubs"

  # Run Decidim custom webpacker installation
  rails "decidim:webpacker:install"

  # Run Decidim custom procfile installation
  rails "decidim:procfile:install"

  # Replace robots.txt
  remove_file "public/robots.txt"
  rails "decidim:robots:replace"
end

#letter_opener_webObject



139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 139

def letter_opener_web
  route <<~RUBY
    if Rails.env.development?
      mount LetterOpenerWeb::Engine, at: "/letter_opener"
    end

  RUBY

  inject_into_file "config/environments/development.rb",
                   after: "config.action_mailer.raise_delivery_errors = false" do
    cut <<~RUBY
      |
      |  config.action_mailer.delivery_method = :letter_opener_web
      |  config.action_mailer.default_url_options = { port: 3000 }
    RUBY
  end
end

#profiling_gemsObject



157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 157

def profiling_gems
  return unless options[:profiling]

  append_file "Gemfile", <<~RUBY

    group :development do
      # Profiling gems
      gem "bullet"
      gem "flamegraph"
      gem "memory_profiler"
      gem "rack-mini-profiler", require: false
      gem "stackprof"
    end
  RUBY

  copy_file "bullet_initializer.rb", "config/initializers/bullet.rb"
  copy_file "rack_profiler_initializer.rb", "config/initializers/rack_profiler.rb"
end

#remove_layoutObject



56
57
58
59
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 56

def remove_layout
  remove_file "app/views/layouts/application.html.erb"
  remove_file "app/views/layouts/mailer.text.erb"
end

#remove_old_assetsObject



112
113
114
115
116
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 112

def remove_old_assets
  remove_file "config/initializers/assets.rb"
  remove_dir("app/assets")
  remove_dir("app/javascript")
end

#remove_sprockets_requirementObject



118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 118

def remove_sprockets_requirement
  gsub_file "config/application.rb", %r{require ['"]rails/all['"]\R}, <<~RUBY
    require "decidim/rails"

    # Add the frameworks used by your app that are not loaded by Decidim.
    # require "action_mailbox/engine"
    # require "action_text/engine"
    require "action_cable/engine"
    require "rails/test_unit/railtie"
  RUBY

  gsub_file "config/environments/development.rb", /config\.assets.*$/, ""
  gsub_file "config/environments/test.rb", /config\.assets.*$/, ""
  gsub_file "config/environments/production.rb", /config\.assets.*$/, ""
end

#secretsObject



52
53
54
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 52

def secrets
  template "secrets.yml.erb", "config/secrets.yml", force: true
end

#smtp_environmentObject



61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# File 'decidim-generators/lib/decidim/generators/install_generator.rb', line 61

def smtp_environment
  inject_into_file "config/environments/production.rb",
                   after: "config.log_formatter = ::Logger::Formatter.new" do
    cut <<~RUBY
      |
      |  config.action_mailer.smtp_settings = {
      |    :address        => Rails.application.secrets.smtp_address,
      |    :port           => Rails.application.secrets.smtp_port,
      |    :authentication => Rails.application.secrets.smtp_authentication,
      |    :user_name      => Rails.application.secrets.smtp_username,
      |    :password       => Rails.application.secrets.smtp_password,
      |    :domain         => Rails.application.secrets.smtp_domain,
      |    :enable_starttls_auto => Rails.application.secrets.smtp_starttls_auto,
      |    :openssl_verify_mode => 'none'
      |  }
    RUBY
  end
end