+ FEATURES |
+ ----------+
+ - AUTO-MAINTENANCE
+ . Terms Of Service acceptance
+ DONE . print date of hard switch
+ DONE . TOS version
+ DONE . user TOS acceptance (db field)
+ DONE . show TOS ([show me later, yes, no]/[yes, no])
+ DONE . switch-off date
+ DONE . manage accept
+ DONE . manage refuse
+ DONE . show current TOS
+ DONE . disable user reason integer field and remove SUSPEND state (db, php)
+ DONE . fix tos layout
+ DONE . opt - download TOS
+ . opt - checkbox for anonimous users with message when not checked
+ . opt - button enabled when arrived to the bottom of the TOS only
+ . opt - check TOS version between config file and TOS file
+ DONE . show guarantee (/guar <login> command)
+ DONE . multi-language
+ DONE . command documentation
+ DONE . manage disagreeding users investigation
+ DONE . self guaranteed
+
+ . email validation
+ . account expiration
+
+
+ DONE - CONTINUE FEATURE
+ DONE . replace explicit strings with multilanguage array
+ DONE . add a php downloader with filtering on allowed requests
+ DONE . save points every game
+ DONE . modify points calculation to include order and mazzo
+ DONE . exclude not standard types from statistics
+ DONE . daily reports (1 for each active tournament)
+ DONE . monthly stats (for normal match only)
+ DONE . show current match ID when created
+ DONE . add info about continue to the info page
+ DONE . add command to continue
+ DONE . check consistency of the request
+ DONE . rearrange users and game status to continue the selected match
+ DONE . investigate user reordering ??
+
+ - WEBSOCKET TRANSPORT
+ . refactoring $enc attribute management
+ DONE . reintroduced $enc = 'plain' for websocket
+ DONE . fallback for not correct WS version
+ DONE . fini of ws stream
+ DONE . reactivate compression
+ DONE . fix xynt_test01
+ DONE M2: brisk working
+ DONE . manage multiport apache config
+ DONE . manage headers correctly in sac-a-push
+ DONE . manage transport.close method where required
+ DONE . xynt_stream: manage fallback to multiple ports
+ DONE . manage fini for ws
+ POST . server: manage input data from clients
+ POST . manage ping/pong (seems not required)
+
+ DONE . client (xynt_streaming.js)
+ DONE . server (transport.phh)
+
+ DONE M1: xynt_test01.php working
+
+
+ - improved S
+ . db update (add components, maybe single string)
+ . filter in index.php
+ . filter in index_wr.php
+
+ - prefs API:
+ . prefs_assign(content): assign json content as output var
+ . prefs_apply(prefs_new): apply new content to g_prefs and system
+ . prefs_load(content): load json content and apply to g_prefs and system
+
+ . prefs_update: update preferences temporarly
+ . prefs_save: save to the server the new prefs
+
+ - preferences (listen into preferences)
+ // js var, volatile server, (db server || cookie)
+ temporary: js var, volatile server
+ permanent: js var, volatile server, (db server || cookie)
+
+ . data from db OR, if missing, from cookies
+
+ . update values
+ . database change
+ . MANAGE NOT AUTH USERS
+
+ - preferences (with "modifiable S")
+ . Mod. S: new flag into database
+ . graph infrastructure
+ . new box to edit color
+
+ MAJOR |
+ -------+
+ - BUG: some connection to the named socket fails
+ - Not simultaneous more then one stream
+
+
+ MINOR |
+ -------+
+ WIP - try to be more antivirus-friendly
+ - multiple rows between games
+ - packetize and automatize php-ancillary and apache module
+ - DISABLED_TO_FIX: DNS access (perform blocking dns requests, must be fixed)
+
+
+ DONE |
+ ------+
+ DONE - temporarly server hung not reflected on user timeouts
+ DONE - timeouted users are still be able to sit down (only the first at the table is banned)
+ DONE - page still opened after the server restart
+ DONE - log_legal address fix
+ DONE - manage too fast reload in xynt-streaming
+ DONE - add xhr as transport layer and manage different streams better
+ TEST - BUG: pari + 72 non fa 4x ma attualmente fa 3x, da correggere
+ TEST - BUG: lurker are logged out (and remain a pending socket opened (look the spush log)
+ DONE - save/restore database
+ DONE - into the room local step remains -1
+ DONE - centralize all '<script ...' incapsulation to allow multiple transport system.
+ DONE - BUG: access with password from 2 diff browsers the second go in strange "page not found"
+ in the first tentative, the second works
+ DONE - BUG: access with password from 2 diff browsers place the first in a strict loop (the
+ problem was a call to a static parent method instead of the overrided child method,
+ substitute self:: with the dynamically get class::)
+ DONE - garbage management
+
+ DONE/FROZEN - problem with getpeer (HOSTADDR)
+
+ DONE - slow cards distribution
+ DONE - substr to mb_substr
+ DONE - parametrizations:
+ . parametrization of $DOCUMENT_ROOT var in brisk-spush.phh file
+ . parametrization of SITE_PREFIX(_LEN) define
+ . move the name of the named socket into the configuration file
+ DONE - manage and test cross forwarder between table and room
+ DONE - setcookie (for tables only and persist prefs)
+ DONE - images flickering on slow windows: try to poll stream every 300 ms (seems to be download problem)
+ DONE - database connection fails after a while, check close and try PGSQL_CONNECT_FORCE_NEW.
+ DONE - unneeded garbage_time.expired access
+ DONE - BUG: fast loop on stream index_rd_ifra page (js watchdog start without timeout corrupt counts)
+ DONE - BUG: logout failed (fixed with a garbage_collector wrapper at sac-a-push level
+ DONE - 404 wrong page management (remove directories redirections (es. brisk/))
+ DONE - configuration file management
+ DONE - app level keep-alive
+ DONE - index_wr other issues
+ DONE - from room to table
+ DONE - from table to room
+ DONE - chunked
+ DONE - bug: read from a not resource handle (already closed because a new socket substitute it)
+ DONE - partial write for normal page management
+ DONE - index_rd_ifra: last_clean issue
+ DONE - fwrite failed error management (select, buffer where store unsent data, and fwrite check and retry)
+ DONE - bug: after restart index_rd.php receive from prev clients a lot of req
+ DONE - index_wr.php::chat
+ DONE - index_wr.php::exit
+ DONE - index_rd.php porting
+ DONE - generic var management from internet
+ DONE - index.php auth part
+ ABRT - index_wr.php::reload - reload is js-only function
+ ABRT - keepalive management - not interesting for our purposes
+
+ BRISK4 (mammuth)
+ ======
+
+ - STEP MANAGEMENT VERIFY
+ Slim Paragraph
+ DONE - move the garbage timeout on file
+ DONE - in index_rd load all data only when required
+ - briskin5 alignment
+ DONE . extern del garb_timeout
+ DONE . user_load parameters verify
+ DONE . Bin5::load_data and Bin5::save_data refactoring with
+ data split
+ . move many function into "Bin5 class"
+ - garbaging of .step files
+
+ DB: - initial usage
+ DONE - configurabilità file o db
+ DONE - aggiornare le funz di gestione db in modo che prevedano anche il flag DISABLE
+ DONE - travasatore file to pg
+ DONE - travaso punteggi
+ DONE - memorizzazione nuovi i punteggi nel db
+ DONE - gestione classifiche in SQL
+ DONE - produrle
+ DONE - mostrarle
+
+ STEP 1.1
+ DONE - points archiver
+
+ STEP 1.2
+ DONE - partial usability if database go down.
+
+ STEP 1.5
+ - sistema di inserimento nuovi utenti (riversatore da form di inserimento)
+
+ STEP 2
+ - aggiornare le funz di gestione db in modo che prevedano anche il flag SUSPEND
+ - modifica password
+ - ripristino password
+
+ STEP 3
+ - comunicazioni di aggiornamento (stato salvato sul server)
+
+ DONE - var $G_base aggiunta per gestire include in include da path differenti
+
+ BRISK3 (trusty)
+ ======
+ DONE - donameter
+ DONE - G_donors
+ DONE (WOW!) - js object with infos
+ DONE - main logic at login (cookie check in index_rd.php; show_message and createCookie via snippets with block
+ to prevent fast reload)
+ DONE - cookie per non assillare e visualizz.
+ DONE - graphical donameter
+ WIP content (in conf.)
+
+ DONE - numero di tavoli auth-only nel .brisk-install
+ - isolation
+ TEST - ricalcolo delle persone in piedi quando si cambia modalità
+ DONE - se si e' in isolation non si può cambiare nick perdendo l' auth
+ DONE - non leggere le chat di quelli non autenticati (in isolation)
+ DONE - regole per passare alla modalita' (in piedi o ai tavoli autenticati)
+ DONE - treni non auth da nascondere
+ DONE - verso gli altri ??: uguale a prima