Skip to content

soulwax/Midori

Repository files navigation

Midori

GitHub license GitHub stars GitHub issues GitHub forks Node.js Version TypeScript Version

Overview

Midori is a Discord bot developed using TypeScript and Discord.js. Currently, the bot offers a greeting message and can send messages to the Stable Diffusion API when prompted. The primary functionality includes generating and posting images to Discord.

Table of Contents

Requirements

  • Node.js
  • TypeScript

Environment Variables

You'll need to set up some environment variables for the bot to work correctly. An example .env-sample file is provided in the repository.

  1. Create a discord bot at the Discord Developer Portal.
  2. Create an account at Stable Diffusion.
  3. Grab your Discord client ID and secret and your bot token and add them to the .env file.
  4. Grab your Stable Diffusion API key and add it to the .env file.
  5. Adjust the links if needed (e.g. if you want to use a different API version) but as of October 2023, the links are very up to date.

You should be good to go. Further details on the configuration can be found in the Configuration section.

Features

  • Diffuse: A feature that allows you to generate images from text and post them to Discord using the Stable Diffusion API.
  • Help: Provides help documentation for the bot's commands.
  • Setup: Sets up the bot for your server.
  • Utils: Various utility functions to make life easier for the developer.

Commands

  • /diffuse [options]: Uses the Stable Diffusion API to convert text to an image and post it to the current channel.
  • /help: Shows the currently implemented functions.

Code Structure

Coding Standards

Prerequisites

  • Node.js (version 18.18.x or higher)
  • npm (version 9.8.0 or higher)

Installation

  1. Clone the repository:

    git clone https://github.com/soulwax/Midori.git
  2. Navigate to the project directory:

    cd Midori
  3. Install dependencies:

    npm install

Usage

To run the application, execute:

npm start

Configuration

  1. Copy .env-sample to .env:

    cp .env-sample .env
  2. Edit .env to include your specific configuration. The following environment variables can be set:

  • DISCORD_CLIENT_ID: Your Discord client ID.
  • DISCORD_CLIENT_SECRET: Your Discord client secret.
  • DISCORD_TOKEN: Your Discord bot token.
  • STABLE_DIFFUSION_API_KEY: Your API key for Stable Diffusion API.
  • GENERAL_CHANNEL_ID: Currently unused but one could limit the bot to post only there.
  • TEXT_TO_IMAGE_API_URL: The URL of the Stable Diffusion API for Text to Image.
  • IMAGE_TO_IMAGE_API_URL: The URL of the Stable Diffusion API for Image to Image.

Development

Typescript Watch, Debugging and Linting

This project uses ESLint for linting. To run the linter, execute:

npm run lint

During development, you should run npm run watch to compile on the fly while you're working on the code.

Provided the correct use of the .vscode/launch.json file, you can debug the code and react to changes immediately while watching is running, without having to restart the bot all the time. This is especially useful when working on the bot's commands.

Formatting

This project uses Prettier for code formatting. To format the code, execute: Current rules can be seen in the .prettierrc file.

Testing

The project is currently tested manually. Automated testing will be implemented in the future. Pull requests are welcome.

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests.

License

This project is licensed under the GPL-3.0 License.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published