qwikgame is a system to help people find a rival to play their favorite (real-world) game at a convenient time and place. Players are able to rate each others ability to enable qwikgame to estimate the relative strength between new rivals. Care has been taken to provide a range privacy options for players. Players are able to add and maintain information about suitable venues to play a range of games from Chess to Squash.
You can use qwikgame for free at qwikgame.org
When you are keen for a game, you can invite other players to a match at your preferred venue and a range of times. Alternatively you can browse invitations from other players and accept one of their available times. Each invitation includes your qwikgame reputation and estimates of the relative strength of the other players. Once a match is confirmed, you are able to chat with your rival before meeting on time at the venue.
After a Match, you should rate your rivals ability as stronger, weaker or well matched. well matched indicates an enjoyable challenging match, regardless of who actually 'won'. YOu may also bolster the reputation of your rival by recognising good sportsmanship, regardless of who was the stronger player.
Typical setup might involve:
- linux on a virtual server
- nginx and lets-encrypt webserver
- psql database
- python3, django and gunicorn
qwikgame is written in html, css, python3, json, javascript, django and psql.
In qwikgame parlace; Matches are played between Rival Players at Venues.
Each registered player has a single xml file in the /player
directory.
A player registers by nominating a favorite game and venue, and an email address. The player is effectively registering that they are available to play Squash at the Milawa Courts (for example) and wish to be alerted when some-one else is keen to play. An email registration confirmation contains a link to the players home page and a cookie is set to maintain the user-login beyond a single session. If the user manually logs-out then another email can be requested with a new login link (ie traditional user passwords are replaced by persistent sessions and a simple password-reset email process).
The internal player ID (pid) is chosen by taking the sha256 hash of the email address. This has a number of advantages:
- The player ID will be unique because the email address will be unique
- Qwikgame can accept and use a sha256 hash to store anonymous player data
- A new email address can be linked to existing anonymous player data
A player must nominate:
- at least one favorite game/venue/time combination when they are available to play
- an email address as a unique ID and for notifications
A player may optionally nominate:
- one or more email addresses of known rivals and their relative ability
- an estimate of their own ability for one or more games in one or more geographic regions
- a nickname visible to other players
- a link to a social media page
Each game venue has a single xml file in the /venue
directory. This directory also contains a subdirectory for each game which contains symlinks back up to the xml files in the /venue
directory. This provides a straight-forward way to list the venues for a given game.
Players are able to add and maintain information about suitable venues to play each game including Name, Address, GPS location etc.
A unique Venue ID (vid) is constructed from the venue's name and address in the form: name|address|locality|state|country This is used as the XML file name which allows qwikgame to use rapid file-system tools to locate a venue without having to parse an XML file or utilize a database.
Match data is stored in the player xml file in the /player
directory.
When a player is keen for a match then they can nominate a game, a venue and a range of times over the next 48 hours. This will trigger invitations to be emailed to all other players who have registered a favorite for playing the game at the venue. The invitations contain the estimated relative ability, and reputation of the potential rival. The first player can then choose a rival from those who accept the invitation. After the match, the rivals can rate each other for behaviour and ability.
Each match has a current status: keen, invitation, accepted, confirmed, feedback, or cancelled.
The /html
directory contains html templates in the form:
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="UTF-8">
</head>
<body>
<h1>{hello}</h1>
<p>You have a game of [game] on [day] at [time]</p>
<h1>{pastRivals}</h1>
<div>
<div id='past-rivals' class='base json'>
[name] is a [parity] [game] player<br>
</repeat>
</div>
</body>
</html>
The process to construct a html page from a html template involves 3 steps:
- The html element with class='base' is replicated for each each data set
- Each [variable-key] is replaced by a value.
- Each {phrase-key} is replaced by a phrase in the users language.
Note: this implies that elements with class='base' may contain both [] and {}; and a value may also contain {}.
- The class='json' triggers a json update of the innerHTML of the parent
qwikgame supports multiple user languages. Translations are contained in /lang/translation.xml
in the form:
<?xml version="1.0"?>
<translation>
<language key="en" dir="ltr">English</language>
<language key="es" dir="ltr">Español</language>
<phrase key="hello">
<en>Hello</en>
<es>Hola</es>
</phrase>
</translation>
A call to translate.php
reads each html template in /html
; replaces each {phrase-key}; and writes the now language specific html template to a directory under /lang
(ie /lang/en
/lang/es
/lang/zh
etc).
A subsequet call to match.php
(for example) takes the appropriate language specific html template, processes the elements, populates the [variables] and then translates the {phrases}, before serving the page to the user.
qwikgame makes estimates of the parity (relative ability) of potential rivals based on feedback from past rivals (and initially the players own self-assessment). This is NOT based on a ranking or grading of players; it is relative assessment. Players can rate each other as well-matched, stronger, weaker, much-stronger or much-weaker. If two players have previously rated each other then their ratings are combined to estimate their relative ability (the players may not be in agreement). Otherwise, qwikgame uses the ratings of a common rival, if direct ratings are not available. More weight is given to more recent ratings; and a record is kept of the reliability of the ratings provided by each player (ie how closely they coincide with rating of their rivals).
php Class files are located in /class
- Qwik.php
- Defend.php Sanitize a web request before further php procesing.
- Hours.php The 24 hours in a day are represented as a bitfield.
- Html.php General code to complete a html document based on a html template with [variables] and {phrases}.
- Email.php
- Page.php General code to serve a html page including elements, [variables] and {phrases}.
- IndexPage.php
- InfoPage.php
- PlayerPage.php
- TranslatePage.php
- UploadPage.php
- VenuePage.php
- Logging.php general code to log messages to a file
- Match.php interface to Match data within a Player's xml data
- Node.php a Node within an Orb contains player ID, parity, reliability, date and a sub-orb.
- Orb.php an array of Nodes Objects used to estimate the parity of two players
- Player.php interface to the xml data of a player.
- Ranking.php represents and processes a ranked list of players.
- Translation.php translate general html templates into language specific html templates.
- Venue.php
Other important files include:
- qwik.css cascading style sheet
- qwik.js javascript
- translate.php translate general html templates into language specific html
General html templates prior to translation.
- html/account.html player account settings
- html/favourite.html player favorite game/venues
- html/friend.html player friends
- html/index.html homepage
- html/info.html user help and info
- html/match.html player matches
- html/upload.html upload player rankings
- html/venue.html venue details
- html/venues.html
language specific translation files
- lang/en/*.php english translation
- lang/es/*.php spanish translation
- lang/zh/*.php chinese translation
json
- json/timezone.php populate a select list with timezone options.
- json/venue-marks generate markers for a google map.