Thanks to visit codestin.com
Credit goes to github.com

Skip to content

gfmota/hive

 
 

Repository files navigation

Hive

Hivegame is a free online hive game server focused mostly on realtime gameplay and ease of use.

It is written in rust nightly and relies on the Leptos framework. Pure hive logic is inside the engine workspace.

It also inclides Hive-hydra, an application to integrate Hivegame with any UHP (Universal Hive Protocol) AIs.

Development

Prerequisites (skip if using Nix)

1. Setup the Rust Toolchain

  • Install the Rust toolchain.
  • Set the default toolchain to nightly from the project root:
rustup override set nightly
  • Alternatively set the default toolchain to nightly globally:
rustup default nightly
  • Add the WebAssembly target:
rustup target add wasm32-unknown-unknown

2. Install Leptos

cargo install cargo-leptos

3. Install and Setup PostgreSQL

  • Follow the installation instructions for your OS (example for Arch Linux).
  • Edit hba.conf to host all all local 127.0.0.1/32 trust (to allow passwordless login).
  • With PostgreSQL running, create a database hive-local and a user hive-dev as the owner:
sudo -u postgres createuser hive-dev && sudo -u postgres createdb -O hive-dev hive-local

Manual Setup (Without Nix)

  1. Install Diesel CLI with PostgreSQL support
cargo install diesel_cli --no-default-features --features postgres
  1. Install Leptos Formatter
cargo install leptosfmt
  1. Run Database Migrations
  • From the project root, navigate to db and run migrations:
cd db && diesel migration run && cd ..
  1. Run the Project
  • The watch command will recompile your code when files change and serve it on localhost::3000, static changes inside the view! macro won't cause a recompile if running with the --hot-reload flag
cargo leptos watch --hot-reload
  1. Before Making a Pull Request please clippy and format your code
cargo clippy --fix --all-features && leptosfmt apis -q && cargo fmt

Alternative to the manual setup use Nix

  1. Install Nix or just run:
curl -L https://nixos.org/nix/install | sh -s -- --daemon
  • Add these experimental features to your nix config (/etc/nix/nix.conf)
experimental-features = nix-command flakes
  1. Start the development shell
nix develop -c $SHELL
  1. Init and Start the PostgreSQL DB
pg-start
  1. Now start the server
migration run
server
  1. Start Hive-hydra to play with Bots

You need to setup bot users in Hive. See hive-hydra/hive-hydra.yaml

hive-hydra
  1. Stop PostgreSQL
pg-stop
  1. (Optional) Setup direnv
  2. Before committing code please run
format

Docker Development

Ensure docker is installed on your machine. You can run the following command to start the server and database:

docker compose up --build -d

This command downloads and installs the required dependencies. The first time you run this command, it may take a few minutes to complete.

# to stop docker compose
docker compose down

# if you have already built the image, you can save some time by running without the build flag:
docker compose up -d

This will create a database, apply migrations and run the app on localhost:3000.

Once the containers are up, follow the app logs to watch cargo-leptos compile and see when the server is actually serving:

docker compose logs -f app

This shows the incremental build output and prints when the server binds to the port.

Troubleshooting

If you get an error of the form

 it looks like the Rust project used to create this Wasm file was linked against
 version of wasm-bindgen that uses a different bindgen format than this binary:
 
   rust Wasm file schema version: 0.2.93
      this binary schema version: 0.2.95
 

That means that the Cargo.lock file was built with a different version of cargo-leptos than your current one. You have two options to fix this. Either update cargo-leptos as the lock file was probably created by a newer version than you have or delete the lock file.

License

This source code with the exception of the graphics is licensed under the GNU Affero General Public License 3 license found in the LICENSE.md file in the root directory of this project. The official graphics for Hive are owned by Gen42 and may not be used without prior written consent.

About

hivegame.com - (ad)free, open-source hive server and engine

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 96.4%
  • Python 2.2%
  • Shell 0.4%
  • Nix 0.3%
  • TypeScript 0.2%
  • Dockerfile 0.2%
  • Other 0.3%