377 lines
19 KiB
Ruby
377 lines
19 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", "JamRuby::QuickMixObserver", "JamRuby::RecordedBackingTrackObserver"
|
|
|
|
# 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"
|
|
config.assets.paths << Rails.root.join('vendor', 'assets', 'bower_components')
|
|
|
|
# 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 = true
|
|
# created using seth@jamkazam.com; can't see way to delegate
|
|
config.recaptcha_public_key = '6Let8dgSAAAAAFheKGWrs6iaq_hIlPOZ2f3Bb56B'
|
|
config.recaptcha_private_key = '6Let8dgSAAAAAJzFxL9w2QR5auxjk0ol1_xAtOGO'
|
|
|
|
|
|
# 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 = 80
|
|
config.websocket_gateway_connect_time_expire_client = 120
|
|
config.websocket_gateway_connect_time_stale_browser = 80
|
|
config.websocket_gateway_connect_time_expire_browser = 120
|
|
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
|
|
config.websocket_gateway_port_ssl = 6443 + 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.websocket_gateway_uri_ssl = "wss://localhost:#{config.websocket_gateway_port_ssl}/websocket"
|
|
config.websocket_gateway_trusted_uri_ssl = "wss://localhost:#{config.websocket_gateway_port_ssl + 1}/websocket"
|
|
config.force_ssl = ENV['FORCE_SSL'].nil? ? false : ENV['FORCE_SSL'] == 'true'
|
|
config.websocket_gateway_max_connections_per_user = 20
|
|
config.lock_connections = false
|
|
|
|
config.external_hostname = ENV['EXTERNAL_HOSTNAME'] || 'localhost'
|
|
config.external_port = ENV['EXTERNAL_PORT'] || 3000
|
|
config.external_protocol = ENV['EXTERNAL_PROTOCOL'] || 'http://'
|
|
config.external_port_ssl = ENV['EXTERNAL_PORT_ssl'] || 3443
|
|
config.external_root_url = "#{config.external_protocol}#{config.external_hostname}#{(config.external_port == 80 || config.external_port == 443) ? '' : ':' + config.external_port.to_s}"
|
|
config.admin_port = ENV['ADMIN_PORT'] || 3333
|
|
config.admin_root_url = "#{config.external_protocol}#{config.external_hostname}#{(config.admin_port == 80 || config.admin_port == 443) ? '' : ':' + config.admin_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"
|
|
config.aws_bucket_jamtracks = 'jamkazam-jamtracks'
|
|
|
|
# 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'
|
|
config.google_email = '785931784279-gd0g8on6sc0tuesj7cu763pitaiv2la8@developer.gserviceaccount.com'
|
|
config.google_public_server_key = "AIzaSyCPTPq5PEcl4XWcm7NZ2IGClZlbsiE8JNo"
|
|
|
|
# Use Private API Keys to communicate with Recurly's API v2. See https://docs.recurly.com/api/basics/authentication to learn more.
|
|
config.recurly_private_api_key = '7d623daabfc2434fa2a893bb008eb3e6'
|
|
# Use Public Keys to identify your site when using Recurly.js. See https://docs.recurly.com/js/#include to learn more.
|
|
config.recurly_public_api_key = 'sjc-SZlO11shkeA1WMGuISLGg5'
|
|
|
|
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
|
|
|
|
config.desk_multipass_key = "453ddfc0bab00130a9c13bc9a68cf24c" # found in https://jamkazam.desk.com/admin/channels/support-center/auth_settings
|
|
config.desk_multipass_site = "jamkazam" # found in https://jamkazam.desk.com/admin/channels/support-center/auth_settings
|
|
|
|
# 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.recurly_webhook_user = 'monkeytoesspeartoss'
|
|
config.recurly_webhook_pass = 'frizzyfloppymushface'
|
|
|
|
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')
|
|
config.normalize_ogg_path = ENV['NORMALIZE_OGG_PATH'] || (File.exist?('/usr/local/bin/normalize-ogg') ? '/usr/local/bin/normalize-ogg' : '/usr/bin/normalize-ogg')
|
|
config.normalize_mp3_path = ENV['NORMALIZE_MP3_PATH'] || (File.exist?('/usr/local/bin/normalize-mp3') ? '/usr/local/bin/normalize-mp3' : '/usr/bin/normalize-mp3')
|
|
|
|
# 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 = 10 # 10 seconds
|
|
config.icecast_hardcoded_source_password = nil # generate a new password everytim. production should always use this value
|
|
config.icecast_wait_after_reload = 0 # 0 seconds. a hack needed until VRFS-1043... maybe
|
|
config.source_changes_missing_secs = 2 # amount of time before we think it's odd that there are no source_change notifications
|
|
|
|
# Location of jamtracks python tool:
|
|
config.jamtracks_dir = ENV['JAMTRACKS_DIR'] || File.expand_path(File.join(File.dirname(__FILE__), "..", "..", "..", "jamtracks"))
|
|
config.jmep_dir = ENV['JMEP_DIR'] || File.expand_path(File.join(File.dirname(__FILE__), "..", "..", "..", "jmep"))
|
|
|
|
# amount of time before we think the queue is stuck
|
|
config.signing_job_queue_max_time = 20 # 20 seconds
|
|
# amount of time to allow before giving up on a single step in packaging job
|
|
config.signing_step_max_time = 60; # 60 seconds
|
|
|
|
config.signing_job_signing_max_time = 300
|
|
# amount of time before we think the queue is stuck
|
|
config.signing_job_queue_max_time = 300
|
|
# amount of time to allow before giving up on a single step in packaging job
|
|
config.mixdown_step_max_time = 300
|
|
config.mixdown_job_queue_max_time = 300
|
|
|
|
config.estimated_jam_track_time = 40
|
|
config.estimated_fast_mixdown_time = 30
|
|
config.estimated_slow_mixdown_time = 80
|
|
config.num_packaging_nodes = 2
|
|
|
|
config.email_social_alias = 'social@jamkazam.com'
|
|
config.email_alerts_alias = 'alerts@jamkazam.com' # should be used for 'oh no' server down/service down sorts of emails
|
|
config.email_generic_from = 'nobody@jamkazam.com'
|
|
config.email_recurly_notice = 'recurly-alerts@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 = 'snorkeltoesniffyfarce1'
|
|
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.twitter_public_account = 'jamkazam'
|
|
|
|
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'
|
|
config.vanilla_staff_postfix = '(JamKazam Staff)'
|
|
|
|
# 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
|
|
# packet size (bytes) of audio-only test
|
|
config.ftue_network_test_packet_size = 60
|
|
# packet size (bytes) of audio + video test
|
|
config.ftue_network_test_packet_size_video = 500
|
|
|
|
# number of times that the backend retries before giving up
|
|
config.ftue_network_test_backend_retries = 3
|
|
# amount of time that we want passed until we run the next network test
|
|
config.ftue_network_test_min_wait_since_last_score = 5
|
|
# the maximum amount of allowable latency
|
|
config.ftue_maximum_gear_latency = 20
|
|
|
|
config.max_mind_working_dir = 'tmp'
|
|
|
|
# recording upload/download configs
|
|
config.max_track_upload_failures = 10
|
|
config.max_track_part_upload_failures = 3
|
|
|
|
# scoring thresholds for 'full score', which is your gear + their gear + and ping time
|
|
config.max_good_full_score = 40
|
|
config.max_yellow_full_score = 70
|
|
config.max_red_full_score = 100
|
|
|
|
# getWork tweak parameters
|
|
config.getwork_result_size = 100 # how many results can we return back in getWork API?
|
|
config.staleness_hours = 24 * 5 # how old in hours does a score have to be before we ask for a new one?
|
|
config.scoring_timeout_minutes = 30 # how long to put a client in the doghouse if it keeps making bad scores
|
|
config.scoring_timeout_threshold = 5 # how many consequetive bad scores before you are put into the doghouse
|
|
config.scoring_get_work_interval = 1000 # how much time between normal getwork requests
|
|
config.scoring_get_work_backoff_interval = 60 * 1000 # how much time between failed getwork requests
|
|
|
|
config.recordings_stale_time = 3 # num days of inactivity before we decide that a recording is no longer going to be claimed
|
|
|
|
config.jam_tracks_available = true
|
|
config.purchases_enabled = true
|
|
|
|
# these values work out of the box with default settings of an influx install (you do have to add a development database by hand though)
|
|
config.influxdb_database = 'development'
|
|
config.influxdb_username = "root"
|
|
config.influxdb_password = "root"
|
|
config.influxdb_unsafe_username = "root" # these are exposed to JavaScript
|
|
config.influxdb_unsafe_password = "root" # these are exposed to JavaScript
|
|
config.influxdb_hosts = ["localhost"]
|
|
config.influxdb_port = 8086
|
|
config.influxdb_ignored_environments = ENV["INFLUXDB_ENABLED"] == '1' ? ['test', 'cucumber'] : ['test', 'cucumber', 'development']
|
|
|
|
config.allow_spikes = false
|
|
config.show_jamblaster_kickstarter_link = true
|
|
config.metronome_available = true
|
|
config.backing_tracks_available = true
|
|
config.one_free_jamtrack_per_user = true
|
|
|
|
config.nominated_jam_track = 'jamtrack-pearljam-alive'
|
|
config.recurly_tax_estimate_jam_track_plan = 'jamtrack-acdc-backinblack'
|
|
|
|
config.minimal_curtain = false
|
|
config.video_available = "full"
|
|
config.alerts_api_enabled = true
|
|
|
|
config.gear_check_ignore_high_latency = false
|
|
config.remove_whitespace_credit_card = false
|
|
config.estimate_taxes = true
|
|
config.ad_sense_enabled = false
|
|
config.guard_against_fraud = true
|
|
config.error_on_fraud = false
|
|
config.expire_fingerprint_days = 14
|
|
config.found_conflict_count = 1
|
|
config.web_performance_timing_enabled = true
|
|
config.jamtrack_landing_bubbles_enabled = true
|
|
config.jamtrack_browser_bubbles_enabled = true
|
|
|
|
config.react.variant = :production
|
|
config.react.addons = true
|
|
|
|
config.time_shift_style = :sbsms # or sox
|
|
|
|
config.middleware.use Rack::Deflater
|
|
end
|
|
end
|