mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-10 05:26:10 +01:00
1c6d28633f
Supid bug generating keys from __FILE__ meant each release build (usually done in /tmp/$$, or on a travis server) had a new key and generated a new MQTT devID (and other stuff less frequently used.) Replace the keys with something that won't change, and as a temporary fix so the upgrade including this fix doesn't generate new keys use the most recent stored key matching the suffix the old keys will have had in common.
96 lines
3.1 KiB
C
96 lines
3.1 KiB
C
/* -*- compile-command: "make MEMDEBUG=TRUE -j5"; -*- */
|
|
/*
|
|
* Copyright 2000 - 2016 by Eric House (xwords@eehouse.org). All rights
|
|
* reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#ifndef _GAMESDB_H_
|
|
#define _GAMESDB_H_
|
|
|
|
#include <sqlite3.h>
|
|
#include <glib.h>
|
|
|
|
#include "main.h"
|
|
#include "comtypes.h"
|
|
|
|
typedef struct _GameInfo {
|
|
sqlite3_int64 rowid;
|
|
XP_UCHAR name[128];
|
|
XP_UCHAR room[128];
|
|
XP_UCHAR conn[128];
|
|
XP_UCHAR scores[128];
|
|
XP_UCHAR relayID[32];
|
|
#ifdef PLATFORM_GTK
|
|
GdkPixbuf* snap;
|
|
#endif
|
|
XP_LangCode dictLang;
|
|
XP_U32 gameID;
|
|
XP_S16 nMoves;
|
|
XP_Bool gameOver;
|
|
XP_Bool turnLocal;
|
|
XP_S16 turn;
|
|
XP_U16 nTotal;
|
|
XP_S16 nMissing;
|
|
XP_U16 seed;
|
|
XP_U16 nPending;
|
|
XP_U32 lastMoveTime;
|
|
XP_U32 dupTimerExpires;
|
|
XP_U16 role;
|
|
} GameInfo;
|
|
|
|
sqlite3* openGamesDB( const char* dbName );
|
|
void closeGamesDB( sqlite3* pDb );
|
|
|
|
void writeToDB( XWStreamCtxt* stream, XWEnv xwe, void* closure );
|
|
sqlite3_int64 writeNewGameToDB( XWStreamCtxt* stream, sqlite3* pDb );
|
|
|
|
void summarize( CommonGlobals* cGlobals );
|
|
|
|
/* Return GSList whose data is (ptrs to) rowids */
|
|
GSList* listGames( sqlite3* pDb );
|
|
/* free list and data allocated by above */
|
|
void freeGamesList( GSList* games );
|
|
|
|
/* Mapping of relayID -> rowid */
|
|
GHashTable* getRelayIDsToRowsMap( sqlite3* pDb );
|
|
|
|
XP_Bool getGameInfo( sqlite3* pDb, sqlite3_int64 rowid, GameInfo* gib );
|
|
void getRowsForGameID( sqlite3* pDb, XP_U32 gameID, sqlite3_int64* rowids,
|
|
int* nRowIDs );
|
|
XP_Bool loadGame( XWStreamCtxt* stream, sqlite3* pDb, sqlite3_int64 rowid );
|
|
void saveInviteAddrs( XWStreamCtxt* stream, sqlite3* pDb,
|
|
sqlite3_int64 rowid );
|
|
XP_Bool loadInviteAddrs( XWStreamCtxt* stream, sqlite3* pDb,
|
|
sqlite3_int64 rowid );
|
|
void deleteGame( sqlite3* pDb, sqlite3_int64 rowid );
|
|
|
|
#define KEY_RDEVID "RDEVID"
|
|
#define KEY_LDEVID "LDEVID"
|
|
#define KEY_SMSPHONE "SMSPHONE"
|
|
#define KEY_SMSPORT "SMSPORT"
|
|
#define KEY_WIN_LOC "WIN_LOC"
|
|
|
|
void db_store( sqlite3* pDb, const gchar* key, const gchar* value );
|
|
void db_remove( sqlite3* pDb, const gchar* key );
|
|
|
|
typedef enum { NOT_THERE, BUFFER_TOO_SMALL, SUCCESS } FetchResult;
|
|
FetchResult db_fetch( sqlite3* pDb, const gchar* key, const gchar* keySuffix,
|
|
gchar* buf, gint* buflen );
|
|
XP_Bool db_fetch_safe( sqlite3* pDb, const gchar* key, const gchar* keySuffix,
|
|
gchar* buf, gint buflen );
|
|
|
|
#endif
|