212 lines
9.8 KiB
Ruby
212 lines
9.8 KiB
Ruby
require File.expand_path('../boot', __FILE__)
|
|
|
|
# Pick the frameworks you want:
|
|
require "active_record/railtie"
|
|
require "action_controller/railtie"
|
|
require "action_mailer/railtie"
|
|
require "active_resource/railtie"
|
|
require "sprockets/railtie"
|
|
require 'shellwords'
|
|
|
|
|
|
|
|
# initialize ActiveRecord's db connection
|
|
# why? Because user.rb uses validates :acceptance, which needs a connection to the database. if there is better way...
|
|
ActiveRecord::Base.establish_connection(YAML::load(File.open('config/database.yml'))[Rails.env])
|
|
|
|
if defined?(Bundler)
|
|
# If you precompile assets before deploying to production, use this line
|
|
Bundler.require(*Rails.groups(:assets => %w(development test)))
|
|
# If you want your assets lazily compiled in production, use this line
|
|
# Bundler.require(:default, :assets, Rails.env)
|
|
end
|
|
|
|
include JamRuby
|
|
# require "rails/test_unit/railtie"
|
|
|
|
module SampleApp
|
|
class Application < Rails::Application
|
|
# Settings in config/environments/* take precedence over those specified here.
|
|
# Application configuration should go into files in config/initializers
|
|
# -- all .rb files in that directory are automatically loaded.
|
|
|
|
# Custom directories with classes and modules you want to be autoloadable.
|
|
config.autoload_paths += %W(#{config.root}/lib)
|
|
|
|
# Only load the plugins named here, in the order given (default is alphabetical).
|
|
# :all can be used as a placeholder for all plugins not explicitly named.
|
|
# config.plugins = [ :exception_notification, :ssl_requirement, :all ]
|
|
|
|
# Activate observers that should always be running.
|
|
# config.active_record.observers = :cacher, :garbage_collector, :forum_observer
|
|
config.active_record.observers = "JamRuby::InvitedUserObserver", "JamRuby::UserObserver", "JamRuby::FeedbackObserver", "JamRuby::RecordedTrackObserver"
|
|
|
|
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
|
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
|
# config.time_zone = 'Central Time (US & Canada)'
|
|
|
|
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
|
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
|
# config.i18n.default_locale = :de
|
|
|
|
# Configure the default encoding used in templates for Ruby 1.9.
|
|
config.encoding = "utf-8"
|
|
|
|
# Configure sensitive parameters which will be filtered from the log file.
|
|
config.filter_parameters += [:password]
|
|
|
|
# Use SQL instead of Active Record's schema dumper when creating the database.
|
|
# This is necessary if your schema can't be completely dumped by the schema dumper,
|
|
# like if you have constraints or database-specific column types
|
|
# config.active_record.schema_format = :sql
|
|
|
|
# Enforce whitelist mode for mass assignment.
|
|
# This will create an empty whitelist of attributes available for mass-assignment for all models
|
|
# in your app. As such, your models will need to explicitly whitelist or blacklist accessible
|
|
# parameters by using an attr_accessible or attr_protected declaration.
|
|
config.active_record.whitelist_attributes = true
|
|
|
|
# Enable the asset pipeline
|
|
config.assets.enabled = true
|
|
|
|
# Version of your assets, change this if you want to expire all your assets
|
|
config.assets.version = '1.0'
|
|
|
|
# suppress locale complaint: http://stackoverflow.com/questions/20361428/rails-i18n-validation-deprecation-warning
|
|
config.i18n.enforce_available_locales = false
|
|
|
|
# Add the assets/fonts directory to assets.paths
|
|
config.assets.paths << "#{Rails.root}/app/assets/fonts"
|
|
|
|
# Precompile additional assets (application.js, application.css, and all non-JS/CSS (i.e., images) are already added)
|
|
config.assets.precompile += %w( client/client.css )
|
|
config.assets.precompile += %w( landing/landing.js landing/landing.css )
|
|
config.assets.precompile += %w( corp/corporate.js corp/corporate.css )
|
|
config.assets.precompile += %w( web/web.js web/web.css )
|
|
|
|
|
|
# where is rabbitmq?
|
|
config.rabbitmq_host = "localhost"
|
|
config.rabbitmq_port = 5672
|
|
|
|
# filepicker app configured to use S3 bucket jamkazam-dev
|
|
config.filepicker_rails.api_key = "Asx4wh6GSlmpAAzoM0Cunz"
|
|
config.filepicker_upload_dir = 'avatars'
|
|
config.fp_secret = 'FTDL4TYDENBWZKK3UZCFIQWXS4'
|
|
|
|
config.recaptcha_enable = false
|
|
|
|
# create one user per real jamkazam employee?
|
|
config.bootstrap_dev_users = true
|
|
|
|
# websocket-gateway configs
|
|
|
|
# Websocket-gateway embedded configs
|
|
config.websocket_gateway_enable = false
|
|
if Rails.env=='test'
|
|
config.websocket_gateway_connect_time_stale = 2
|
|
config.websocket_gateway_connect_time_expire = 5
|
|
else
|
|
config.websocket_gateway_connect_time_stale = 300
|
|
config.websocket_gateway_connect_time_expire = 6000
|
|
end
|
|
config.websocket_gateway_internal_debug = false
|
|
config.websocket_gateway_port = 6767 + ENV['JAM_INSTANCE'].to_i
|
|
# Runs the websocket gateway within the web app
|
|
config.websocket_gateway_uri = "ws://localhost:#{config.websocket_gateway_port}/websocket"
|
|
|
|
config.external_hostname = ENV['EXTERNAL_HOSTNAME'] || 'localhost'
|
|
config.external_port = ENV['EXTERNAL_PORT'] || 3000
|
|
config.external_protocol = ENV['EXTERNAL_PROTOCOL'] || 'http://'
|
|
config.external_root_url = "#{config.external_protocol}#{config.external_hostname}#{(config.external_port == 80 || config.external_port == 443) ? '' : ':' + config.external_port.to_s}"
|
|
|
|
# set this to false if you want to disable signups (lock down public user creation)
|
|
config.signup_enabled = true
|
|
|
|
config.storage_type = :fog
|
|
# config.storage_type = :file # or :fog, if using AWS
|
|
|
|
# these only used if storage_type = :fog
|
|
config.aws_access_key_id = ENV['AWS_KEY']
|
|
config.aws_secret_access_key = ENV['AWS_SECRET']
|
|
config.aws_region = 'us-east-1'
|
|
config.aws_bucket = 'jamkazam-dev'
|
|
config.aws_bucket_public = 'jamkazam-dev-public'
|
|
config.aws_cache = '315576000'
|
|
config.aws_fullhost = "#{config.aws_bucket_public}.s3.amazonaws.com"
|
|
|
|
# cloudfront host
|
|
config.cloudfront_host = "d34f55ppvvtgi3.cloudfront.net"
|
|
|
|
# google api keys
|
|
config.google_client_id = '785931784279-gd0g8on6sc0tuesj7cu763pitaiv2la8.apps.googleusercontent.com'
|
|
config.google_secret = 'UwzIcvtErv9c2-GIsNfIo7bA'
|
|
|
|
if Rails.env == 'production'
|
|
config.desk_url = 'https://jamkazam.desk.com'
|
|
config.multipass_callback_url = "http://jamkazam.desk.com/customer/authentication/multipass/callback"
|
|
else
|
|
config.desk_url = 'https://jamkazam.desk.com' # TODO: replace with test URL
|
|
config.multipass_callback_url = "http://jamkazam.desk.com/customer/authentication/multipass/callback"
|
|
end
|
|
|
|
# perf_data configs
|
|
config.perf_data_signed_url_timeout = 3600 * 24 # 1 day
|
|
|
|
# crash_dump configs
|
|
config.crash_dump_data_signed_url_timeout = 3600 * 24 # 1 day
|
|
|
|
# client update killswitch; turn on if client updates are broken and are affecting users
|
|
config.check_for_client_updates = true
|
|
|
|
# allow hot-key to switch between native and normal client
|
|
config.allow_force_native_client = true
|
|
|
|
config.bugsnag_key = "4289fc981c8ce3eb0969003c4f498b01"
|
|
config.bugsnag_notify_release_stages = ["production"] # add 'development' if you want to test a bugsnag feature locally
|
|
|
|
config.ga_ua = 'UA-44184562-2' # google analytics
|
|
config.ga_endpoint = 'www.google-analytics.com'
|
|
config.ga_ua_version = '1'
|
|
config.ga_anonymous_client_id = '555'
|
|
config.ga_suppress_admin = true
|
|
|
|
|
|
config.redis_host = "localhost:6379"
|
|
|
|
config.audiomixer_path = "/var/lib/audiomixer/audiomixer/audiomixerapp"
|
|
config.ffmpeg_path = ENV['FFMPEG_PATH'] || (File.exist?('/usr/local/bin/ffmpeg') ? '/usr/local/bin/ffmpeg' : '/usr/bin/ffmpeg')
|
|
|
|
# if it looks like linux, use init.d script; otherwise use kill
|
|
config.icecast_reload_cmd = ENV['ICECAST_RELOAD_CMD'] || (File.exist?('/usr/local/bin/icecast2') ? "bash -l -c #{Shellwords.escape("sudo /etc/init.d/icecast2 reload")}" : "bash -l -c #{Shellwords.escape("kill -1 `ps -f | grep /usr/local/bin/icecast | grep -v grep | awk \'{print $2}\'`")}")
|
|
# if it looks like linux, use that path; otherwise use the brew default path
|
|
config.icecast_config_file = ENV['ICECAST_CONFIG_FILE'] || (File.exist?('/etc/icecast2/icecast.xml') ? '/etc/icecast2/icecast.xml' : '/usr/local/etc/icecast.xml')
|
|
# this will be the qualifier on the IcecastConfigWorker queue name
|
|
config.icecast_server_id = ENV['ICECAST_SERVER_ID'] || 'localhost'
|
|
config.icecast_max_missing_check = 2 * 60 # 2 minutes
|
|
config.icecast_max_sourced_changed = 15 # 15 seconds
|
|
config.icecast_hardcoded_source_password = nil # generate a new password everytim. production should always use this value
|
|
config.icecast_wait_after_reload = 5 # 5 seconds. a hack needed until VRFS-1043
|
|
|
|
config.email_alerts_alias = 'nobody@jamkazam.com' # should be used for 'oh no' server down/service down sorts of emails
|
|
config.email_generic_from = 'nobody@jamkazam.com'
|
|
config.email_smtp_address = 'smtp.sendgrid.net'
|
|
config.email_smtp_port = 587
|
|
config.email_smtp_domain = 'www.jamkazam.com'
|
|
config.email_smtp_authentication = :plain
|
|
config.email_smtp_user_name = 'jamkazam'
|
|
config.email_smtp_password = 'jamjamblueberryjam'
|
|
config.email_smtp_starttls_auto = true
|
|
|
|
config.facebook_app_id = ENV['FACEBOOK_APP_ID'] || '468555793186398'
|
|
config.facebook_app_secret = ENV['FACEBOOK_APP_SECRET'] || '546a5b253972f3e2e8b36d9a3dd5a06e'
|
|
|
|
config.twitter_app_id = ENV['TWITTER_APP_ID'] || 'nQj2oEeoJZxECC33tiTuIg'
|
|
config.twitter_app_secret = ENV['TWITTER_APP_SECRET'] || 'Azcy3QqfzYzn2fsojFPYXcn72yfwa0vG6wWDrZ3KT8'
|
|
|
|
config.autocheck_create_session_agreement = false;
|
|
|
|
config.max_email_invites_per_request = 10
|
|
end
|
|
end
|