Class: Decidim::Generators::InstallGenerator

Inherits:
Rails::Generators::Base
  • Object
show all
Defined in:
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 '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 don't want Decidim seeds.
    Decidim.seed!
  RUBY
end

#copy_initializerObject



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

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

#copy_migrationsObject



122
123
124
125
# File 'lib/decidim/generators/install_generator.rb', line 122

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

#installObject



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

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

#install_decidim_webpackerObject



81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# File 'lib/decidim/generators/install_generator.rb', line 81

def install_decidim_webpacker
  # Copy CSS files
  copy_file "decidim_application.scss", "app/packs/stylesheets/decidim/decidim_application.scss"
  copy_file "_decidim-settings.scss", "app/packs/stylesheets/decidim/_decidim-settings.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"

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

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

#letter_opener_webObject



127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
# File 'lib/decidim/generators/install_generator.rb', line 127

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



145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
# File 'lib/decidim/generators/install_generator.rb', line 145

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"

  run "bundle install"
end

#remove_layoutObject



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

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

#remove_old_assetsObject



100
101
102
103
104
# File 'lib/decidim/generators/install_generator.rb', line 100

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

#remove_sprockets_requirementObject



106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# File 'lib/decidim/generators/install_generator.rb', line 106

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



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

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

#smtp_environmentObject



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

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