diff --git a/README.md b/README.md new file mode 100644 index 0000000..b4e701b --- /dev/null +++ b/README.md @@ -0,0 +1,75 @@ +

+
+ Guava Image +
+ Guava
+

+ +

+ Dead simple Discord music bot +
+ Invite Guava +

+ +

+ + discord.py + + + Code Style: Black + + + + + + + +

+ +# Overview + +Guava is a Discord music bot with support for multiple different music and video streaming platforms. Guava is a part of >150 Discord servers and currently supports these services: + +- Spotify +- YouTube (videos and streams) +- SoundCloud +- Bandcamp +- Deezer +- Twitch Streams +- Vimeo + +Getting started is easy, simply invite Guava to your server and run `/help` to see what all Guava has to offer. + +# Want to self-host? +Guava is built on Python and requires a Lavalink node running release `v4` or higher with the LavaSrc plugin. If you would like to configure Guava and run it on your own, follow the steps below. + +*P.S. Some information on starting your own lavalink node can be found [here](#lavalink-information)* + +On first run you will likely get a critical warning in your console, don't worry, this is expected. It will automatically create a `config.ini` file for you in the root of the directory with all of the necessary configuration options. + +Fill out the configuration options, then re-run the bot, and everything *should* just work. For information on each configuration option, look below. + +Field | Description +--- | --- +TOKEN | The token for your bot. Create a bot at [discord.com/developers](https://discord.com/developers) +BOT_COLOR | Hex color code that will be used for the color of message embeds +HOST | Host address for your Lavalink node +PORT | Port for your Lavalink node +PASSWORD | Password to authenticate into the Lavalink node + +# Lavalink Information + +As previously state, a Lavalink node running at least `v4` with the LavaSrc plugin is required. Due to the plugin requirement, it is unlikely that you will be able to use a free/public Lavalink node. + +For instructions on setting up a Lavalink node, look [here](https://lavalink.dev/getting-started/), and for instructions on the LavaSrc plugin, look [here](). +
+*P.S. Only the Spotify, Deezer, and YouTube sources/search providers are needed.* + +It is also highly recommended to setup IPv6 rotation in order to avoid blocks and other issues. There are helpful guides for this both [here](https://blog.arbjerg.dev/2020/3/tunnelbroker-with-lavalink) and [here](https://gist.github.com/Drapersniper/11fee08f91ea7174e0d8af12496f3443). + +An example of my personal `application.yml` file can be found [here](https://github.com/packetparker/Guava/applcation.yml.example). + +
+
+ +If you have any questions, feel free to email at [contact@pkrm.dev](mailto:contact@pkrm.dev). Thank you for checking out Guava, and happy coding. \ No newline at end of file diff --git a/application.yml.example b/application.yml.example new file mode 100644 index 0000000..c25aca8 --- /dev/null +++ b/application.yml.example @@ -0,0 +1,118 @@ +server: # REST and WS server + port: 2333 + address: localhost + http2: + enabled: false # Whether to enable HTTP/2 support + +plugins: + lavasrc: + providers: # Custom providers for track loading. This is the default + - "ytsearch:\"%ISRC%\"" # Will be ignored if track does not have an ISRC. See https://en.wikipedia.org/wiki/International_Standard_Recording_Code + - "ytsearch:%QUERY%" # Will be used if track has no ISRC or no track could be found for the ISRC + - "spsearch:%QUERY%" + - "scsearch:\"%ISRC%\"" + - "scsearch:%QUERY%" + - "dzisrc:\"%ISRC%\"" + - "dzsearch:%QUERY%" + sources: + spotify: true # Enable Spotify source + applemusic: false # Enable Apple Music source + deezer: true # Enable Deezer source + yandexmusic: false # Enable Yandex Music source + flowerytts: false # Enable Flowery TTS source + youtube: true # Enable YouTube search source (https://github.com/topi314/LavaSearch) + spotify: + clientId: "" + clientSecret: "" + countryCode: "US" # the country code you want to use for filtering the artists top tracks. See https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2 + playlistLoadLimit: 6 # The number of pages at 100 tracks each + albumLoadLimit: 6 # The number of pages at 50 tracks each + deezer: + masterDecryptionKey: "" # the master key used for decrypting the deezer tracks. (yes this is not here you need to get it from somewhere else) + +lavalink: + plugins: + - dependency: "com.github.topi314.lavasrc:lavasrc-plugin:4.0.1" + repository: "https://maven.lavalink.dev/releases" # this is optional for lavalink v4.0.0-beta.5 or greater + snapshot: false # set to true if you want to use snapshot builds (see below) + + server: + password: "youshallnotpass" + sources: + youtube: true + bandcamp: true + soundcloud: true + twitch: true + vimeo: true + http: true + local: false + filters: # All filters are enabled by default + volume: true + equalizer: true + karaoke: true + timescale: true + tremolo: true + vibrato: true + distortion: true + rotation: true + channelMix: true + lowPass: true + + bufferDurationMs: 400 # The duration of the NAS buffer. Higher values fare better against longer GC pauses. Duration <= 0 to disable JDA-NAS. Minimum of 40ms, lower values may introduce pauses. + frameBufferDurationMs: 5000 # How many milliseconds of audio to keep buffered + opusEncodingQuality: 10 # Opus encoder quality. Valid values range from 0 to 10, where 10 is best quality but is the most expensive on the CPU. + resamplingQuality: LOW # Quality of resampling operations. Valid values are LOW, MEDIUM and HIGH, where HIGH uses the most CPU. + trackStuckThresholdMs: 10000 # The threshold for how long a track can be stuck. A track is stuck if does not return any audio data. + useSeekGhosting: true # Seek ghosting is the effect where whilst a seek is in progress, the audio buffer is read from until empty, or until seek is ready. + youtubePlaylistLoadLimit: 6 # Number of pages at 100 each + playerUpdateInterval: 5 # How frequently to send player updates to clients, in seconds + youtubeSearchEnabled: true + soundcloudSearchEnabled: true + gc-warnings: true + ratelimit: + ipBlocks: ["IPv6 Block"] # list of ip blocks + excludedIps: [] # ips which should be explicit excluded from usage by lavalink + strategy: "LoadBalance" # RotateOnBan | LoadBalance | NanoSwitch | RotatingNanoSwitch + searchTriggersFail: true # Whether a search 429 should trigger marking the ip as failing + # retryLimit: -1 # -1 = use default lavaplayer value | 0 = infinity | >0 = retry will happen this numbers times + #youtubeConfig: # Required for avoiding all age restrictions by YouTube, some restricted videos still can be played without. + #email: "" # Email of Google account + #password: "" # Password of Google account + #httpConfig: # Useful for blocking bad-actors from ip-grabbing your music node and attacking it, this way only the http proxy will be attacked + #proxyHost: "localhost" # Hostname of the proxy, (ip or domain) + #proxyPort: 3128 # Proxy port, 3128 is the default for squidProxy + #proxyUser: "" # Optional user for basic authentication fields, leave blank if you don't use basic auth + #proxyPassword: "" # Password for basic authentication + +metrics: + prometheus: + enabled: false + endpoint: /metrics + +sentry: + dsn: "" + environment: "" +# tags: +# some_key: some_value +# another_key: another_value + +logging: + file: + path: ./logs/ + + level: + root: INFO + lavalink: INFO + + request: + enabled: true + includeClientInfo: true + includeHeaders: false + includeQueryString: true + includePayload: true + maxPayloadLength: 10000 + + logback: + rollingpolicy: + max-file-size: 1GB + max-history: 30 diff --git a/config.ini.example b/config.ini.example new file mode 100644 index 0000000..ad9a254 --- /dev/null +++ b/config.ini.example @@ -0,0 +1,8 @@ +[BOT_INFO] +token = +bot_color = + +[LAVALINK] +host = +port = +password = \ No newline at end of file diff --git a/guava.png b/guava.png new file mode 100644 index 0000000..a05a077 Binary files /dev/null and b/guava.png differ