Home

Awesome

WebQuake

WebQuake is an HTML5 WebGL port of the game Quake by id Software.

Online demo by SpiritQuaddicted.

Installing and running

Follow these steps to install WebQuake:

  1. Install a web server with HTTP 1.1 Range support. The project was developed and tested on Abyss Web Server on Windows, so it's guaranteed to work on it.
  2. Download entire contents of the Client folder (index.htm and WebQuake/ folder) from the Code tab and put it somewhere on your server.
  3. Get Quake resource files. The demo version containing only the first episode is enough.
  4. Copy the id1 folder from the Quake folder to the folder where you put index.htm.
  5. If you have Quake mission packs, repeat step 4 for hipnotic and/or rogue folders.
  6. If you're running a system with case-sensitive names (such as Linux), make sure that all game files except for code files have lowercase names.

To launch WebQuake, go to the WebQuake directory on your server in your browser.

To launch the game with command line arguments, add ? after the address and put the arguments after it in the same format as you use for Quake.

For Scourge of Armagon, add -hipnotic command line argument. For Dissolution of Eternity, add -rogue.

To launch mods, copy the mod folder into the folder containing index.htm and add -game MOD_NAME_HERE command line argument. Ensure step 6 of the installing instructions for the mod folder.

To use browser hotkeys (such as F5, Ctrl+T and Ctrl+W), click the address bar, and when you're done, click the game.

Playing multiplayer

If you want to join a multiplayer game, do one of the following steps, go to Multiplayer menu in the main menu, type the IP in "Join game at" field and press Enter, or type connect ws://ip:port in the console.

You can also play WebQuake games in a native Quake (not QuakeWorld) client such as WinQuake or GLQuake. Choose TCP/IP in the Join Game menu.

You cannot join multiplayer games if the client is installed on https:// protocol, however.

If you want to create a server, first, install the dedicated server by completing the following steps.

  1. Install Node.js.
  2. Download the "Server" folder from the repository.
  3. Put Quake resource files into the downloaded Server folder.
  4. Open Node.js command prompt.
  5. Go (cd) to the Server folder.
  6. Type npm install websocket (for more information, see Worlize/WebSocket-Node repository).

Then, to launch a server, open Node.js command prompt, go to the Server folder and type node WebQDS.js.

To change maximum number of players, use -maxplayers command line argument.

Remote console

To execute console commands on the server from the client or the web, set rcon_password in the server console. If you have spaces in the password, surround it with quotes.

Don't tell the password to anyone except for the server admins. Don't put the password in the command line, as everybody on the web can see your command line on your server's /rule_info page!

Then, you have 4 ways to execute server commands:

Server info API

You can retrieve some server information in JSON format by going to special addresses on your server IP.

Adding game music

To add music to WebQuake, you need to get the music off the Quake CD and convert it into .ogg format (Audacity is great for this).

The .ogg files should be called quake##.ogg, where ## is CD track number minus 1 with trailing 0, so the main theme is named quake01.ogg and the last track on the Quake disc is quake10.ogg.

Then you should configure the server to return audio/ogg MIME type for .ogg files.

After that, create "media" folder in the "id1" folder (or, for the mission pack music, "hipnotic" or "rogue") and put the .ogg files into it.

Browser support

The port has been tested on the following browsers (results from 2013):

Mouse support is currently available only on Chrome and Firefox. Stereo positional audio is supported on Chrome and Safari.

Tips

If the sound randomly doesn't play, go to console (press ~ or Options > Go to console in main menu), type stopsound and press Enter.

You can delete saved games by pressing Del in the load or save menus. This only works for the saved games created in WebQuake.

Contributing

If you want to contribute to WebQuake, feel free to fork the project and make a pull request. Pull requests and issues will be reviewed by the developer.