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) # 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 ] config.eager_load = false # 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)' #config.default_timezone = :local # 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 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 ) config.assets.precompile += %w( modern/modern.js modern/modern.css ) config.assets.precompile += %w( basic/basic.js basic/basic.css ) config.assets.precompile += %w( events/events.js events/events.scss ) config.assets.precompile += %w( support/support.js support/support.scss ) config.assets.precompile += %w( jk2021/jk2021.js jk2021/jk2021.css ) config.assets.precompile += %w( modern/scripts.js ) # where is rabbitmq? config.rabbitmq_host = "127.0.0.1" 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' config.active_record.raise_in_transactional_callbacks = true # 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.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.websocket_gateway_uri = "ws://#{config.external_hostname}:#{config.websocket_gateway_port}/websocket" config.websocket_gateway_trusted_uri = "ws://#{config.external_hostname}:#{config.websocket_gateway_port + 1}/websocket" config.websocket_gateway_uri_ssl = "wss://#{config.external_hostname}:#{config.websocket_gateway_port_ssl}/websocket" config.websocket_gateway_trusted_uri_ssl = "wss://#{config.external_hostname}:#{config.websocket_gateway_port_ssl + 1}/websocket" 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_analytics_bucket = 'jamkazam-analytics-dev' 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" # Facebook Conversions API config.facebook_ad_source = Set.new(['facebook', 'instagram', 'meta', 'meta_ads', 'fb', 'ig', 'th', 'threads']) config.facebook_pixel_id = "25663975269956141" # ONLY ONE. NO MULTI ENV config.facebook_access_token = "EABAGQTtcGk4BQewKCztlfImT86ZAPsRAm3KDrYWsOFZAdLtJCa7bVOzdnZCnHZBFZBRMFVoSZCQdIpX01xXDM0ZCFmYrkPuAHdLsNBU61c7MZCZBLCFd3Q0qrxiJkeYr3F8FH3p98d0tGKljplhJ8vWBIKAiBXaUCCYk6urZB5qZAIEPsppWZCHOep91xZCtMVqtbGJQfFAZDZD" # ONLY ONE. NO MULTI ENV config.facebook_conversion_api_tls = true # 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 = '55f2fdfa4d014e64a94eaba1e93f39bb' # 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 = 'ewr1-HciusxMNfSSjz5WlupGk0C' config.stripe_charge_token = '#XXX#' 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 # user_assets configs config.user_asset_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 = "fa0e229f687bcb2c8711fcb80223744e" 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.bugs_alias = 'bugs@jamkazam.com' config.email_support_alias = 'support@jamkazam.com' config.email_partners_alias = 'partners@jamkazam.com' config.email_social_alias = 'social@jamkazam.com' config.email_crashes_alias = 'clientcrash@jamkazam.com' config.email_alerts_alias = 'alerts@jamkazam.com' # should be used for 'oh no' server down/service down sorts of emails config.email_jamclass_alerts_alias= 'jamclass-alerts@jamkazam.com' config.email_generic_from = 'nobody@jamkazam.com' config.email_recurly_notice = 'recurly-alerts@jamkazam.com' config.email_smtp_address = 'email-smtp.us-east-1.amazonaws.com' config.email_smtp_port = 587 config.email_smtp_domain = 'www.jamkazam.com' config.email_smtp_authentication = :plain config.email_smtp_user_name = 'AKIA2SXEHOQFKRW3OWMG' # ses-smtp-user.20200526-212148 config.email_smtp_password = 'BJZEdTkTcuIrN1koG40PQ2JLHdMmTprC/aLj48Q5KhWJ' config.email_smtp_starttls_auto = true config.sendgrid_username = 'jamkazam' config.sendgrid_password = 'snorkeltoesniffyfarce1' 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 config.session_cookie_domain = ".jamkazam.local" config.elasticsearch_host = "http://support.jamkazam.com:9200" # 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" config.network_test_required = false # how long should the frontend wait for the IO to stabilize before asking for a IO score? config.ftue_io_wait_time = 5 # 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 = 4 # 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.influxdb_ignored_environments = ['test', 'cucumber', 'development', 'production'] 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.show_recording_debug_status = false 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.guard_against_browser_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 # spam for invited users config.max_invites_ever_per_sender = 70 config.max_invites_per_day_per_sender = 20 config.max_invites_to_receiver_per_day = 1 config.react.variant = :production config.react.addons = true config.time_shift_style = :sbsms # or sox config.middleware.use Rack::Deflater config.download_tracker_day_range = 90 config.max_user_ip_address = 10 config.max_multiple_users_same_ip = 2 config.session_stat_thresholds = { network: { wifi: {warn: true, poor: true, eql: true}, net_bitrate: {warn: 210, poor: 155, inverse:true}, audio_bitrate_tx:{warn: 128, poor: 96, inverse:true}, audio_bitrate_rx:{warn: 128, poor: 96, inverse:true}, video_rtpbw_tx: {warn: 600.1, poor: 400.1, inverse: true, zero_is_good: true}, video_rtpbw_rx: {warn: 600.1, poor: 400.1, inverse: true, zero_is_good: true}, ping: {warn: 30.1, poor: 50.1}, pkt_loss: {warn: 2.1, poor: 5.1}, audiojq_median: {warn: 4.1, poor: 6.1}, jitter_var: {warn: 2.1, poor: 4.1} }, system: { cpu: {warn: 60.1, poor:80.1} }, audio: { audio_in_type: {warn: 'Windows WDM-KS', poor: nil, eql:true}, audio_out_type: {warn: 'Windows WDM-KS', poor: nil, eql:true}, framesize: {warn: 2.6, poor: 2.6}, latency: {warn: 10, poor: 20}, input_jitter: {warn: 0.51, poor: 1.01}, output_jitter: {warn: 0.51, poor: 1.01}, }, aggregate: { latency: {warn: 20.1, poor: 35.1} } } config.vst_enabled = true config.midi_enabled = true config.targeted_feed_disabled = false config.verify_email_enabled = false config.kickbox_api_key = 'e262991e292dd5fe382c4a69f2b359f718cf267712b8684c9c28d6402ec18965' config.check_bounced_emails = false config.ban_jamtrack_downloaders = true config.chat_opened_by_default = false config.chat_blast = true config.use_ios_sandbox = true config.stripe = { :publishable_key => 'pk_test_9vO8ZnxBpb9Udb0paruV3qLv', :secret_key => 'sk_test_cPVRbtr9xbMiqffV8jwibwLA', :source_customer => 'cus_8J2sI8iOHFEl2u', :client_id => 'ca_8CgkjoHvfRMVqoQkcKdPt5Riy3dSPIlg', :ach_pct => 0.008, :charge_fee => 0.03 } config.test_drive_wait_period_year = 1 config.minimum_lesson_booking_hrs = 24 config.wait_time_window_pct = 0.75 config.lesson_together_threshold_minutes = 5 config.lesson_join_time_window_minutes = 5 config.lesson_wait_time_window_minutes = 10 config.end_of_wait_window_forgiveness_minutes = 1 config.olark_enabled = false config.jamclass_enabled = false config.musician_count = '200,000+' config.jamblaster_menu = false # Applications created before Rails 4.1 uses Marshal to serialize cookie values into the signed and encrypted cookie jars. # If you want to use the new JSON-based format in your application, you can add an initializer file with the following content: # This would transparently migrate your existing Marshal-serialized cookies into the new JSON-based format. config.action_dispatch.cookies_serializer = :hybrid config.jam_class_card_wait_period_year = 1 config.paypal_mode = 'sandbox' #sandbox or live #config.app_id = 'APP-80W284485P519543T' # this is constant across all sandbox accts config.paypal_username = 'seth+ppmerchant_api1.jamkazam.com' # seth+ppmerchant@jamkazam.com' # 'seth+ppmerchant_api1.jamkazam.com' config.paypal_password = 'UXDKMPLYNE5YRLMK' config.paypal_signature = 'AFcWxV21C7fd0v3bYYYRCpSSRl31AmvhBjN40M8etif4EA.L8EyMxdsu' config.paypal_debug = true config.paypal_express_url = 'https://www.sandbox.paypal.com/cgi-bin/webscr?cmd=_express-checkout' # drop sandbox for production config.paypal_admin_only = true config.rating_dialog_min_time = 60 config.rating_dialog_min_num = 1 config.gcp_stats_host = "https://us-central1-tough-craft-276813.cloudfunctions.net" config.root_redirect_on = true config.root_redirect_subdomain = '' config.root_redirect_path = '/' config.subscription_codes = [ {id: nil, name: 'Free', price: 0.00, cycle: 'month'}, {id: 'jamsubsilver', name: 'Silver', price: 4.99, cycle: 'month'}, {id: 'jamsubgold', name: 'Gold', price:9.99, cycle: 'month'}, {id: 'jamsubplatinum', name: 'Platinum', price:19.99, cycle: 'month'}, {id: 'jamsubsilveryearly', name: 'Silver', price: 49.99, cycle: 'year'}, {id: 'jamsubgoldyearly', name: 'Gold', price:99.99, cycle: 'year'}, {id: 'jamsubplatinumyearly', name: 'Platinum', price:199.99, cycle: 'year'}] # sandbox # braintree: merchant id: 5v5rwm94m2vrfbms # braintree: public key: 367d6dtdswvdr87s # braintree: private key: 8309b8f9c669cfa940f617eb9cac56ea config.braintree_token = 'sandbox_pgjp8dvs_5v5rwm94m2vrfbms' config.paypal_admin_only = false config.video_conferencing_host = "http://localhost:3001" config.video_open_room = "openroom12345" config.latency_data_host = "http://localhost:4001" config.latency_data_host_auth_code = "c2VydmVyOnBhc3N3b3Jk" config.manual_override_installer_ends_with = "JamKazam-1.0.3776.dmg" config.spa_origin = "http://beta.jamkazam.local:3000" end end