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 ) config.assets.precompile += %w( minimal/minimal.js minimal/minimal.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 config.websocket_gateway_connect_time_stale_client = 40 # 40 matches production config.websocket_gateway_connect_time_expire_client = 60 # 60 matches production config.websocket_gateway_connect_time_stale_browser = 40 # 40 matches production config.websocket_gateway_connect_time_expire_browser = 60 # 60 matches production config.websocket_gateway_cidr = ['0.0.0.0/0'] 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.websocket_gateway_trusted_uri = "ws://localhost:#{config.websocket_gateway_port + 1}/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 config.autocheck_create_session_agreement = false config.max_audio_downloads = 100 config.send_join_session_email_notifications = true config.use_promos_on_homepage = false # should we use the new FindSessions API that has server-side scores config.use_cached_session_scores = true config.allow_both_find_algos = false config.session_cookie_domain = nil # these are production values. we should have a test server, but would require us to set one up # we do have some 'fake pages' in the vanilla_forums_controller.rb to get close config.vanilla_client_id = 'www' config.vanilla_secret = 'bibbitybobbityslipperyslopes' config.vanilla_url = 'http://forums.jamkazam.com' config.vanilla_login_url = 'http://forums.jamkazam.com/entry/jsconnect' # we have to do this for a while until all www.jamkazam.com cookies are gone, # and only .jamkazam.com cookies are around.. 2016? config.middleware.insert_before "ActionDispatch::Cookies", "Middlewares::ClearDuplicatedSession" # how long should the frontend wait for the IO to stabilize before asking for a IO score? config.ftue_io_wait_time = 10 # what should the threshold be for us to say, 'this person can't play at this rate' during the network test config.ftue_packet_rate_treshold = 0.95 # how long to test at each network test step config.ftue_network_test_duration = 10 # max number of people to test config.ftue_network_test_max_clients = 8 # the maximum amount of allowable latency config.ftue_maximum_gear_latency = 20 config.max_mind_working_dir = 'tmp' end end