Files
EpinelPS/README.md
2024-07-03 15:36:13 -04:00

1.7 KiB

nikke-server

Private/local server for Nikke. NOTE: This project is in a very early state.

Usage

First, build and run nksrv project. Next, open libsodium-1.0.18-RELEASE/libsodium.sln and build that as well. Ignore the failed tests as the encryption public key was hardcoded.

After that, add the following to your C:\Windows\System32\hosts or /etc/hosts file to use the local server:

127.0.0.1 cloud.nikke-kr.com
127.0.0.1 global-lobby.nikke-kr.com
127.0.0.1 aws-na-dr.intlgame.com
127.0.0.1 sg-vas.intlgame.com
127.0.0.1 aws-na.intlgame.com
127.0.0.1 common-web.intlgame.com
127.0.0.1 li-sg.intlgame.com
127.0.0.1 data-aws-na.intlgame.com
255.255.221.21 sentry.io

Run generate_ssl_cert.sh in WSL or linux to generate SSL certificates. Make sure to trust myCA.pfx

As Nikke encrypts packet data, you also need to replace C:\NIKKE\NIKKE\game\nikke_Data\Plugins\x86_64\sodium.dll from the one you built.

NOTE: Make sure to undo these modifications (especially change back sodium.dll) to play on the offical servers.

After doing the following steps, you can register an account in the launcher (enter anything into email verification code section), and play like normal.

Progress

Stage, character, and story information is saved and works, as well as player nickname. TODO: Gacha system, reward system (works but does not show in UI), xp system, sim room, outpost, etc TODO: Create a custom launcher that allows switching between offical/local server easily.

TODO: Provide screenshots

Contributing

Server code structure:

nksrv/LobbyServer: Handles save data.

nksrv/IntlServer: Provides Launcher APIs and authentication

nksrv/Protos: Google protobuf definition files

DataFixupUtil: Utility to parse packets from server/client