forked from odota/core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.ts
executable file
·99 lines (97 loc) · 6.8 KB
/
config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/**
* File managing configuration for the application
* */
import 'dotenv/config';
const defaults = {
STEAM_API_KEY: '', // for API reqs, in worker
STEAM_USER: '', // for getting replay salt/profile data, in retriever
STEAM_PASS: '', // for getting replay salt/profile data, in retriever
ROLE: '', // for specifying the file that should be run when entry point is invoked
GROUP: '', // for specifying the group of apps that should be run when entry point is invoked
START_SEQ_NUM: '', // truthy: use sequence number stored in redis, else: use approximate value from live API
PROVIDER: '', // The cloud provider used by the application (determines how environment data is downloaded)
STEAM_ACCOUNT_DATA: '', // The URL to read Steam account data from
NODE_ENV: 'development',
PORT: '', // Default port to use by services often set by the system
FRONTEND_PORT: '5000', // Port to run the webserver/API on
RETRIEVER_PORT: '5100', // Port to run the Steam GC retriever on
PROXY_PORT: '5300', // Port to run the Steam API proxy on
ROOT_URL: 'http://localhost:5000', // base url to redirect to after steam oauth login
RETRIEVER_HOST: 'localhost:5100', // Comma separated list of retriever hosts (access to Dota 2 GC data)
PARSER_HOST: 'localhost:5600', // host of the Java parse server
UI_HOST: '', // The host of the UI, target of /logout and /return
STEAM_API_HOST: 'api.steampowered.com', // comma separated list of hosts to fetch Steam API data from
POSTGRES_URL: 'postgresql://postgres:postgres@localhost/yasp', // connection string for PostgreSQL
READONLY_POSTGRES_URL: 'postgresql://readonly:readonly@localhost/yasp', // readonly connection string for PostgreSQL
REDIS_URL: 'redis://127.0.0.1:6379/0', // connection string for Redis
CASSANDRA_URL: 'cassandra://localhost/yasp', // connection string for Cassandra
SCYLLA_URL: 'scylla://localhost/yasp', // connection string for Scylla
ELASTICSEARCH_URL: 'localhost:9200',
RETRIEVER_SECRET: '', // string to use as shared secret with retriever/parser
SESSION_SECRET: 'secret to encrypt cookies with', // string to encrypt cookies
COOKIE_DOMAIN: '', // domain to use for the cookie. Use e.g. '.opendota.com' to share cookie across subdomains
UNTRACK_DAYS: '30', // The number of days a user is tracked for after every visit
MMR_PARALLELISM: '1', // Number of simultaneous MMR requests to make (per retriever)
PARSER_PARALLELISM: '1', // Number of simultaneous parse jobs to run (per parser)
FULLHISTORY_PARALLELISM: '1', // Number of simultaneous fullhistory (player refresh) jobs to process
GCDATA_PARALLELISM: '1', // Number of simultaneous GC match details requests to make (per retriever)
BENCHMARK_RETENTION_MINUTES: '60', // minutes in block to retain benchmark data for percentile
GCDATA_PERCENT: '0', // percent of inserted matches to randomly queue for GC data
SCANNER_PERCENT: '100', // percent of matches to insert from scanner
PUBLIC_SAMPLE_PERCENT: '10', // percent of public matches to sample in DB
SCENARIOS_SAMPLE_PERCENT: '100', // percent of parsed matches to sample for scenarios
BENCHMARKS_SAMPLE_PERCENT: '100', // percent of parsed matches to sample for benchmarks
ENABLE_MATCH_CACHE: '', // set to enable caching matches in Redis
ENABLE_PLAYER_CACHE: '', // enable/disable player aggregation caching
ENABLE_RANDOM_MMR_UPDATE: '', // set to request MMR updates after ranked matches
MAXIMUM_AGE_SCENARIOS_ROWS: '4', // maximum allowed age of scenarios rows in weeks
MATCH_CACHE_SECONDS: '60', // number of seconds to cache matches
PLAYER_CACHE_SECONDS: '86400', // number of seconds to cache player aggregations
// AUTO_PLAYER_CACHE_SECONDS: '86400', // number of seconds to auto cache player aggregations
ENABLE_API_LIMIT: '', // if truthy, API calls after exceeding API_FREE_LIMIT are blocked
API_FREE_LIMIT: '2000', // number of api requests per day before 429 is returned. If using an API key, calls over this are charged.
API_BILLING_UNIT: '100', // how many calls is equivalent to a unit of calls e.g. 100 calls per $0.01.
API_KEY_PER_MIN_LIMIT: '300', // Rate limit per minute if using an API key
NO_API_KEY_PER_MIN_LIMIT: '60', // Rate limit per minute if not using an API key
ADMIN_ACCOUNT_IDS: '', // Whitelisted, comma separated account IDs to access /admin* routes
STRIPE_SECRET: 'rk_test_gRqwhv4xqv0a1olp8kk8fZ94', // for stripe payment processing (kept on server)
STRIPE_API_PLAN: 'plan_CgLthOgwrDgz2K', // plan id for stripe metering
ENABLE_MATCH_ARCHIVE: '', // Allow reading/writing parsed match blobs to S3 storage
MATCH_ARCHIVE_S3_KEY_ID: '', // S3-compatible key ID to archive parsed match blobs
MATCH_ARCHIVE_S3_KEY_SECRET: '', // S3-compatible key secret to archive parsed match blobs
MATCH_ARCHIVE_S3_ENDPOINT: '', // S3-compatible endpoint to archive parsed match blobs
MATCH_ARCHIVE_S3_BUCKET: 'opendota', // name of the S3 bucket to archive parsed match blobs
ENABLE_PLAYER_ARCHIVE: '', // Allow reading/writing player match blobs to S3 storage
PLAYER_ARCHIVE_S3_KEY_ID: '', // S3-compatible key ID to archive player match blobs
PLAYER_ARCHIVE_S3_KEY_SECRET: '', // S3-compatible key secret to archive player match blobs
PLAYER_ARCHIVE_S3_ENDPOINT: '', // S3-compatible endpoint to archive player match blobs
PLAYER_ARCHIVE_S3_BUCKET: 'opendota-players', // name of the S3 bucket to archive player match blobs
DISABLE_REPARSE: '', // Disable reparsing matches that are already parsed
DISABLE_REPARSE_EARLY: '', // Disable reparsing matches by checking parsed_matches table first
DISABLE_REGCDATA: '', // Disable refetching new GC data on every request (cache it)
DISABLE_REAPI: '', // Disable refetching new API data on every request
DISABLE_OLD_PARSE: '', // Disable parsing for old non-league matches unlikely to have replays
API_KEY_GEN_THRESHOLD: '0', // Account ID requirement (delta from max) for generating API keys
SERVICE_REGISTRY_HOST: '', // Host for external services to register themselves at
USE_SERVICE_REGISTRY: '', // Use the service registry for determining gc and parser urls
SCANNER_OFFSET: '0', // Delay in match seq num value to run secondary scanner (to pick up missing matches)
};
if (process.env.NODE_ENV === 'development') {
// force PORT to null in development so we can run multiple web services without conflict
process.env.PORT = '';
}
if (process.env.NODE_ENV === 'test') {
process.env.PORT = ''; // use service defaults
process.env.POSTGRES_URL = process.env.POSTGRES_URL + '_test';
process.env.CASSANDRA_URL = process.env.CASSANDRA_URL + '_test';
process.env.SCYLLA_URL = process.env.SCYLLA_URL + '_test';
process.env.REDIS_URL = process.env.REDIS_URL?.slice(0, -1) + '1';
process.env.SESSION_SECRET = 'testsecretvalue';
process.env.FRONTEND_PORT = '5001';
}
// Export the combined values
export const config = {
...defaults,
...process.env,
};
export default config;