-
Notifications
You must be signed in to change notification settings - Fork 183
Rooms configuration
The Wiki page explains the following:
- File structure for the rooms.yml file
- Glossary of terms used in rooms.yml
- How to configure SmokeDetector for development
The file is a yaml/yml markdown file which has 3 sections, one for each chat domain:
- stackexchange.com
- meta.stackexchange.com
- stackoverflow.com
Each section contains the following structure:
<chat host>:
<room id>:
commands: true/false,
watcher: true/false,
msg_types:
- <role string...>
- ...
privileges:
- <user id...>
- ...
-
<chat host>
- The domain in which the chat host is a sub-domain. Stack Exchange has 3 chat domains: chat.stackexchange.com, chat.meta.stackexchange.com, and chat.stackoverflow.com. The correct entries for<chat host>
corresponding to these domains arestackexchange.com
,meta.stackexchange.com
, andstackoverflow.com
. Each chat server has independent rate limiting for the chat messages a single user can post. If you're making a test room into which the SmokeDetector user is going to be posting lots of messages, then please create the room on eithermeta.stackexchange.com
orstackoverflow.com
. SmokeDetector currently posts most of it's messages to thestackexchange.com
chat server, which means it's the one that gets rate-limited the most. -
<room id>
- room id for the rooms with which SmokeDetector interacts. For example: 12345. -
commands
- true/false boolean flag which determines if SmokeDetector listens for commands in the room -
watcher
- true/false boolean flag which determines if during the 2 minute chat edit/delete window, the report receives FP feedback from feedback in that chat room, or the SE post is deleted, then SmokeDetector will delete the report. -
msg_types
- kinds of messages the room will receive, as described in the following role_string types:- Define which sites will have spam reports which are detected for at least one non-experimental reason posted to the room:
-
all-sites
: Reports for all sites will be posted to the room. -
site-<domain>
: The room will receive reports about SE posts on the indicated site (e.gsite-askubuntu.com
orsite-codegolf.stackexchange.com
). There can be multiplesite-<domain>
lines to include more than one site. Meta sites are separate domains. If you want reports for both a main site and its meta site, then that's two entries. -
site-no-<domain>
: exclude a site's reports from being posted in the room (e.g.site-no-stackoverflow.com
); normally used in combination withall-sites
. There can be multiplesite-no-<domain>
lines to exclude more than one site. Thesite-no-<domain>
settings affect all reports, including experimental reports. Meta sites are separate domains. If you want prevent reports for both a main site and its meta site, then that's two entries.
-
- Define which sites will have spam reports which are detected for only experimental reasons posted to the room. From SmokeDetector's point of view, the experimental reasons are defined in
experimental_reasons
in the globalvars.py file. Experimental reasons are also separately defined on metasmoke, which restricts their maximum weight to 1 (ping a metasmoke developer, if those reasons should change).-
experimental-all-sites
: Experimental reports for all sites will be posted to the room. -
experimental-site-<domain>
: The room will receive experimental reports about SE posts on the indicated site (e.gexperimental-site-askubuntu.com
and/orexperimental-site-codegolf.stackexchange.com
). There can be multipleexperimental-site-<domain>
lines to include more than one site. Meta sites are separate domains. If you want experimental reports for both a main site and its meta site, then that's two entries.
-
-
debug
: This is what Charcoal HQ or your main room would have set. Rooms with this set will receive startup messages and other debugging information (basically anything that would have previously been done withGlobalVars.charcoal_hq.send_message
). -
delay
: introduces a 5 minute delay for reports; reports won't be posted if the post has been marked as false positive or deleted within the 5 minute window. -
dump
: used for Socket Science. Do not add this, unless you are a developer working on Socket Science. Rooms with thedump
option must exist and not be deleted, or SmokeDetector will fail when becoming the "active" instance. If a room defined asdump
becomes deleted, then you will probably want to ping the owners of any SmokeDetector instances which have gone off-line as a result. The quickest way to get those instances back will be to have the owners manually pull a new version of rooms.yml from GitHub with thedump
removed. SmokeDetector instances that are in standby can be instructed to pull a newer version from GitHub through the status page on metasmoke. -
metasmoke
: Messages sent from metasmoke are forwarded to this room. This includes things like notification of the first feedback received for a report, CI success/failure which metasmoke is monitoring, etc. This is intended for additional information in Charcoal HQ. -
metatavern
: A special role created for the Tavern on Meta, currently it just receives messages about blocks (for Town Halls). - Define whether or not reports on posts with offensive titles will have their actual titles posted, or will have their titles masked and the text "potentially offensive title - see MS for details" posted instead.
-
offensive-mask
: Posts with offensive titles will have their titles masked, and not have them posted in the room. -
no-offensive-mask
: Posts with offensive titles will not have their titles masked, and the actual titles will be posted in the room.
-
-
no-<reason>
: This room won't receive reports with the specified reason (e.gno-all-caps body
)
- Define which sites will have spam reports which are detected for at least one non-experimental reason posted to the room:
-
privileges
- who can run privileged commands in this room. There are two mutually exclusive formats to what this section can contain.
The first is a list of SE Network user IDs, one per line. Each user ID must be defined in users.yml.
The other format isinherit
/additional
:-
inherit
: indicates the list of permissions should be inherited from another room.-
site
: a "chat host" (see above) which contains the room from which to inherit. -
room
: the number of the room from which the list of permitted user IDs is to be inherited.
-
-
additional
: a list of SE Network user IDs, one per line, which are privileged in this room in addition to those inherited from thesite
/room
defined ininherit
. Ifinherit
is used,additional
is available. When available, it is optional.
-
During development, you probably want to avoid posting a bunch of reports and debug messages to our main rooms. In this case, you can set up a custom rooms.yml file to configure where Smokey will post messages.
Simply create a file named rooms_custom.yml
, and fill it in using the format described above. If you need a spare room to test in, we have one available for your use:
If you are going to do testing which will result in the bot posting a lot of messages to chat, it's preferred that you reduce the possibility of SmokeDetector becoming rate-limited. You can do this by, preferably, using a different bot account for your testing. If you need to use the SmokeDetector account, please use a room on chat.stackoverflow.com, as that is the Stack Exchange chat server which gets the lightest traffic from SmokeDetector.
If you don't want Smokey to post any chat messages, you can simply leave the file blank.
Smokey is made with <3 by the Charcoal Team and the other awesome contributors from Charcoal HQ.