Start contributing to airi
Hello! Thank you for your interest in contributing to this project. This guide will help you get started.
Windows setup
-
Open PowerShell
-
Install
scoop
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser Invoke-RestMethod -Uri https://get.scoop.sh | Invoke-Expression
-
Install
git
,node
throughscoop
scoop install git nodejs
-
Install
pnpm
throughcorepack
corepack enable corepack prepare pnpm@latest --activate
macOS setup
-
Open Terminal, (or iTerm2, Ghostty, Kitty, etc.)
-
Install
git
,node
throughbrew
brew install git node
-
Install
pnpm
throughcorepack
corepack enable corepack prepare pnpm@latest --activate
Linux setup
-
Open Terminal
-
Follow nodesource/distributions: NodeSource Node.js Binary Distributions to install
node
-
Follow Git to install
git
-
Install
pnpm
throughcorepack
corepack enable corepack prepare pnpm@latest --activate
Warning
If you haven't clone this repository, skip this section.
Make sure your local repository is up to date with the upstream repository:
git fetch -all
git checkout main
git pull upstream main --rebase
If you have a working branch, to make your branch up to date with the upstream repository:
git checkout <your-branch-name>
git rebase main
Click on the Fork button on the top right corner of the moeru-ai/airi page.
git clone https://github.com/<your-github-username>/airi.git
cd airi
git checkout -b <your-branch-name>
corepack enable
pnpm install
Note
We would recommend to install @antfu/ni to make your script simpler.
corepack enable
npm i -g @antfu/ni
Once installed, you can
- use
ni
forpnpm install
,npm install
andyarn install
. - use
nr
forpnpm run
,npm run
andyarn run
.
You don't need to care about the package manager, ni
will help you choose the right one.
pnpm -F @proj-airi/docs... --parallel dev
Stage web (Frontend for airi.moeru.ai, or airi.ayaka.io)
pnpm -F @proj-airi/stage-web... --parallel dev
pnpm -F @proj-airi/stage-tamagotchi... --parallel dev
A Postgres database is required.
cd services/telegram-bot
docker compose up -d
Configure .env
cp .env .env.local
Edit the credentials in .env.local
.
Migrate the database
pnpm -F @proj-airi/telegram-bot db:generate
pnpm -F @proj-airi/telegram-bot db:push
Generate bundles for Monorepo packages
pnpm packages:stub
Run the bot
pnpm -F @proj-airi/telegram-bot start
cd services/discord-bot
Configure .env
cp .env .env.local
Edit the credentials in .env.local
.
Generate bundles for Monorepo packages
pnpm packages:stub
Run the bot
pnpm -F @proj-airi/discord-bot start
cd services/minecraft
Start a Minecraft client, export your world with desired port, and fill-in the port number in .env.local
.
Configure .env
cp .env .env.local
Edit the credentials in .env.local
.
Generate bundles for Monorepo packages
pnpm packages:stub
Run the bot
pnpm -F @proj-airi/minecraft-bot start
Caution
Please make sure lint (static checkers) and TypeScript compilers are satisfied:
pnpm packages:stub && pnpm lint && pnpm typecheck
Note
If you have @antfu/ni installed, you can use nr
to run the commands:
nr packages:stub && nr lint && nr typecheck
git add .
git commit -m "<your-commit-message>"
git push origin <your-branch-name> -u
You should be able to browse the branch on your fork repository.
Note
If this is your first time contributing with this project, you need to add the upstream repository too:
git remote add upstream https://github.com/moeru-ai/airi.git
Navigate to moeru-ai/airi page, click on the Pull requests tab, and click on the New pull request button, click on the Compare across forks link, and select your fork repository.
Review the changes, and click on the Create pull request button.
Congratulations! You made your first contribution to this project. You can now wait for the maintainers to review your pull request.