Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/igolaizola/bulkai
AI image generation in bulk automatically
https://github.com/igolaizola/bulkai
automation bluewillow bulk golang midjourney
Last synced: 4 days ago
JSON representation
AI image generation in bulk automatically
- Host: GitHub
- URL: https://github.com/igolaizola/bulkai
- Owner: igolaizola
- License: mit
- Created: 2023-02-12T21:02:22.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-18T22:56:22.000Z (about 1 month ago)
- Last Synced: 2025-01-08T15:14:01.244Z (18 days ago)
- Topics: automation, bluewillow, bulk, golang, midjourney
- Language: Go
- Homepage:
- Size: 7.98 MB
- Stars: 206
- Watchers: 13
- Forks: 42
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# bulkai đ¤đ¨
**bulkai** is a tool to generate AI images in bulk
> đĸ Connect with us! Join our Telegram group for support and collaboration: [t.me/igohub](https://t.me/igohub)
> [!TIP]
>
> ## đ Looking for a No-Code Solution?
>
> **[Midjourney Automation Actor](https://apify.com/igolaizola/midjourney-automation)** - all the power of bulkai with zero setup!
>
> - đ¯ No CLI or technical setup required
> - đĨī¸ Simple web interface
> - đ Automatic image generation & upscaling
> - đ Concurrent job processing
> - đ Built-in image gallery
> - âī¸ Cloud-based - run from anywhere
>
> Starting at $19/month. Perfect for users who want to skip the technical setup and get straight to generating images.
>
> [Get Started with Midjourney Automation â](https://apify.com/igolaizola/midjourney-automation)## đ Features
**bulkai** works with the following AI image generators:
- Midjourney
- Bluewillow**bulkai** automates the following tasks:
- Send prompts to the AI
- Upscale the generated images
- Or crop the preview images if upscale is disabled
- Optionally, generate variations of the generated images
- Download the generated images
- Create thumbnails
- Generate a HTML album page with the generated images## đĻ Installation
You can use the golang binary to install **bulkai**:
```bash
go install github.com/igolaizola/bulkai/cmd/bulkai@latest
```Or you can download the binary from the [releases](https://github.com/igolaizola/bulkai/releases)
## đšī¸ Usage
### 1. Create session (only for the first time)
You first need to create a session file with the discord credentials and other information retrieved from your browser.
**bulkai** needs this to:- Be able to login to Discord
- Mimic the browser and avoid being detected as a botUse the `bulkai create-session` command to create the session file.
It will open a chrome window and you will need to login to Discord.```bash
bulkai create-session
```### 2. Configure settings
You can configure different settings.
See the parameters section to see all available options: [Parameters](#parameters)Using a configuration file in YAML format:
```bash
bulkai generate --config bulkai.yaml
```bulkai.yaml
```yaml
bot: midjourney
album: cute-animals
download: true
upscale: true
variation: false
thumbnail: true
suffix: " --ar 3:2"
prompt:
- cute-animals-1.txt
- cute-animals-2.txt
- cute monkey dancing on a tree
```### 2. Launch
Use the `bulkai generate` command to launch the generation.
Images will be downloaded to the album name in the output directory specified in the configuration file.
You will be able to see the progress in the console.
This task can take a long time depending on the number of images to generate.```bash
bulkai generate
```You can press `Ctrl+C` to stop the generation.
If you want to resume the generation, just press launch the command again using the same settings and album name.
Prompt field will be ignored and the prompts will be loaded from the album.## đ ī¸ Parameters
Here is a list of all the parameters available to run the image generation.
- `bot` (string): Name of the bot to use.
Available options are: `midjourney` and `bluewillow`. (required)
- `download` (bool): Download the generated images. (default: `true`)
- `upscale` (bool): Upscale the generated images. (default: `true`)
If you disable this the generation will be much faster.
It will directly use the preview images generated by the AI.
In midjourney for example, the preview images are 256x256.
- `variation` (bool): Generate variations of the generated images. (default: `false`)
This will generate 4 extra variations of each prompt.
The generation will be much slower.
- `thumbnail` (bool): Generate thumbnails of the generated images. (default: `true`)
This operation is done locally, it will improve the performance of the HTML page.
- `html` (bool): Generate HTML files to show and link the generated images. (default: `true`)
- `suffix` (string): Suffix to add to all prompts. (optional)
- `prefix` (string): Prefix to add to all prompts. (optional)
- `prompt` (list): List of prompts to use. (required)
If you want include prompts from a file, just write the path to the file.
- `album` (string): Name of the album. (optional, but recommended)
If unset a time based name will be used.
- `output` (string): Path to the output directory. (default: `./output`)
- `session` (string): Path to the session file. (default: `./session.json`)
- `channel` (string): ID of the channel to use in the form `guild-id/channel-id`. (optional)
You can obtain it from the URL of the channel in discord web.
If unset the DM chat with the bot will be used.
- `proxy` (string): Proxy to use in HTTP calls. (optional)
- `concurrency` (int): How many prompts can be running at the same time. (optional)
If unset the maximum for the bot will be used.
- `wait` (duration): Time to wait between prompts, for example `5s`. (optional)
There is already a rate limit implemented to avoid sending too many requests to discord.
- `midjourney-cdn` (bool): Use Midjourney CDN for URLs instead of Discord CDN URLs. (default: `false`)
- `debug` (bool): Enable debug mode. (default: `false`)## â FAQ
### Do I need to generate a new session every time I want to use use **bulkai**?
No, you only need to generate a new session if you want to use a different account.
### Do I need to enable relaxed mode?
It is up to you to use relaxed or fast mode.
Just keep in mind that if you use fast mode with a lot of prompts, you may consume your quota very quickly.### I'm getting `couldn't find dm channel for bot` error
You must manually join the discord server of the bot you want to use.
Then you have to open a DM chat with the bot.
Alternatively, you can specify the channel to use in the form `guild/channel`.
The bot must be available in the channel you specify.## â ī¸ Disclaimer
The automation of User Discord accounts also known as self-bots is a violation of Discord Terms of Service & Community guidelines and will result in your account(s) being terminated.
The automation of Midjourney and Bluewillow accounts is also a violation of their Terms of Service and will result in your account(s) being terminated.
Read about Discord, Midjourney and Bluewillow Terms of Service and Community Guidelines
**bulkai** was written as a proof of concept and the code has been released for educational purposes only.
The authors are released of any liabilities which your usage may entail.## đ Support
If you have found my code helpful, please give the repository a star â
Additionally, if you would like to support my late-night coding efforts and the coffee that keeps me going, I would greatly appreciate a donation.
You can invite me for a coffee at ko-fi (0% fees):
[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/igolaizola)
Or at buymeacoffee:
[![buymeacoffee](https://user-images.githubusercontent.com/11333576/223217083-123c2c53-6ab8-4ea8-a2c8-c6cb5d08e8d2.png)](https://buymeacoffee.com/igolaizola)
Donate to my PayPal:
[paypal.me/igolaizola](https://www.paypal.me/igolaizola)
Sponsor me on GitHub:
[github.com/sponsors/igolaizola](https://github.com/sponsors/igolaizola)
Or donate to any of my crypto addresses:
- BTC `bc1qvuyrqwhml65adlu0j6l59mpfeez8ahdmm6t3ge`
- ETH `0x960a7a9cdba245c106F729170693C0BaE8b2fdeD`
- USDT (TRC20) `TD35PTZhsvWmR5gB12cVLtJwZtTv1nroDU`
- USDC (BEP20) / BUSD (BEP20) `0x960a7a9cdba245c106F729170693C0BaE8b2fdeD`
- Monero `41yc4R9d9iZMePe47VbfameDWASYrVcjoZJhJHFaK7DM3F2F41HmcygCrnLptS4hkiJARCwQcWbkW9k1z1xQtGSCAu3A7V4`Thanks for your support!
## đ Resources
Some of the resources I used to create this project:
- [bwmarrin/discordgo](https://github.com/bwmarrin/discordgo) to retrieve events from Discord.
- [Danny-Dasilva/CycleTLS](https://github.com/Danny-Dasilva/CycleTLS) to mimic the browser and avoid being detected as a bot.