ruby-on-rails - 如何创建特定于 Rails 的 Rubygem?

标签 ruby-on-rails ruby rubygems html-safe

我们正在构建一个聊天服务,人们可以在他们的代码中使用该服务。

在我们正在构建的工具中,我们制作了一个 Ruby gem,让人们可以快速将聊天窗口添加到他们的 Ruby 网络应用程序中。

不过,我们想创建一个特定于 Rails 的包装器,因为目前用户必须手动调用 .html_safe

如何在 Ruby gem 中使用这些特定于 Rails 的功能?我听说这可能被称为“Railsties”,但我无法找到关于这些以及如何使用它们的任何综合文档。

具体来说,我们希望:

  • 在某些字符串输出上调用 html_safe,这样用户就不必手动执行此操作。
  • 将一些配置设置放在 config/initializers/some_name.rb 中的文件中,而不必内联指定这些设置。
  • 可能会创建一个生成器,用户可以运行该生成器来自动填充此初始化程序。

我们如何使用这些功能?我们是否可以在我们的 gem 中包含一些其他的 gem 依赖项来访问这些功能?

最佳答案

Engines can be considered miniature applications that provide functionality to their host applications. A Rails application is actually just a "supercharged" engine, with the Rails::Application class inheriting a lot of its behavior from Rails::Engine.
https://guides.rubyonrails.org/engines.html

引擎可以包含模型、 Controller 、路由、生成器、中间件以及您可以在主机应用程序中安装的任意代码。引擎通常打包为 gem 。

例如,Devise 是一个提供授权的 Rails 引擎。

Rails 有一个用于创建引擎的生成器命令:

rails plugin new chatty --mountable

对于这个例子,我们称之为闲聊。

由于引擎安装在 Rails 应用程序中,您可以完全访问 Rails 堆栈(例如 .html_safe)。这也意味着您可以通过将引擎安装在虚拟应用程序中来测试引擎。

如果您已将应用程序打包为 gem,则只需将其添加到 Gemfile 即可将其安装到主机应用程序中。

要使您的引擎可配置,您可以遵循 "MyGem.configure pattern" :

# lib/chatty.rb
module Chatty
  class << self
    attr_accessor :configuration
  end

  def self.configure
    self.configuration ||= Configuration.new
    yield(configuration)
  end

  class Configuration
    attr_accessor :foo

    def initialize
      @foo = 'some_value'
    end
  end
end

要创建用户配置文件,您可以使用 generator :

# lib/generators/chatty/install/install_generator.rb
module Chatty
  class InstallGenerator < Rails::Generators::Base
    source_root File.expand_path('templates', __dir__)

    desc "Creates a Chatty initializer."

    def copy_initializer
      template 'chatty.rb', 'config/initializers/chatty.rb'
    end
  end
end

还有一个代码模板:

# /lib/generators/chatty/install/templates/chatty.rb
Chatty.configure do |config|
  config.foo = "bar"
end

您现在可以运行 rails g chatty:install,它将在主机应用程序中创建文件。

关于ruby-on-rails - 如何创建特定于 Rails 的 Rubygem?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52974425/

相关文章:

Growl 的 Ruby gem

rubygems - 由于规范中的日期格式,gemspec 无效

ruby-on-rails - Rails 返回 JSON 序列化属性 with_indifferent_access

ruby-on-rails - Rails cron 与无论何时

ruby-on-rails - Rails - 如何获取 Assets 的文件路径(不是 url 路径)?

mysql - 在另一个范围内重用多个范围以在 Rails 中创建搜索多个字段

mysql - 将 Ruby on Rails 连接到现有 MySQL 数据库(之前安装了 XAMPP)

ruby-on-rails - ActionMailer 渲染一次,发送多次?

javascript - 在 Ruby on Rails 中加载 CSS 和 JS 文件

ruby - ruby 在线快速计算环境