Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/focus04/focus

Professional Discord moderation bot.
https://github.com/focus04/focus

discord discord-bot discord-js keyv mongodb mongodb-atlas node-fetch node-js nodejs

Last synced: 6 days ago
JSON representation

Professional Discord moderation bot.

Awesome Lists containing this project

README

        

# Focus
## Overview
*Revamp your Discord server. Moderation, role management, logging and more, all in an easy to use, feature rich and bug free Discord bot!*
## Command List
### Debug Commands
- `/botinfo` Checks how many servers the bot is in.
- `/botsuggestion` Submits a suggestion directly to the bot's Discord server.
- `/bugreport` Submits a bug report directly to the bot's Discord server.
- `/discordserver` Sends an invite link to the bot's support server.
- `/invitelink` Sends the invite link for the bot.
- `/ping` Displays the bot's current latency in ms.
- `/serversettings` Sends current bot settings for this server.
### Fun Commands
- `/approved` Approves your profile picture or someone else's.
- `/blur` Blurs your profile picture or someone else's.
- `/dogfact` Sends a lovely dog fact.
- `/catfact` Same as dogfact, except it's for cats.
- `/contrast` Adds contrast effect to your profile picture or someone else's.
- `/deepfry` Add deepfried effect to your profile picture or someone else's.
- `/define` Looks up a term in the dictionary.
- `/nasanews` Looks up an astronomy-related term on NASA's Website and returns a fact about it.
- `/weather` Tells you information about the weather in a given location.
- `/yomomma` Sends a your mom joke to someone.
### Info Commands
- `/avatar` Displays the avatar of a user.
- `/help` Displays a list of all available commands along with their usage.
- `/serverinfo` Displays information about the server you're in.
- `/userinfo` Displays information about a user's account account.
### Staff Commands
- `/addnote` Adds an admin note on someone's account. All staff members will be able to view this note.
- `/ban` Restricts a user's access to the server.
- `/baninfo` View details about a banned user.
- `/checknames` Check a member's previous nicknames.
- `/clear` Bulk deletes a certain amount of messages.
- `/delnote` Deletes a note from a user.
- `/delsuggestion` Deletes a suggestion.
- `/disablecmd` Disables a command from the server.
- `/editnote` Edits a note from a user.
- `/enablecmd` Enables a command from the server.
- `/kick` Kicks a user out of the server.
- `/mute` Restricts a user from sending messages.
- `/muteinfo` View details about a muted member.
- `/record` Displays how many punishments a user has ever received on the server.
- `/remindme` Sets a timer for a reminder.
- `/report` Submits a report to the staff's logs channel.
- `/serversuggestion` Submit a server suggestion.
- `/setlogschannel` Sets a custom channel where moderation logs will be sent.
- `/suggestion` Accept or decline a suggestion from your suggestion channel.
- `/suggestionchannel` Sets a channel for suggestions to be sent in.
- `/togglemsglogs` Toggles message logs on/off.
- `/unban` The username of the banned user.
- `/unmute` Removes a user's muted status earlier.
- `/viewnotes` Shows all notes linked to a user from this server.
- `/warn` Sends a warning message to a user.
### Role Commands
- `/rolepicker` Creates a menu that automatically assigns roles to users that react to it.
- `/addroletorp` Adds a role option to an existent role picker.
- `/removerolefromrp` Removes a role option from an existent role picker.
- `/disablerp` Disables an existent role picker.
- `/enablerp` Enables a disabled role picker.
- `/giverole` Adds a role to a user.
- `/takerole` Removes a role from a user.
### Welcome Commands
- `/setwelcomechannel` Sets a custom channel where newcommers will receive a welcome message.
- `/setleavechannel` Sets a custom channel where leaving members will be logged.
- `/welcomemessage` Sets a custom welcome message to be displayed when someone joins the server.
- `/leavemessage` Sets a custom good bye message for those leaving the server.
- `/welcomedm` Sets a custom welcome message that will be inboxed to new users.
- `/welcomerole` Sets a role to be assigned to new users when they join the server.
- `/togglewelcomemsg` Toggles welcome messages on/off.
- `/toggleleavemsg` Toggles leave messages on/off.
- `/togglewelcomedm` Toggles welcome DMs on/off.
## Reviews
> It's a really useful and good bot. Easy to manage. I would recommend everyone to add this to their respective servers.

> A really useful and easy to use bot.
## Official Invite Link
You can invite my official bot running on the latest version [from here](https://discord.com/oauth2/authorize?client_id=723094801175806024&permissions=268561494&scope=bot%20applications.commands).
## Installation Guide
This guide will cover all the steps needed to get a bot up and running from absolute scratch using my source code. If you stumble across any issues with setting it up, my [Discord server](https://discord.gg/r4bsXez) is the right place to seek help.
Please note though, I strongly advice that you have a decent understanding of JavaScript, Node.js and discord.js before diving into this.
### 1. Creating a Bot Account
* Open your browser, go to Discord's [Developer Portal](https://discord.com/developers/applications), click on `New Application` and give your application a name.

* Click on the application you've just created and navigate into `Bot`. Here you can give your bot a username, description (that will show up in the About Me section) and an avatar. You want to make sure that the `Server Members Intent` stays enabled.

* In order to have your bot join any servers, you have to create an invite link. The invite url will contain your bot's user ID (which you can copy from the `Application` menu). Simply replace `[your_bot_id]` with your bot client ID you just copied in the template below, then use it to invite the bot.
```
https://discord.com/oauth2/authorize?client_id=[your_bot_id]&permissions=268561494&scope=bot%20applications.commands
```
### 2. Connecting The Code To The Bot
* Before downloading the bot's source code, you must download and install [Node.js](https://nodejs.org/en/) on your computer.

* You can now proceed to download [the latest code](https://github.com/Focus04/focus/releases). Scroll to the latest release and download the corresponding zip file, then extract it somewhere on your computer.

* Navigate into the folder you've just extracted (which should contain all the code), right click and open a new terminal in the folder (my recommendation would be [PowerShell 7](https://github.com/PowerShell/powershell/releases) if you're a Windows user). Use the following command to install all the dependencies:
```
npm i
```

* Go back to the `Developer Portal` into your browser and navigate into `Bot`. Here you want to click on `Copy` to copy your bot's token. This token is the password for your bot account, so you want to keep that as secure as possible in an environment variable.

* Open the code using your preferred text editor (I recommend sticking to [Visual Studio Code](https://code.visualstudio.com/)). To speed this up, you can type `code.` in the terminal.

* With your text editor, navigate into the `.env` file and replace `your_bot_token` with the token you just copied, then hit save.
### 3. Configuring the bot
* The bot offers suggestions and bug reporting features. For those to work, you have to create 2 channels for suggestions and bug reports respectively.

* Right click on the suggestions channel, then hit `Copy ID`. Replace the `changeme` in the `suggestionChId` field with the ID you copied.

* Repeat for the bug reports channel by editing the `bugChId` field.

* You can finally edit your `botInviteLink`, `discordInviteLink`, `topgg`, `website` and `github` fields with your own urls (or leave them empty).

* You can also edit the `package.json` file.
### 4. Setting up the database
* Here comes the trickier part, setting up a MongoDB database for the bot to store its data in. Start by registering an account at [MongoDB](https://www.mongodb.com/).

* Navigate to `Databases`, then hit `Create`. Select your prefered options (there are options for free tier clusters too). When you're done, click `Create Cluster`. The creation process can take several minutes, so be patient.

* Once the cluster goes live, click on `Browse Collections` and hit `Create Database`. Here you have to create a database for each field in the `.env` file (22 in total). You can start with `bannedUsers`. The name of the database is up to you but make sure it's something suggestive as you'll need it later. You can now click `Create`.

* Repeat for the remaining fields (`bns`, `disabledCmds`, `kks`, `leaveMessages`, `leaveChannels`, `logChannels`, `msgLogs`, `mts`, `mutedMembers`, `names`, `notes`, `punishments`, `reminders`, `suggestionChannels`, `toggleLeaveMsg`, `toggleWelcomeDm`, `toggleWelcomeMsg`, `welcomeChannels`, `welcomeDms`, `welcomeMessages`, `welcomeRoles` & `wrns`).

* Go back to your cluster overview, click `Connect` and choose the second option. Here you have to choose `Node.js` and the `2.2.12 or later` version. Copy the connection string. Replace `database_url` with the url you copied in all fields of the `.env`. Replace `` with the password you set on your cluster. Replace `myFirstDatabase` with the name of the database that you created for the corresponding field. There should be 25 databases in total, which equates to 25 connection strings.
### 5. Generating API Keys
* In order for the weather command to work, you'll need to generate a key for the [OpenWeatherMap API](https://openweathermap.org/api). Register an account there.

* On the homepage, click on your username and go to `My API keys`.

* Input a name for your key and hit `Generate`.

* Copy the newly generated key, go to the `.env` file and replace `your_open_weather_map_api_key` with it.
### 6. Starting up the bot
* At this point you're pretty much done. You can now run the following command in your terminal to start the bot. Remember to use it everytime you update the source code:
```
node .
```