class ActionCable::Server::Configuration

Parent:
Object

An instance of this configuration object is available via ActionCable.server.config, which allows you to tweak Action Cable configuration in a Rails config initializer.

Attributes

allow_same_origin_as_host[RW]
allowed_request_origins[RW]
cable[RW]
connection_class[RW]
disable_request_forgery_protection[RW]
log_tags[RW]
logger[RW]
mount_path[RW]
url[RW]
worker_pool_size[RW]

Public Class Methods

new() Show source
# File actioncable/lib/action_cable/server/configuration.rb, line 11
def initialize
  @log_tags = []

  @connection_class = -> { ActionCable::Connection::Base }
  @worker_pool_size = 4

  @disable_request_forgery_protection = false
  @allow_same_origin_as_host = true
end

Public Instance Methods

pubsub_adapter() Show source
# File actioncable/lib/action_cable/server/configuration.rb, line 24
def pubsub_adapter
  adapter = (cable.fetch("adapter") { "redis" })
  path_to_adapter = "action_cable/subscription_adapter/#{adapter}"
  begin
    require path_to_adapter
  rescue Gem::LoadError => e
    raise Gem::LoadError, "Specified '#{adapter}' for Action Cable pubsub adapter, but the gem is not loaded. Add `gem '#{e.name}'` to your Gemfile (and ensure its version is at the minimum required by Action Cable)."
  rescue LoadError => e
    raise LoadError, "Could not load '#{path_to_adapter}'. Make sure that the adapter in config/cable.yml is valid. If you use an adapter other than 'postgresql' or 'redis' add the necessary adapter gem to the Gemfile.", e.backtrace
  end

  adapter = adapter.camelize
  adapter = "PostgreSQL" if adapter == "Postgresql"
  "ActionCable::SubscriptionAdapter::#{adapter}".constantize
end

Returns constant of subscription adapter specified in config/cable.yml. If the adapter cannot be found, this will default to the Redis adapter. Also makes sure proper dependencies are required.

© 2004–2018 David Heinemeier Hansson
Licensed under the MIT License.