stop storing fcm keys and similar data in postgres arrays

Not sure why I was doing this, but it's not worth the
trouble (e.g. stopping updates of other data to fix an android bug
sending too many reregistration messages.) So now just use the first
element of arrays, replacing what's there instead of prepending. Ideally
those columns would not be arrays, but that's a harder change.
This commit is contained in:
Eric House 2019-02-02 21:49:50 -08:00
parent b198091490
commit d067b867a2
2 changed files with 8 additions and 20 deletions

View file

@ -451,14 +451,13 @@ DBMgr::ReregisterDevice( DevIDRelay relayID, const DevID* host,
{ {
QueryBuilder qb; QueryBuilder qb;
qb.appendQueryf( "UPDATE " DEVICES_TABLE " SET " qb.appendQueryf( "UPDATE " DEVICES_TABLE " SET "
"devTypes = array_prepend($$, devTypes), " "devTypes[1] = $$, "
"devids = array_prepend($$, devids), " ) "devids[1] = $$, " )
.appendParam( host->m_devIDType ) .appendParam( host->m_devIDType )
.appendParam( host->m_devIDString.c_str() ); .appendParam( host->m_devIDString.c_str() );
formatUpdate( qb, true, desc, clientVersion, model, osVers, variant, relayID, formatUpdate( qb, true, desc, clientVersion, model, osVers, variant,
host->m_devIDString.c_str() ); relayID );
qb.finish(); qb.finish();
execParams( qb ); execParams( qb );
} }
@ -481,7 +480,7 @@ DBMgr::UpdateDevice( DevIDRelay relayID, const char* const desc,
QueryBuilder qb; QueryBuilder qb;
qb.appendQueryf( "UPDATE " DEVICES_TABLE " SET " ); qb.appendQueryf( "UPDATE " DEVICES_TABLE " SET " );
formatUpdate( qb, false, desc, clientVersion, model, osVers, formatUpdate( qb, false, desc, clientVersion, model, osVers,
variant, relayID, NULL ); variant, relayID );
qb.finish(); qb.finish();
execParams( qb ); execParams( qb );
} }
@ -499,13 +498,9 @@ DBMgr::formatUpdate( QueryBuilder& qb,
bool append, const char* const desc, bool append, const char* const desc,
int clientVersion, const char* const model, int clientVersion, const char* const model,
const char* const osVers, const char* const variant, const char* const osVers, const char* const variant,
DevIDRelay relayID, const char* newDevID ) DevIDRelay relayID )
{ {
if ( append ) { qb.appendQueryf( "mtimes[1]='now'" );
qb.appendQueryf( "mtimes=array_prepend('now', mtimes)" ); // FIXME: too many
} else {
qb.appendQueryf( "mtimes[1]='now'" );
}
if ( NULL != desc && '\0' != desc[0] ) { if ( NULL != desc && '\0' != desc[0] ) {
qb.appendQueryf( ", clntVers=$$" ) qb.appendQueryf( ", clntVers=$$" )
@ -525,15 +520,8 @@ DBMgr::formatUpdate( QueryBuilder& qb,
qb.appendQueryf( ", variant=$$" ) qb.appendQueryf( ", variant=$$" )
.appendParam( variant ); .appendParam( variant );
} }
qb.appendQueryf( " WHERE id = $$" ) qb.appendQueryf( " WHERE id = $$" )
.appendParam( relayID ); .appendParam( relayID );
if ( !!newDevID ) {
assert( append );
qb.appendQueryf( " AND NOT devids[1] = $$" )
.appendParam( newDevID );
}
} }
HostID HostID

View file

@ -177,7 +177,7 @@ class DBMgr {
void formatUpdate( QueryBuilder& qb, bool append, const char* const desc, void formatUpdate( QueryBuilder& qb, bool append, const char* const desc,
int clientVersion, const char* const model, int clientVersion, const char* const model,
const char* const osVers, const char* const variant, const char* const osVers, const char* const variant,
DevIDRelay relayID, const char* newDevID ); DevIDRelay relayID );
PGconn* getThreadConn( void ); PGconn* getThreadConn( void );