Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jaller94/boat-racing-404

My 2020 game for the js13kGames jam. Look at the `submission` branch for the state submitted before the deadline.
https://github.com/jaller94/boat-racing-404

game game-2d webapp

Last synced: 8 days ago
JSON representation

My 2020 game for the js13kGames jam. Look at the `submission` branch for the state submitted before the deadline.

Awesome Lists containing this project

README

        

# Boat racing 405

This game was started as part of the [js13kGames Competition](http://js13kgames.com/) 2020.

You can play the improved game here: https://boat-racing-405.herokuapp.com/

Invite some friends to play the game with you! There are currently no bots.

## Submission version 404

**If you want to rate the game, please review this version.** It represents the state before the submission deadline on 2020-09-13.

Send the link to some friends and press 'Restart game'.

Deployed version: https://boat-racing-404.herokuapp.com/

Submission page: https://js13kgames.com/entries/boat-racing-404

Source code: https://github.com/jaller94/boat-racing-404/tree/submission

## Install

Extract the files and install the third party libraries with `npm`.

npm install

## Runinng

You can run the server locally with the following command:

npm run start:dev

You can reach the test server at [http://localhost:3000](http://localhost:3000)

The dev server uses `nodemon` to auto restart when you change some source file. If you want to pass some parameter to it, just add an `--` after `start:dev`. An example:

npm run start:dev -- --inspect

## Code structure

All your code must be in the `public` folder. Put your server side code into the `server.js` file. The `shared.js` file is loaded at the begining of the `server.js` file. You can also use this code on the client side.

The `server.js` is a standard Node.js module. You can use the following structure to create new [Express](https://expressjs.com/) routes or [Socket.io](https://socket.io/) connection handler.

module.exports = {
// Express route to /hello
hello => (req, res) { ... }
// Socket.io connection event handler
io => (socket) { ... }
}

## Persistent storage

The server category entries can use 13kByte persistent storage. The key and value size also counts into the limit!

The storage uses SQL database to save the key/value pairs. By default it's SQLite but on Heroku you have to use the Postgres add-on!

In the `server.js` file you can access the `storage` interface. The API documentation is inside the [lib](./lib/) folder.

## Deploy to Heroku

This game can be hosted on [Heroku](https://www.heroku.com/). You can either use free or paid plan.

1. Push your files to your GitHub repository
2. Create new WebApp on heroku
3. Add Heroku Postgres add-on (optional)
4. Connect your WebApp with the GitHub repository
5. Deploy your code

You can find more information about the platform on the [Heroku Dev Center](https://devcenter.heroku.com/) site.

## Server category rules

* Sandbox server
- You can find the official sandbox server at [https://github.com/js13kGames/js13kserver](https://github.com/js13kGames/js13kserver).

* Package size still below 13 kB
- Game package will contain all the game code and assets, for the client and the server.
- That also means you must not use the server database to store extra code or assets, that was not created by its users. If your game needs to seed the DB, your 13k code must do it.

* Sandboxed environment
- Your game will run in a node.js based sandbox environment. That means you will not really use node. You cannot require modules and your own modules shipped by your 13k pack.

* Do not leak the sandbox
- This is not a hacking competition. This is a way to help the competition admins, the site persistence, and you. Do not touch the `procfile` and the skeleton code.

* Socket.io client lib
- You can use it. Simply add `` to your HTML and that will be loaded. No server configuration will be needed. The sandbox already did it.

* Google's free STUN servers are the only allowed external services:
* stun.l.google.com:19302
* stun1.l.google.com:19302
* stun2.l.google.com:19302
* stun3.l.google.com:19302
* stun4.l.google.com:19302

* Can I test the sandbox before submitting?
- Yes, you can and you must! Installing and getting it running is simple. Visit the project page at [https://github.com/js13kGames/js13kserver](https://github.com/js13kGames/js13kserver).

* Is there any example? How do I develop my game using the sandbox server?
- There's a simple "Rock, Paper, Scissors" example in the public folder.

* I have more questions!
- Feel free to send them to [[email protected]](mailto:[email protected]).

## FAQ

* Can I minify the server side code?
- Yes, but you have to keep the readable code also.

* Can I add more npm packages?
- Yes, but you cannot use them in your game code.

* What files count in the 13kb limit?
- All files in the `public` folder.

* Can I deploy new code after I submited the entry?
- Yes, but you have to resubmit your entry on the site also.

* Can I modify the `procfile` or the skeleton code?
- No