Code Monkey home page Code Monkey logo

client's Introduction

Brot-Client

Build LOC Go Version License

This repository contains our client for spe_ed, the game of the InformatiCup 2021. Our team placed third and won the award for the best github repository 🥳. A video about our solution is available here (German only)

Overview

In this README you find all the information you need to use our software. Navigate around with the table of contents. For more detailed information read the wiki or follow the links in the README. If you think some important information or feature is missing, feel free to open an issue. If you'd like to give us feedback directly feel free to mail us.

Installation

After completing this, you set up a spe_ed development server and you can run our client locally.

0. Prerequisites

Our software is written in Go. So you need an up-to-date go installation. You can get information on how to install Go on your computer here. At least version 1.15 is required.

This program uses the websocket library that can be found here: https://github.com/gorilla/websocket.

After installing Go, you can run go get github.com/gorilla/websocket to install the library.

1. Cloning the repository

Run git clone https://github.com/TeamBrot/client.git to clone the repository.

Run cd client to jump right into it.

2. Build

The client code is located in the client directory. Before building, go there by running cd client.

To build the code, run go build. In case of failure, check if you are in the right directory because the repository is also named client. If you change the code of the client make sure to run the build command.

3. Setting up the development server

To run the client you need a server, that implements the game API. If you got your own spe_ed server you can skip this step. Otherwise, you can use ours which we wrote for development purposes. You can find it here.

4. Running the Client

You can start the client by going into the client directory and then running ./client. Now the client tries to connect to our development server. If you get a connection established message you've succesfully setup our software 🥳

If you wish to connect to another server, set the URL environment variable accordingly. You find information about that here

./client runs the combi client. Other clients can be run with ./client -client <client>.

The following clients are available:

5. Connecting to other servers

To play on other servers, the environment variables URL, TIME_URL and KEY have to be set to the appropriate values.

For the official API of the competition, use these values:

URL="wss://msoll.de/spe_ed" TIME_URL="https://msoll.de/spe_ed_time" KEY="<key>"

If you connect the client to another server, you can watch the game in your browser under http://localhost:8081/

Docker

To build the docker image, run docker build . -t spe_ed.

To run the client container, run docker run -e URL="wss://msoll.de/spe_ed" -e TIME_URL="https://msoll.de/spe_ed_time" -e KEY="<key>" spe_ed.

Extensions

We built several extensions for our spe_ed client. For example several scripts that can run or visualize games.

Testing against other clients

Run ./test_internal.sh to start mutltiple games. This can be useful to test different parameters or to run statistical analytics.

You can stop the script by creating a file with the name stop at the root of the repository.

Just change the script for your purposes.

Testing on the official API

You can also run ./test_api.sh to play multiple games on the official without having to restart the client manually.

The default client is the combi client. You can change that by setting the variable client directly in the script.

Visualize games as videos

Prerequisites:

  • Python 3.9+
  • Pillow
  • ffmpeg

Run ./visualize.py <path to JSON-Log> to create a video from a JSON-Log. You typically find all log files under client/log. To see all command line options run ./visualize.py --help.

client's People

Contributors

jacob271 avatar rgwohlbold avatar sohn123 avatar

Stargazers

 avatar  avatar  avatar

Watchers

 avatar

Forkers

jonico

client's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.