A server software reimplementation for a certain anime game.
Go to file
2022-04-24 21:54:01 +08:00
.github/workflows Workflow: Switch from Temurin 8 to 16 2022-04-22 22:53:54 -04:00
data Fix Ayaka and weapon banner titles not showing up 2022-04-21 14:01:51 +07:00
gradle/wrapper Update gradle + Work gacha reload (gs broken atm) 2022-04-20 16:05:53 +08:00
Grasscutter-Protos@dd17415b71 Update Grasscutter-Protos 2022-04-23 03:32:18 -07:00
keys Initial commit 2022-04-17 05:43:07 -07:00
lib Initial commit 2022-04-17 05:43:07 -07:00
src/main Merge pull request #175 from omg-xtao/suicide 2022-04-24 00:03:21 -07:00
.gitignore gitignore'd protos 2022-04-24 06:00:27 +07:00
.gitmodules Protos 2022-04-19 10:26:31 -07:00
build.gradle why is Account#onLoad THE DAMN REASON FOR HOURS OF TESTING 2022-04-21 02:07:05 -04:00
gradlew Make gradlew executable 2022-04-22 22:53:54 -04:00
gradlew.bat Initial commit 2022-04-17 05:43:07 -07:00
keystore.p12 Update the keystore 2022-04-22 22:34:00 -04:00
LICENSE Initial commit 2022-04-17 05:43:07 -07:00
proxy_config.py Add port & SSL options to proxy script 2022-04-21 21:41:07 +08:00
proxy.py Update proxy.py 2022-04-22 22:00:13 +08:00
README.md Update README.md 2022-04-24 21:54:01 +08:00
settings.gradle Initial commit 2022-04-17 05:43:07 -07:00
start_config.cmd Allow configuration overrides 2022-04-22 11:34:22 +08:00
start.cmd Merge branch 'development' into stable 2022-04-23 16:23:15 +08:00

Grasscutter

Documention GitHub release (latest by date) GitHub GitHub last commit GitHub Workflow Status
Discord - Grasscutter

Documentation: Grasscutter Wiki
Note: For support please join the Discord server.

Current features

  • Logging in
  • Combat
  • Friends list
  • Teleportation
  • Gacha system
  • Co-op partially work
  • Spawning monsters via console
  • Inventory features (recieving items/characters, upgrading items/characters, etc)

Quick setup guide

Requirements

  • Java - 8u202 (mirror link since Oracle required an account to download old builds)

    Note: If you just want to run it, then jre is fine

  • MongoDB (recommended 4.0+)

  • Proxy daemon: mitmproxy (mitmdump, recommended), Fiddler Classic, etc.

Running

Note: If you update from an older version, delete config.json for regeneration

  1. Get grasscutter.jar
  2. Create a resources folder in the directory where grasscutter.jar is located and bring your BinOutput and ExcelBinOutput folders into it (Check the wiki for more details how to get those.)
  3. Run Grasscutter with java -jar grasscutter.jar. Make sure mongodb service is running as well.

Connecting with the client

½. Create an account using server console command.

  1. Redirect traffic: (choose one)

    • mitmdump: mitmdump -s proxy.py -k

      Trust CA certificate:

      **Note:**The CA certificate is usually stored in % USERPROFILE%\ .mitmproxy, or you can download it from http://mitm.it

      Double click for install or ...

      • Via command line

        certutil -addstore root %USERPROFILE%\.mitmproxy\mitmproxy-ca-cert.cer
        
    • Fiddler Classic: Run Fiddler Classic, turn on Decrypt https traffic in setting and change the default port there (Tools -> Options -> Connections) to anything other than 8888, and load this script.

    • Hosts file

  2. Set network proxy to 127.0.0.1:8080 or the proxy port you specified.

you can also use run.cmd to start servers and proxy daemons automatically

Commands

Commands Usage Permission node Availability description Alias
account account <create|delete> [uid] Server only Creates an account with the specified username and the in-game uid for that account. The uid will be auto generated if not set.
broadcast broadcast server.broadcast Both side Sends a message to all the players. b
changescene changescene player.changescene Client only Switch scenes by scene ID. scene
clearartifacts clearartifacts player.clearartifacts Client only Deletes all unequipped and unlocked level 0 artifacts, including yellow rarity ones from your inventory. clearart
clearweapons clearweapons player.clearweapons Client only Deletes all unequipped and unlocked weapons, including yellow rarity ones from your inventory. clearwpns
drop drop <itemID|itemName> [amount] server.drop Client only Drops an item around you. d dropitem
give give [player] <itemId|itemName> [amount] [level] player.give Both side Gives item(s) to you or the specified player. g item giveitem
givechar givechar [level] player.givechar Both side Gives the player a specified character. givec
godmode godmode [uid] player.godmode Client only Prevents you from taking damage.
heal heal player.heal Client only Heal all characters in your current team. h
help help [command] Both side Sends the help message or shows information about a specified command.
kick kick server.kick Both side Kicks the specified player from the server. (WIP) k
killall killall [playerUid] [sceneId] server.killall Both side Kill all entities in the current scene or specified scene of the corresponding player.
list list Both side List online players.
permission permission <add|remove> * Both side Grants or removes a permission for a user.
position position Client only Get coordinates. pos
reload reload server.reload Both side Reload server config
resetconst resetconst [all] player.resetconstellation Client only Resets the constellation level on your current active character, will need to relog after using the command to see any changes. resetconstellation
restart Both side Restarts the current session
say say server.sendmessage Both side Sends a message to a player as the server sendservmsg sendservermessage sendmessage
setfetterlevel setfetterlevel player.setfetterlevel Client only Sets your fetter level for your current active character setfetterlvl
setstats setstats player.setstats Client only Set fight property for your current active character stats
setworldlevel setworldlevel player.setworldlevel Client only Sets your world level (Relog to see proper effects) setworldlvl
spawn spanw <entityID|entityName> [level] [amount] server.spawn Client only Spawns an entity near you
stop stop server.stop Both side Stops the server
talent talent player.settalent Client only Set talent level for your current active character
teleport teleport player.teleport Client only Change the player's position. tp
weather weather player.weather Client only Changes the weather w

Bonus

When you want to teleport to somewhere, use the ingame marking function on Map, click Confirm. You will see your character falling from a very high destination, exact location that you marked.

Building

Grasscutter uses Gradle to handle dependencies & building.

Requirements:

  • Java Development Kits - 8u202
  • Git

Windows

git clone https://github.com/Grasscutters/Grasscutter.git
cd Grasscutter
.\gradlew.bat # Setting up environments
.\gradlew jar # Compile

Linux

git clone https://github.com/Grasscutters/Grasscutter.git
cd Grasscutter
chmod +x gradlew
./gradlew jar # Compile

You can find the output jar in the root of the project folder

Quick Troubleshooting

  • If compiling wasn't successful, please check your JDK installation (must be JDK 8 and validated JDK's bin PATH variable)
  • My client doesn't connect, doesn't login, 4206, etc... - Mostly your proxy daemon setup is the issue, if using Fiddler make sure it running on another port except 8888
  • Startup sequence: Mongodb > Grasscutter > Proxy daemon (mitmdump, fiddler, etc.) > Client