mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-24 07:58:34 +01:00
don't handle duplicate invitations in DEBUG case
Was creating a second game in some cases in response to duplicated invitations. Add a test for forceChannel: if there's already a game with the same gameID *and* forceChannel assume the invitation is a dupe and drop it.
This commit is contained in:
parent
e0f4a028d1
commit
2c73f4ca77
1 changed files with 38 additions and 14 deletions
|
@ -27,14 +27,15 @@ import android.content.Intent;
|
||||||
import org.eehouse.android.xw4.MultiService.DictFetchOwner;
|
import org.eehouse.android.xw4.MultiService.DictFetchOwner;
|
||||||
import org.eehouse.android.xw4.MultiService.MultiEvent;
|
import org.eehouse.android.xw4.MultiService.MultiEvent;
|
||||||
import org.eehouse.android.xw4.jni.CommsAddrRec;
|
import org.eehouse.android.xw4.jni.CommsAddrRec;
|
||||||
|
import org.eehouse.android.xw4.jni.CurGameInfo;
|
||||||
import org.eehouse.android.xw4.jni.JNIThread;
|
import org.eehouse.android.xw4.jni.JNIThread;
|
||||||
import org.eehouse.android.xw4.jni.UtilCtxt;
|
import org.eehouse.android.xw4.jni.UtilCtxt;
|
||||||
import org.eehouse.android.xw4.jni.UtilCtxtImpl;
|
import org.eehouse.android.xw4.jni.UtilCtxtImpl;
|
||||||
|
import org.eehouse.android.xw4.jni.XwJNI.GamePtr;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
|
||||||
abstract class XWServiceHelper {
|
abstract class XWServiceHelper {
|
||||||
private static final String TAG = XWServiceHelper.class.getSimpleName();
|
private static final String TAG = XWServiceHelper.class.getSimpleName();
|
||||||
private Service mService;
|
private Service mService;
|
||||||
|
@ -121,14 +122,36 @@ abstract class XWServiceHelper {
|
||||||
protected boolean handleInvitation( NetLaunchInfo nli, String device,
|
protected boolean handleInvitation( NetLaunchInfo nli, String device,
|
||||||
DictFetchOwner dfo )
|
DictFetchOwner dfo )
|
||||||
{
|
{
|
||||||
boolean success = false;
|
boolean success = nli.isValid() && checkNotInFlight( nli );
|
||||||
long[] rowids = DBUtils.getRowIDsFor( mService, nli.gameID() );
|
if ( success ) {
|
||||||
if ( 0 == rowids.length
|
long[] rowids = DBUtils.getRowIDsFor( mService, nli.gameID() );
|
||||||
|| ( rowids.length < nli.nPlayersT // will break for two-per-device game
|
if ( 0 == rowids.length ) {
|
||||||
&& XWPrefs.getSecondInviteAllowed( mService ) ) ) {
|
// cool: we're good
|
||||||
|
} else if ( rowids.length < nli.nPlayersT ) {
|
||||||
|
success = XWPrefs.getSecondInviteAllowed( mService );
|
||||||
|
|
||||||
if ( nli.isValid() && checkNotDupe( nli ) ) {
|
// Allowing a second game allows the common testing action of
|
||||||
|
// sending invitation to myself. But we still need to check
|
||||||
|
// for duplicates! forceChannel's hard to dig up, but works
|
||||||
|
for ( int ii = 0; success && ii < rowids.length; ++ii ) {
|
||||||
|
long rowid = rowids[ii];
|
||||||
|
try ( GameLock lock = GameLock.getFor( rowid ).tryLockRO() ) {
|
||||||
|
// drop invite if can't open game; likely a dupe!
|
||||||
|
success = null != lock;
|
||||||
|
if ( success ) {
|
||||||
|
CurGameInfo gi = new CurGameInfo( mService );
|
||||||
|
GamePtr gamePtr = GameUtils
|
||||||
|
.loadMakeGame( mService, gi, lock );
|
||||||
|
success = gi.forceChannel != nli.forceChannel;
|
||||||
|
gamePtr.release();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
success = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( success ) {
|
||||||
if ( DictLangCache.haveDict( mService, nli.lang, nli.dict ) ) {
|
if ( DictLangCache.haveDict( mService, nli.lang, nli.dict ) ) {
|
||||||
long rowid = GameUtils.makeNewMultiGame( mService, nli,
|
long rowid = GameUtils.makeNewMultiGame( mService, nli,
|
||||||
getSink( 0 ),
|
getSink( 0 ),
|
||||||
|
@ -139,12 +162,12 @@ abstract class XWServiceHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
postNotification( device, nli.gameID(), rowid );
|
postNotification( device, nli.gameID(), rowid );
|
||||||
success = true;
|
|
||||||
} else {
|
} else {
|
||||||
Intent intent = MultiService
|
Intent intent = MultiService
|
||||||
.makeMissingDictIntent( mService, nli, dfo );
|
.makeMissingDictIntent( mService, nli, dfo );
|
||||||
MultiService.postMissingDictNotification( mService, intent,
|
MultiService.postMissingDictNotification( mService, intent,
|
||||||
nli.gameID() );
|
nli.gameID() );
|
||||||
|
success = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -163,20 +186,21 @@ abstract class XWServiceHelper {
|
||||||
|
|
||||||
// Check that we aren't already processing an invitation with this
|
// Check that we aren't already processing an invitation with this
|
||||||
// inviteID.
|
// inviteID.
|
||||||
private static final long SEEN_INTERVAL_MS = 1000 * 5;
|
private static final long SEEN_INTERVAL_MS = 1000 * 2;
|
||||||
private static Map<String, Long> s_seen = new HashMap<>();
|
private static Map<String, Long> s_seen = new HashMap<>();
|
||||||
private boolean checkNotDupe( NetLaunchInfo nli )
|
private boolean checkNotInFlight( NetLaunchInfo nli )
|
||||||
{
|
{
|
||||||
|
boolean inProcess;
|
||||||
String inviteID = nli.inviteID();
|
String inviteID = nli.inviteID();
|
||||||
synchronized( s_seen ) {
|
synchronized( s_seen ) {
|
||||||
long now = System.currentTimeMillis();
|
long now = System.currentTimeMillis();
|
||||||
Long lastSeen = s_seen.get( inviteID );
|
Long lastSeen = s_seen.get( inviteID );
|
||||||
boolean seen = null != lastSeen && lastSeen + SEEN_INTERVAL_MS > now;
|
inProcess = null != lastSeen && lastSeen + SEEN_INTERVAL_MS > now;
|
||||||
if ( !seen ) {
|
if ( !inProcess ) {
|
||||||
s_seen.put( inviteID, now );
|
s_seen.put( inviteID, now );
|
||||||
}
|
}
|
||||||
Log.d( TAG, "checkNotDupe('%s') => %b", inviteID, !seen );
|
|
||||||
return !seen;
|
|
||||||
}
|
}
|
||||||
|
Log.d( TAG, "checkNotInFlight('%s') => %b", inviteID, !inProcess );
|
||||||
|
return !inProcess;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue