2015-02-22 02:09:22 +00:00
|
|
|
pyx.cookie_domain=.localhost
|
|
|
|
pyx.max_users=100
|
|
|
|
pyx.max_games=25
|
|
|
|
pyx.include_inactive_cardsets=true
|
2015-02-22 03:38:23 +00:00
|
|
|
pyx.broadcast_connects_and_disconnects=true
|
2018-02-28 19:19:34 +00:00
|
|
|
pyx.global_chat_enabled=true
|
Add ID codes for positive user identification, and minor fixups.
Users can specify an identification code when they connect (8-100 characters), only if they are using HTTPS. This code is combined with their nickname and a server-side secret, hashed with SHA-256, and condensed down to 64 bits by XORing every 8th byte with each other, and finally converted to base64 (with the trailing = removed). This code is displayed in a tooltip when hovering over the user's chat (TODO: mobile way to view it).
Sigils have been added to be displayed before the user's name in the chat. Admins get @, users with an ID code get +, and normal users get nothing. The IS_ADMIN field is now deprecated, as this can be determined from the user's sigil. It will be removed eventually, but is still being included in events even though the official client should not be using it anymore.
Kicks and bans are now always displayed to all users, even if the server isn't transmitting quit events normally.
2018-03-03 01:24:58 +00:00
|
|
|
# allow identification codes to be used without HTTPS
|
|
|
|
pyx.insecure_id_allowed=true
|
|
|
|
# set this to some secure random value, and never change it, unless you want to break all codes
|
|
|
|
pyx.id_code_salt=
|
2018-03-22 23:26:30 +00:00
|
|
|
# comma-separated listed of IP addresses (v4 or v6) from which users are considered admins.
|
|
|
|
pyx.admin_addrs=127.0.0.1,::1
|
2018-03-24 00:08:28 +00:00
|
|
|
|
|
|
|
# Settings for global chat protection. Some of these do not apply to game chats.
|
|
|
|
# Ratio of 'basic' characters to length of message. Basic characters are defined by
|
|
|
|
# Character.isJavaIdentifierPart, which stipulates:
|
|
|
|
# -it is a letter
|
|
|
|
# -it is a currency symbol (such as '$')
|
|
|
|
# -it is a connecting punctuation character (such as '_')
|
|
|
|
# -it is a digit
|
|
|
|
# -it is a numeric letter (such as a Roman numeral character)
|
|
|
|
# -it is a combining mark
|
|
|
|
# -it is a non-spacing mark
|
|
|
|
# -isIdentifierIgnorable(codePoint) returns true for the character
|
|
|
|
pyx.global.basic_ratio=.5
|
|
|
|
# A message must have at least this many characters for that ratio to apply.
|
|
|
|
pyx.global.basic_min_len=10
|
|
|
|
# messages longer than min_len characters require at least min_count spaces between words
|
|
|
|
pyx.global.spaces_min_len=50
|
|
|
|
pyx.global.spaces_min_count=4
|
2018-03-23 21:36:26 +00:00
|
|
|
# this many messages to global chat in that many seconds is considered chatting too fast.
|
2018-03-24 00:08:28 +00:00
|
|
|
pyx.global.flood_count=3
|
2018-03-23 00:12:47 +00:00
|
|
|
# seconds
|
2018-03-24 00:08:28 +00:00
|
|
|
pyx.global.flood_time=25
|
|
|
|
|
|
|
|
# Settings for game chat protection. If it isn't listed here, it isn't supported.
|
2018-03-23 21:36:26 +00:00
|
|
|
# same but for game chats
|
2018-03-24 00:08:28 +00:00
|
|
|
pyx.game.flood_count=5
|
2018-03-23 21:36:26 +00:00
|
|
|
# seconds
|
2018-03-24 00:08:28 +00:00
|
|
|
pyx.game.flood_time=30
|
2018-03-23 21:36:26 +00:00
|
|
|
|
2015-02-22 02:09:22 +00:00
|
|
|
|
2015-02-16 01:29:45 +00:00
|
|
|
# for production use, use postgres
|
|
|
|
#hibernate.dialect=org.hibernate.dialect.PostgreSQLDialect
|
|
|
|
#hibernate.driver_class=org.postgresql.Driver
|
|
|
|
#hibernate.url=jdbc:postgresql://localhost/pyx
|
|
|
|
|
|
|
|
# for local use, you can also use sqlite
|
|
|
|
hibernate.dialect=net.socialgamer.cah.hibernate.SqliteDialect
|
|
|
|
hibernate.driver_class=org.sqlite.JDBC
|
|
|
|
hibernate.url=jdbc:sqlite:pyx.sqlite
|
|
|
|
|
|
|
|
# these likely need specified even with sqlite, even though they don't matter
|
2015-02-14 04:03:46 +00:00
|
|
|
hibernate.username=pyx
|
|
|
|
hibernate.password=CorrectHorseBatteryStaple
|
2015-02-16 01:29:45 +00:00
|
|
|
|
|
|
|
# debugging information
|
|
|
|
hibernate.sql.show=false
|
|
|
|
hibernate.sql.format=false
|
2015-02-28 19:58:47 +00:00
|
|
|
|
|
|
|
# second-level hibernate cache.
|
|
|
|
# vastly reduces database load at expense of data potentially being stale.
|
|
|
|
# use an in-memory cache provider. this is not suitable for long-term use, however I am using it for
|
|
|
|
# my servers for the time being -- better than nothing
|
|
|
|
#hibernate.cache.use_second_level_cache=true
|
|
|
|
#hibernate.cache.use_query_cache=true
|
|
|
|
#hibernate.cache.provider_class=org.hibernate.cache.HashtableCacheProvider
|
|
|
|
|
|
|
|
# to turn it off, use these settings instead. you will hit the db a lot more often.
|
|
|
|
hibernate.cache.use_second_level_cache=false
|
|
|
|
hibernate.cache.use_query_cache=false
|
|
|
|
hibernate.cache.provider_class=org.hibernate.cache.NoCacheProvider
|
2017-02-21 05:35:44 +00:00
|
|
|
|
|
|
|
# Metrics implementation.
|
|
|
|
pyx.metrics.impl=net.socialgamer.cah.metrics.NoOpMetrics
|
|
|
|
|
2017-02-27 06:27:56 +00:00
|
|
|
# for kafka metrics
|
|
|
|
kafka.host=kafka-host:9092
|
|
|
|
kafka.topic=pyx-metrics
|
2017-03-04 21:55:41 +00:00
|
|
|
# if this is false, the rest don't matter
|
|
|
|
kafka.ssl=false
|
|
|
|
kafka.truststore.path=
|
|
|
|
kafka.truststore.password=
|
|
|
|
# if this is false, the rest don't matter
|
2017-03-04 23:43:00 +00:00
|
|
|
kafka.ssl.usekey=false
|
2017-03-04 21:55:41 +00:00
|
|
|
kafka.keystore.path=
|
|
|
|
kafka.keystore.password=
|
|
|
|
kafka.key.password=
|
2017-03-04 23:43:00 +00:00
|
|
|
# only SCRAM-SHA-512 supported; if this is false, the rest don't matter
|
|
|
|
# must be used with ssl, does not need client key
|
|
|
|
kafka.sasl=false
|
|
|
|
kafka.sasl.username=
|
|
|
|
kafka.sasl.password=
|
|
|
|
|
2017-02-27 06:27:56 +00:00
|
|
|
|
|
|
|
|
2017-02-21 05:35:44 +00:00
|
|
|
# GeoIP database for analytics. If unset, will not be used.
|
|
|
|
# Only used if the above is not NoOpMetrics.
|
|
|
|
# See README.md for instructions.
|
|
|
|
geoip.db=
|