123456789_123456789_123456789_123456789_123456789_

Class: Rails::Generators::MasterKeyGenerator

Do not use. This class is for internal use only.
Relationships & Source Files
Super Chains via Extension / Inclusion / Inheritance
Class Chain:
self, Base, Thor::Group
Instance Chain:
self, Base, Actions, Thor::Actions, Thor::Group
Inherits: Rails::Generators::Base
Defined in: railties/lib/rails/generators/rails/master_key/master_key_generator.rb

Constant Summary

Class Attribute Summary

Base - Inherited

Class Method Summary

Base - Inherited

.base_root

Returns the base root for a common set of generators.

.default_source_root

Returns the default source root for a given generator.

.desc

Tries to get the description from a USAGE file one folder above the source root otherwise uses a default description.

.hide!

Convenience method to hide this generator from the available ones when running rails generator command.

.hook_for

Invoke a generator based on the value supplied by the user to the given option named “name”.

.namespace

Convenience method to get the namespace from the class name.

.remove_hook_for

Remove a previously added hook.

.source_root

Returns the source root for this generator using default_source_root as default.

.add_shebang_option!

Small macro to add ruby as an option to the generator with proper default value plus an instance helper method called shebang.

.banner

Use Rails default banner.

.base_name

Sets the base_name taking into account the current class namespace.

.default_aliases_for_option

Returns default aliases for the option name given doing a lookup in aliases.

.default_for_option

Returns default for the option name given doing a lookup in config.

.default_generator_root,
.default_value_for_option

Returns the default value for the option name given doing a lookup in options.

.generator_name

Removes the namespaces and get the generator name.

.usage_path,
.class_option

Make class option aware of options and aliases.

.inherited

Cache source root and add lib/generators/base/generator/templates to source paths.

.hooks

Keep hooks configuration that are used on prepare_for_invocation.

.prepare_for_invocation

Prepare class invocation to search on ::Rails namespace if a previous added hook is being used.

Instance Attribute Summary

Base - Inherited

Instance Method Summary

Base - Inherited

#class_collisions

Check whether the given class names are already taken by user application or Ruby on ::Rails.

#extract_last_module

Takes in an array of nested modules and extracts the last module.

#indent,
#module_namespacing

Wrap block with namespace of current application if namespace exists and is not skipped.

#namespace, #namespace_dirs, #namespaced_path, #wrap_with_namespace

Actions - Included

#add_source

Add the given source to Gemfile

#application
#environment

Adds configuration code to a Rails runtime environment.

#gem

Adds a gem declaration to the Gemfile for the specified gem.

#gem_group

Wraps gem entries inside a group.

#generate

Runs another generator.

#git

Runs one or more git commands.

#github,
#initializer

Creates an initializer file in config/initializers/.

#lib

Creates a file in lib/.

#rails_command

Runs the specified Rails command.

#rake

Runs the specified Rake task.

#rakefile

Creates a Rake tasks file in lib/tasks/.

#readme

Reads the given file at the source root and prints it in the console.

#route

Make an entry in Rails routing file config/routes.rb.

#vendor

Creates a file in vendor/.

#append_file_with_newline

Append string to a file with a newline if necessary.

#execute_command

Runs the supplied command using either rake or rails based on the executor parameter provided.

#indentation

Returns a string corresponding to the current indentation level (i.e. 2 * @indentation spaces).

#log

Define log for backwards compatibility.

#match_file,
#optimize_indentation

Returns optimized string with indentation.

#quote

Always returns value in double quotes.

#rebase_indentation
#route_namespace_pattern,
#with_indentation

Increases the current indentation indentation level for the duration of the given block, and decreases it after the block ends.

#initialize

Instance Method Details

#add_master_key_file

[ GitHub ]

  
# File 'railties/lib/rails/generators/rails/master_key/master_key_generator.rb', line 13

def add_master_key_file
  unless MASTER_KEY_PATH.exist?
    key = ActiveSupport::EncryptedFile.generate_key

    log "Adding #{MASTER_KEY_PATH} to store the master encryption key: #{key}"
    log ""
    log "Save this in a password manager your team can access."
    log ""
    log "If you lose the key, no one, including you, can access anything encrypted with it."

    log ""
    add_master_key_file_silently(key)
    log ""
  end
end

#add_master_key_file_silently(key = nil)

[ GitHub ]

  
# File 'railties/lib/rails/generators/rails/master_key/master_key_generator.rb', line 29

def add_master_key_file_silently(key = nil)
  unless MASTER_KEY_PATH.exist?
    key_file_generator.add_key_file_silently(MASTER_KEY_PATH, key)
  end
end

#ignore_master_key_file

[ GitHub ]

  
# File 'railties/lib/rails/generators/rails/master_key/master_key_generator.rb', line 35

def ignore_master_key_file
  key_file_generator.ignore_key_file(MASTER_KEY_PATH, ignore: key_ignore)
end

#ignore_master_key_file_silently

[ GitHub ]

  
# File 'railties/lib/rails/generators/rails/master_key/master_key_generator.rb', line 39

def ignore_master_key_file_silently
  key_file_generator.ignore_key_file_silently(MASTER_KEY_PATH, ignore: key_ignore)
end

#key_file_generator (private)

[ GitHub ]

  
# File 'railties/lib/rails/generators/rails/master_key/master_key_generator.rb', line 44

def key_file_generator
  EncryptionKeyFileGenerator.new([], options)
end

#key_ignore (private)

[ GitHub ]

  
# File 'railties/lib/rails/generators/rails/master_key/master_key_generator.rb', line 48

def key_ignore
  [ "", "# Ignore master key for decrypting credentials and more.", "/#{MASTER_KEY_PATH}", "" ].join("\n")
end