Solaris was built using more than 2 years of bot building experience to be the definitive word in server security. Bundled with plenty of powerful features, and with many more planned for the future, it's been designed to do all the things other moderation bots don't. Special thanks to those who helped me in building this bot. Note that this is just a re-written version of the original bot Solaris and the original author of this project is Parafoxia. Once again thank you very much if you liked my work!
If you ever wished you could hire a bouncer for your server, Solaris might be just what you're looking for.
- Make spam bots and excuses from rulebreaking members a thing of the past. A powerful gateway / verification system makes sure new members accept the rules before being able to talk in the server, and personally deals with those who don't.
- Add your own personal touch with tonnes of customisation options. Whether you want customisable messages, including separate messages for humans and bots, or the ability to set multiple member roles, Solaris has you covered.
- Get that peace of mind you deserve. With 24/7 uptime, and systems in place to make sure nothing goes amiss even if Solaris does go down, no new members will be left out.
Solaris is bundled full of useful moderation commands to give you the power you need, when you need it.
These include some old favourites...
kick
, which kicks all the specified members from the serverban
, which bans all the specified members from the serverunban
, which unbans all the specified members from the serverclear
, which clears the specified number of messages from a channelsetnickname
, which sets a member's nicknameclearnickname
, which clears all given members' nicknames
...as well as some rarer ones.
clearchannel
, which clears an entire channel of messages, giving you a clean slateunhoistnicknames
, which sorts out those annoying hoisters
There are plenty of detailed information commands to keep you in the know.
Again, the old timers are present:
userinfo
serverinfo
botinfo
...as well as the new guys.
detailedserverinfo
avatar
icon
If you liked the sound of all the above features, well, we're only just getting started. With plans to provide the ability to back up server configurations, include a dynamic warning system, and account for the most urgent situations with a lockdown system, there's a lot to keep your eyes open for!
You are able to clone Solaris to your machine in order to test it or contribute.
Solaris was also not designed with universal compatibility in mind. If you want to include sections of Solaris' code in your own program, you will likely need to make significant modifications. Make sure you abide by the terms of the license, which you can find in LICENSE.
Note: As of v1.0.0-rc.2, these instructions haven't been fully tested. If they are wrong, open an issue.
Warning: Docker functionality in Solaris was designed specifically with Debian 10 Buster in mind. If you are using another OS, you may need to modify the Dockerfile.
- docker
- docker-compose
cd
into the root directory (the one with this README in it).- Run
mkdir secrets
. - Create a file called "token" in the "/secrets" directory.
- Copy and paste your bot's token into the "token" file.
cd
back into the root directory.- Run
docker-compose build
.
Note: You may need to create a [root]/solaris/data/dynamic
directory for the build to be successful.
cd
into the root directory (the one with this README in it).- Run
docker-compose up
.- To run silently, use the
-d
flag.
- To run silently, use the
You should be able to run Solaris using this method on any OS.
- Python 3.8.0 or above
cd
into the root directory (the one with this README in it).- Create a file called ".env" in this directory.
- Populate the ".env" file using the following template. Note that all is here required specially don't forget to set all the emojis otherwise the bot will crash as the backup
EmojiGetter()
class hasn't been rewritten.TOKEN="xxxxxxxxxxxxxxxxxxxxxxxx.xxxxxx.xxxxxxxxxxxxxxxxxxxxxxxxxxx" DEFAULT_PREFIX=">>" HUB_GUILD_ID=<guild id> HUB_COMMANDS_CHANNEL_ID=<channel id> HUB_RELAY_CHANNEL_ID=<channel id> HUB_STDOUT_CHANNEL_ID=<channel id> SUPPORT_GUILD_ID=<guild id> SUPPORT_ROLE_ID=<role id> ACCEPT_EMOJI_ID=<emoji id> CANCEL_EMOJI_ID=<emoji id> EXIT_EMOJI_ID=<emoji id> INFO_EMOJI_ID=<emoji id> OPTION1_EMOJI_ID=<emoji id> OPTION2_EMOJI_ID=<emoji id> OPTION3_EMOJI_ID=<emoji id> OPTION4_EMOJI_ID=<emoji id> OPTION5_EMOJI_ID=<emoji id> OPTION6_EMOJI_ID=<emoji id> OPTION7_EMOJI_ID=<emoji id> OPTION8_EMOJI_ID=<emoji id> OPTION9_EMOJI_ID=<emoji id> PAGE_BACK_EMOJI_ID=<emoji id> PAGE_NEXT_EMOJI_ID=<emoji id> STEP_BACK_EMOJI_ID=<emoji id> STEP_NEXT_EMOJI_ID=<emoji id>
- Run
py -3 -m pip install poetry
.- You may need to use a different
pip
command depending on your Python configuration.
- You may need to use a different
- Run
py -3 -m venv ./.venv
. - Run
source ./.venv/bin/activate
. - Run
poetry install
.
cd
into the root directory (the one with this README in it).- Run
py -3 -m solaris
.