Welcome to the documentation of OpenQOTD! Here you can find all the information you need to get started with the bot, as well as some more advanced topics.
The main way to interact with OpenQOTD is using Slash Commands.
OpenQOTD also only acts once the configuration has been initialized, otherwise it does nothing.
OpenQOTD must be configured initially using /config initialize
.
Afterwards, /config set
and /config reset
can be used to set the config, and /config get
can be used to view it.
/config
can only be run by users with the "Administrator" server permission.
The following config variables can be set using /config initialize
or /config set
:
Required fields are marked with "field
", and default values are shown using "value
".
basic_role
: This is the role that is required to run non-administrative commands, which includes: /suggest
(if suggestions are enabled)/leaderboard
/topic
/sentquestions
admin_role
: This is the role that is required to run administrative and potentially destructive commands, which includes: /questions
/suggestions
/presets
/trigger
⚠️ Warning: While people without this role cannot run /suggestions
, they can accept or deny suggestions using the buttons of the messages, so make sure to have your suggestions_channel
set to a channel that is only viewable by people you trust!
It's recommended to set it to a staff-only channel, and it can also be within a thread, to make it easier for organization purposes.
qotd_channel
: This is the channel that QOTDs are sent to, which includes the daily QOTD and the QOTDs that are triggered manually using /trigger
. qotd_ping_role
: This is the role that gets pinged when a QOTD is sent manually or using /trigger
, even if it is a preset or there is no QOTD available.enable_automatic_qotdtrue
: Determines whether the QOTD is sent automatically every day at the set time.false
, the QOTD has to be triggered manually using /trigger
. enable_qotd_pin_messagetrue
: Determines whether the old QOTD, if existant and pinned, is unpinned and the new QOTD is pinned automatically after it is sent. enable_qotd_create_threadfalse
: Determines whether to create a thread for the QOTD when it is sent, with the auto-archive duration being 24 hours. enable_qotd_automatic_presetstrue
: Determines whether Presets are sent if there are no custom questions available.enable_qotd_unavailable_messagetrue
: Determines whether a message is sent if there are no QOTDs available, which happens if there are no custom questions available and presets are disabled or exhausted.qotd_time_hour_utc
& qotd_time_minute_utc
: The hour and minute at which the QOTDs are sent (if enable_automatic_qotd
is enabled), in UTC time.qotd_time_hour_utc
to 15 and qotd_time_minute_utc
to 47.enable_suggestionstrue
: Determines whether suggestions are enabled./suggest
and /qotd
commands are not available. suggestions_channel
: The channel where new suggestions are sent to, with buttons to accept/deny them./suggestions
.suggestions_ping_role
: The role that gets pinged alongside with the message in the suggestions_channel
when a new suggestion is received.notices_levelAll
: Notices are messages that are sent alongside QOTDs, which are written by the developer and are used to inform users about updates, changes, suggestions and thelike.All
: All notices are sent. Keep in mind that some of these notices may include encouraging users to join the community server, donate, contribute, or similar. Consider keeping this enabled to help this free and open-source project work out. Thank you ♡Important
: Only important announcements are sent, including maintenance times and breaking changes. It is recommended to keep at least this level enabled.None
: No notices are sent whatsoever.logs_channel
: The channel where logs are sent to, which includes changes being made to the config, questions or suggestions. /trigger
, or the config getting re-initialized using /config initialize
. Questions are the main feature of OpenQOTD, and they are what the bot sends every day.
They can be added by staff members or suggested by users (if suggestions are enabled). Presets work a little differently, to learn more about them see Presets.
Each question has one of three types, Suggested, Accepted or Sent:
As you can see, the only questions that are sendable are Accepted questions, and they are prioritized over Presets if they are available.
If a QOTD is triggered either daily automatically or using /trigger
, a random Accepted question is sent, and that question is marked as Sent.
The following commands are available to manage questions and are only available to Administrators or users with the admin_role
set in the config:
Required parameters are shown in square brackets ([required]
) and optional in angled brackets (<required>
), and default values are shown using "value
".
/questions view [question_id]
: View all available information about a question, including its type, content, author, the date it was added, the person who accepted it, and more. /questions list [type] <page1>
: List all question of a certain type, which can be Suggested
, Accepted
or Sent
. /questions search [query] <page1>
: Search for questions using a query. All questions that contain the query in their content are shown, no matter the type. This is case-insensitive. /questions add [question] [type]
: Add a question to the bot with a certain type, which can be Suggested
, Accepted
or Sent
. /questions changetype [question_id] [type]
: Change the type of a question to Suggested
, Accepted
or Sent
. Note that setting a question from Suggest
to Accepted
works, but it is recommended to use /suggestions accept
instead. /questions changetypebulk [from_type] [to_type]
: Change the type of all questions of a certain type to another. For example, you can change all Sent
questions to Accepted
. Unlike /suggestions acceptall
, running this command with Suggested
→Accepted
will not notify the suggesters. /questions remove [question_id]
: Remove a question from the bot. This is irreversible, and the question is removed from all listings. If suggestions are enabled, users can suggest questions using /suggest
or /qotd
.
These suggestions (=questions with type Suggested
) have to be accepted or denied by staff members in order to be sendable, and they are sent to the suggestions_channel
with buttons to accept or deny them.
Note that anyone can accept or deny suggestions using the buttons of the messages, so make sure to have your suggestions_channel
set to a channel that is only viewable by people you trust!
The following commands are available to manage suggestions and are only available to Administrators or users with the admin_role
set in the config:
Required parameters are shown in square brackets ([required]
) and optional in angled brackets (<required>
), and default values are shown using "value
".
/suggestions accept [suggestion_id]
: Accepts a suggestion. This changes the type of the question to Accepted
and notifies the suggester in private messages. /suggestions deny [suggestion_id] [reason]
: Denies a suggestion with a reason. This permanently removes the suggestion from the bot and notifies the suggester with the denial reason in private messages./suggestions acceptall
: Accepts all suggestions. This changes the type of all suggestions to Accepted
and notifies the suggesters in private messages. /suggestions denyall
: Denies all suggestions without reason. This permanently removes all suggestions from the bot and notifies the suggesters in private messages. Note that if you want to list all suggestions, you can use /questions list type:Suggested
.
Presets are a special type of questions that are sent if they are enabled and there are no custom questions available.
Once a preset is sent, it is marked as completed, and is not sendable unless it is manually enabled again. They do NOT show in the /questions
or /suggestions
listings, and they are not editable, however it is possible to disable them individually by manually marking them as completed using /presets setactive
.
Just like questions, they get sent in a random order and not as a queue.
/presets list <type> <page1>
: List all presets of a certain type, which can be Active
or Completed
./presets setactive [preset_id] [active]
: Set a preset to be Active
or Completed
. If a preset is active, it is sent if there are no custom questions available./presets reset
: Reset all presets to be active. This makes all presets sendable if there are no custom questions available. /presets suggest
: Suggest a preset to be added to the bot globally. This is similar to /feedback
, only that it is specifically for suggesting presets. The following commands are other commands, most of which are available to everyone with the basic_role
role (with a notable exception being /trigger
being admin-only):
Required parameters are shown in square brackets ([required]
) and optional in angled brackets (<required>
), and default values are shown using "value
".
/help
: Print general information about the bot. /leaderboard <page1>
: View the leaderboard of the server, which shows the top users by the amount of Sent
questions they have added (questions that have been accepted and sent as QOTD)./lb
. /topic <include_presetstrue>
: Send a random question of type Sent
to the current channel. /sentquestions <page1>
: List all questions that have been sent as QOTD./questions list type:Sent
, except that it is available to all users with the basic_role
(not just admins). /suggest [question]
: Suggest a question to be added to the server, which will create a Suggested
question that has to be accepted or denied by staff members to be sendable./qotd
. /trigger
: Trigger a QOTD manually. This sends a random available QOTD, as if it was sent automatically.admin_role
set in the config. /feedback [message]
: Send feedback to the bot's developer. basic_role
. > OpenQOTD is looking for contributors! If you want to help out with making the bot or this website better, you can take a look at the source code on GitHub or send me a message!
>> Have any questions, suggestions, or want to report a bug? Please let us know in our community server!
Licensed under GPL-3.0 | Source Code
Terms of Service | Privacy Policy