mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
make sms work via invitations too
This commit is contained in:
parent
c7c1946793
commit
38a4e494a4
7 changed files with 77 additions and 63 deletions
|
@ -158,7 +158,9 @@ static gint
|
||||||
inviteIdle( gpointer data )
|
inviteIdle( gpointer data )
|
||||||
{
|
{
|
||||||
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)data;
|
CursesBoardGlobals* bGlobals = (CursesBoardGlobals*)data;
|
||||||
if ( !!bGlobals->cGlobals.params->connInfo.relay.inviteeRelayIDs ) {
|
LaunchParams* params = bGlobals->cGlobals.params;
|
||||||
|
if ( !!params->connInfo.relay.inviteeRelayIDs
|
||||||
|
|| !!params->connInfo.sms.inviteePhones ) {
|
||||||
handleInvite( bGlobals, 0 );
|
handleInvite( bGlobals, 0 );
|
||||||
}
|
}
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -1177,6 +1179,31 @@ handleReplace( void* closure, int XP_UNUSED(key) )
|
||||||
return XP_TRUE;
|
return XP_TRUE;
|
||||||
} /* handleReplace */
|
} /* handleReplace */
|
||||||
|
|
||||||
|
static bool
|
||||||
|
inviteList( CommonGlobals* cGlobals, CommsAddrRec* addr, GSList* invitees,
|
||||||
|
bool useRelay )
|
||||||
|
{
|
||||||
|
bool haveAddressees = !!invitees;
|
||||||
|
if ( haveAddressees ) {
|
||||||
|
LaunchParams* params = cGlobals->params;
|
||||||
|
for ( int ii = 0; ii < g_slist_length(invitees); ++ii ) {
|
||||||
|
const XP_U16 nPlayers = 1;
|
||||||
|
gint forceChannel = ii + 1;
|
||||||
|
NetLaunchInfo nli = {0};
|
||||||
|
nli_init( &nli, cGlobals->gi, addr, nPlayers, forceChannel );
|
||||||
|
if ( useRelay ) {
|
||||||
|
uint64_t inviteeRelayID = (uint64_t)g_slist_nth_data( invitees, ii );
|
||||||
|
relaycon_invite( params, (XP_U32)inviteeRelayID, NULL, &nli );
|
||||||
|
} else {
|
||||||
|
const gchar* inviteePhone = (const gchar*)g_slist_nth_data( invitees, ii );
|
||||||
|
linux_sms_invite( params, &nli, inviteePhone,
|
||||||
|
params->connInfo.sms.port );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return haveAddressees;
|
||||||
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
handleInvite( void* closure, int XP_UNUSED(key) )
|
handleInvite( void* closure, int XP_UNUSED(key) )
|
||||||
{
|
{
|
||||||
|
@ -1199,20 +1226,10 @@ handleInvite( void* closure, int XP_UNUSED(key) )
|
||||||
/* Invite first based on an invitee provided. Otherwise, fall back to
|
/* Invite first based on an invitee provided. Otherwise, fall back to
|
||||||
doing a send-to-self. Let the recipient code reject a duplicate if
|
doing a send-to-self. Let the recipient code reject a duplicate if
|
||||||
the user so desires. */
|
the user so desires. */
|
||||||
} else if ( !!params->connInfo.sms.inviteePhone ) {
|
} else if ( inviteList( cGlobals, &addr, params->connInfo.sms.inviteePhones, false ) ) {
|
||||||
/* These should both be settable/derivable */
|
/* do nothing */
|
||||||
linux_sms_invite( params, &nli, params->connInfo.sms.inviteePhone,
|
} else if ( inviteList( cGlobals, &addr, params->connInfo.relay.inviteeRelayIDs, true ) ) {
|
||||||
params->connInfo.sms.port );
|
/* do nothing */
|
||||||
} else if ( !!params->connInfo.relay.inviteeRelayIDs ) {
|
|
||||||
GSList* inviteeRelayIDs = params->connInfo.relay.inviteeRelayIDs;
|
|
||||||
for ( int ii = 0; ii < g_slist_length(inviteeRelayIDs); ++ii ) {
|
|
||||||
XP_U16 nPlayers = 1;
|
|
||||||
gint forceChannel = ii + 1;
|
|
||||||
NetLaunchInfo nli = {0};
|
|
||||||
nli_init( &nli, cGlobals->gi, &addr, nPlayers, forceChannel );
|
|
||||||
uint64_t inviteeRelayID = (uint64_t)g_slist_nth_data(inviteeRelayIDs, ii);
|
|
||||||
relaycon_invite( params, (XP_U32)inviteeRelayID, NULL, &nli );
|
|
||||||
}
|
|
||||||
/* Try sending to self, using the phone number or relayID of this device */
|
/* Try sending to self, using the phone number or relayID of this device */
|
||||||
} else if ( addr_hasType( &addr, COMMS_CONN_SMS ) ) {
|
} else if ( addr_hasType( &addr, COMMS_CONN_SMS ) ) {
|
||||||
linux_sms_invite( params, &nli, addr.u.sms.phone, addr.u.sms.port );
|
linux_sms_invite( params, &nli, addr.u.sms.phone, addr.u.sms.port );
|
||||||
|
|
|
@ -1153,10 +1153,9 @@ onJoined( void* closure, const XP_UCHAR* connname, XWHostID hid )
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void
|
static void
|
||||||
relayInviteReceivedCurses( void* closure, NetLaunchInfo* invite )
|
inviteReceivedCurses( CursesAppGlobals* aGlobals, const NetLaunchInfo* invite,
|
||||||
|
const CommsAddrRec* returnAddr )
|
||||||
{
|
{
|
||||||
CursesAppGlobals* aGlobals = (CursesAppGlobals*)closure;
|
|
||||||
|
|
||||||
sqlite3_int64 rowids[1];
|
sqlite3_int64 rowids[1];
|
||||||
int nRowIDs = VSIZE(rowids);
|
int nRowIDs = VSIZE(rowids);
|
||||||
getRowsForGameID( aGlobals->cag.params->pDb, invite->gameID, rowids, &nRowIDs );
|
getRowsForGameID( aGlobals->cag.params->pDb, invite->gameID, rowids, &nRowIDs );
|
||||||
|
@ -1167,15 +1166,23 @@ relayInviteReceivedCurses( void* closure, NetLaunchInfo* invite )
|
||||||
doIt = 0 == cursesask( aGlobals->mainWin, question, VSIZE(buttons), buttons );
|
doIt = 0 == cursesask( aGlobals->mainWin, question, VSIZE(buttons), buttons );
|
||||||
}
|
}
|
||||||
if ( doIt ) {
|
if ( doIt ) {
|
||||||
CommsAddrRec returnAddr = {0};
|
|
||||||
nli_makeAddrRec( invite, &returnAddr );
|
|
||||||
|
|
||||||
cb_dims dims;
|
cb_dims dims;
|
||||||
figureDims( aGlobals, &dims );
|
figureDims( aGlobals, &dims );
|
||||||
cb_newFor( aGlobals->cbState, invite, &returnAddr, &dims );
|
cb_newFor( aGlobals->cbState, invite, returnAddr, &dims );
|
||||||
|
} else {
|
||||||
|
XP_LOGFF( "%s", "Not accepting duplicate invitation" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
relayInviteReceivedCurses( void* closure, NetLaunchInfo* invite )
|
||||||
|
{
|
||||||
|
CursesAppGlobals* aGlobals = (CursesAppGlobals*)closure;
|
||||||
|
CommsAddrRec addr = {0};
|
||||||
|
nli_makeAddrRec( invite, &addr );
|
||||||
|
inviteReceivedCurses( aGlobals, invite, &addr );
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
cursesGotBuf( void* closure, const CommsAddrRec* addr,
|
cursesGotBuf( void* closure, const CommsAddrRec* addr,
|
||||||
const XP_U8* buf, XP_U16 len )
|
const XP_U8* buf, XP_U16 len )
|
||||||
|
@ -1211,20 +1218,7 @@ smsInviteReceivedCurses( void* closure, const NetLaunchInfo* nli,
|
||||||
const CommsAddrRec* returnAddr )
|
const CommsAddrRec* returnAddr )
|
||||||
{
|
{
|
||||||
CursesAppGlobals* aGlobals = (CursesAppGlobals*)closure;
|
CursesAppGlobals* aGlobals = (CursesAppGlobals*)closure;
|
||||||
/* LaunchParams* params = aGlobals->cag.params; */
|
inviteReceivedCurses( aGlobals, nli, returnAddr );
|
||||||
/* CurGameInfo gi = {0}; */
|
|
||||||
/* gi_copy( MPPARM(params->mpool) &gi, ¶ms->pgi ); */
|
|
||||||
|
|
||||||
/* gi_setNPlayers( &gi, invite->nPlayersT, invite->nPlayersH ); */
|
|
||||||
/* gi.gameID = invite->gameID; */
|
|
||||||
/* gi.dictLang = invite->lang; */
|
|
||||||
/* gi.forceChannel = invite->forceChannel; */
|
|
||||||
/* gi.serverRole = SERVER_ISCLIENT; /\* recipient of invitation is client *\/ */
|
|
||||||
/* replaceStringIfDifferent( params->mpool, &gi.dictName, invite->dict ); */
|
|
||||||
|
|
||||||
cb_dims dims;
|
|
||||||
figureDims( aGlobals, &dims );
|
|
||||||
cb_newFor( aGlobals->cbState, nli, returnAddr, &dims );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -2722,7 +2722,8 @@ main( int argc, char** argv )
|
||||||
addr_addType( &mainParams.addr, COMMS_CONN_SMS );
|
addr_addType( &mainParams.addr, COMMS_CONN_SMS );
|
||||||
break;
|
break;
|
||||||
case CMD_INVITEE_SMSNUMBER:
|
case CMD_INVITEE_SMSNUMBER:
|
||||||
mainParams.connInfo.sms.inviteePhone = optarg;
|
mainParams.connInfo.sms.inviteePhones =
|
||||||
|
g_slist_append( mainParams.connInfo.sms.inviteePhones, optarg );
|
||||||
addr_addType( &mainParams.addr, COMMS_CONN_SMS );
|
addr_addType( &mainParams.addr, COMMS_CONN_SMS );
|
||||||
break;
|
break;
|
||||||
case CMD_SMSPORT:
|
case CMD_SMSPORT:
|
||||||
|
|
|
@ -115,15 +115,12 @@ write_fake_sms( LaunchParams* params, const void* buf, XP_U16 buflen,
|
||||||
|
|
||||||
if ( skipWrite ) {
|
if ( skipWrite ) {
|
||||||
nSent = buflen;
|
nSent = buflen;
|
||||||
XP_LOGF( "%s(): dropping sms msg of len %d to phone %s", __func__,
|
XP_LOGFF( "dropping sms msg of len %d to phone %s", nSent, phone );
|
||||||
nSent, phone );
|
|
||||||
} else {
|
} else {
|
||||||
LinSMSData* storage = getStorage( params );
|
LinSMSData* storage = getStorage( params );
|
||||||
XP_LOGF( "%s(phone=%s, port=%d, len=%d)", __func__, phone,
|
XP_LOGFF( "(phone=%s, port=%d, len=%d)", phone, port, buflen );
|
||||||
port, buflen );
|
|
||||||
|
|
||||||
XP_ASSERT( !!storage );
|
XP_ASSERT( !!storage );
|
||||||
char path[256];
|
|
||||||
|
|
||||||
lock_queue( storage );
|
lock_queue( storage );
|
||||||
|
|
||||||
|
@ -131,6 +128,7 @@ write_fake_sms( LaunchParams* params, const void* buf, XP_U16 buflen,
|
||||||
gchar* str64 = g_base64_encode( buf, buflen );
|
gchar* str64 = g_base64_encode( buf, buflen );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
char path[256];
|
||||||
formatQueuePath( phone, port, path, sizeof(path) );
|
formatQueuePath( phone, port, path, sizeof(path) );
|
||||||
|
|
||||||
/* Random-number-based name is fine, as we pick based on age. */
|
/* Random-number-based name is fine, as we pick based on age. */
|
||||||
|
@ -143,7 +141,7 @@ write_fake_sms( LaunchParams* params, const void* buf, XP_U16 buflen,
|
||||||
XP_U16 smslen = sizeof(sms);
|
XP_U16 smslen = sizeof(sms);
|
||||||
binToSms( sms, &smslen, buf, buflen );
|
binToSms( sms, &smslen, buf, buflen );
|
||||||
XP_ASSERT( smslen == strlen(sms) );
|
XP_ASSERT( smslen == strlen(sms) );
|
||||||
XP_LOGF( "%s: writing msg to %s", __func__, path );
|
XP_LOGFF( "writing msg to %s", path );
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
XP_ASSERT( !strcmp( str64, sms ) );
|
XP_ASSERT( !strcmp( str64, sms ) );
|
||||||
|
@ -202,7 +200,7 @@ decodeAndDelete( LinSMSData* storage, const gchar* name,
|
||||||
*strstr(eol, "\n" ) = '\0';
|
*strstr(eol, "\n" ) = '\0';
|
||||||
|
|
||||||
XP_U16 inlen = strlen(eol); /* skip \n */
|
XP_U16 inlen = strlen(eol); /* skip \n */
|
||||||
XP_LOGF( "%s(): decoding message from file %s", __func__, name );
|
XP_LOGFF( "decoding message from file %s", name );
|
||||||
XP_U8 out[inlen];
|
XP_U8 out[inlen];
|
||||||
XP_U16 outlen = sizeof(out);
|
XP_U16 outlen = sizeof(out);
|
||||||
XP_Bool valid = smsToBin( out, &outlen, eol, inlen );
|
XP_Bool valid = smsToBin( out, &outlen, eol, inlen );
|
||||||
|
@ -212,8 +210,7 @@ decodeAndDelete( LinSMSData* storage, const gchar* name,
|
||||||
nRead = outlen;
|
nRead = outlen;
|
||||||
addr_setType( addr, COMMS_CONN_SMS );
|
addr_setType( addr, COMMS_CONN_SMS );
|
||||||
XP_STRNCPY( addr->u.sms.phone, phone, sizeof(addr->u.sms.phone) );
|
XP_STRNCPY( addr->u.sms.phone, phone, sizeof(addr->u.sms.phone) );
|
||||||
XP_LOGF( "%s: message came from phone: %s, port: %d", __func__,
|
XP_LOGFF( " message came from phone: %s, port: %d", phone, port );
|
||||||
phone, port );
|
|
||||||
addr->u.sms.port = port;
|
addr->u.sms.port = port;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -272,7 +269,7 @@ linux_sms_init( LaunchParams* params, const gchar* myPhone, XP_U16 myPort,
|
||||||
storage->protoState = smsproto_init( MPPARM(params->mpool) params->dutil );
|
storage->protoState = smsproto_init( MPPARM(params->mpool) params->dutil );
|
||||||
|
|
||||||
formatQueuePath( myPhone, myPort, storage->myQueue, sizeof(storage->myQueue) );
|
formatQueuePath( myPhone, myPort, storage->myQueue, sizeof(storage->myQueue) );
|
||||||
XP_LOGF( "%s: my queue: %s", __func__, storage->myQueue );
|
XP_LOGFF( " my queue: %s", storage->myQueue );
|
||||||
storage->myPort = params->connInfo.sms.port;
|
storage->myPort = params->connInfo.sms.port;
|
||||||
|
|
||||||
(void)g_mkdir_with_parents( storage->myQueue, 0777 );
|
(void)g_mkdir_with_parents( storage->myQueue, 0777 );
|
||||||
|
@ -400,8 +397,7 @@ check_for_files_once( gpointer data )
|
||||||
snprintf( fullPath, sizeof(fullPath), "%s/%s", storage->myQueue, name );
|
snprintf( fullPath, sizeof(fullPath), "%s/%s", storage->myQueue, name );
|
||||||
int err = stat( fullPath, &statbuf );
|
int err = stat( fullPath, &statbuf );
|
||||||
if ( err != 0 ) {
|
if ( err != 0 ) {
|
||||||
XP_LOGF( "%s(); %d from stat (error: %s)", __func__,
|
XP_LOGF( "%d from stat (error: %s)", err, strerror(errno) );
|
||||||
err, strerror(errno) );
|
|
||||||
XP_ASSERT( 0 );
|
XP_ASSERT( 0 );
|
||||||
} else {
|
} else {
|
||||||
XP_Bool replace = !oldestFile[0]; /* always replace empty/unset :-) */
|
XP_Bool replace = !oldestFile[0]; /* always replace empty/unset :-) */
|
||||||
|
@ -416,7 +412,7 @@ check_for_files_once( gpointer data )
|
||||||
if ( replace ) {
|
if ( replace ) {
|
||||||
oldestModTime = statbuf.st_mtim;
|
oldestModTime = statbuf.st_mtim;
|
||||||
if ( !!oldestFile[0] ) {
|
if ( !!oldestFile[0] ) {
|
||||||
XP_LOGF( "%s(): replacing %s with older %s", __func__, oldestFile, name );
|
XP_LOGFF( "replacing %s with older %s", oldestFile, name );
|
||||||
}
|
}
|
||||||
snprintf( oldestFile, sizeof(oldestFile), "%s", name );
|
snprintf( oldestFile, sizeof(oldestFile), "%s", name );
|
||||||
}
|
}
|
||||||
|
|
|
@ -160,7 +160,7 @@ typedef struct LaunchParams {
|
||||||
#ifdef XWFEATURE_SMS
|
#ifdef XWFEATURE_SMS
|
||||||
struct {
|
struct {
|
||||||
const char* myPhone;
|
const char* myPhone;
|
||||||
const char* inviteePhone;
|
GSList* inviteePhones;
|
||||||
int port;
|
int port;
|
||||||
} sms;
|
} sms;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -253,7 +253,7 @@ class Device():
|
||||||
self.relaySeed = int(match.group(1))
|
self.relaySeed = int(match.group(1))
|
||||||
self.relayID = match.group(2)
|
self.relayID = match.group(2)
|
||||||
|
|
||||||
if not self.inviteeDevID:
|
if self.args.ADD_RELAY and not self.inviteeDevID:
|
||||||
match = Device.sDevIDPat.match(line)
|
match = Device.sDevIDPat.match(line)
|
||||||
if match: self.inviteeDevID = int(match.group(1), 16)
|
if match: self.inviteeDevID = int(match.group(1), 16)
|
||||||
|
|
||||||
|
@ -292,16 +292,17 @@ class Device():
|
||||||
# the same order so channels will be assigned consistently. So
|
# the same order so channels will be assigned consistently. So
|
||||||
# keep them in an array as they're encountered, and use in
|
# keep them in an array as they're encountered, and use in
|
||||||
# that order
|
# that order
|
||||||
if not self.usePublic and self.order == 1 and self.inviteeDevID and not self.connected:
|
if self.args.ADD_RELAY:
|
||||||
for peer in self.peers:
|
if not self.usePublic and self.order == 1 and self.inviteeDevID and not self.connected:
|
||||||
if peer.inviteeDevID and not peer == self:
|
for peer in self.peers:
|
||||||
if not peer.inviteeDevID in self.inviteeDevIDs:
|
if peer.inviteeDevID and not peer == self:
|
||||||
self.inviteeDevIDs.append(peer.inviteeDevID)
|
if not peer.inviteeDevID in self.inviteeDevIDs:
|
||||||
|
self.inviteeDevIDs.append(peer.inviteeDevID)
|
||||||
|
|
||||||
if self.inviteeDevIDs:
|
if self.inviteeDevIDs:
|
||||||
args += [ '--force-invite' ]
|
args += [ '--force-invite' ]
|
||||||
for inviteeDevID in self.inviteeDevIDs:
|
for inviteeDevID in self.inviteeDevIDs:
|
||||||
args += ['--invitee-relayid', str(inviteeDevID)]
|
args += ['--invitee-relayid', str(inviteeDevID)]
|
||||||
|
|
||||||
self.proc = subprocess.Popen(args, stdout = subprocess.DEVNULL,
|
self.proc = subprocess.Popen(args, stdout = subprocess.DEVNULL,
|
||||||
stderr = subprocess.PIPE, universal_newlines = True)
|
stderr = subprocess.PIPE, universal_newlines = True)
|
||||||
|
@ -464,8 +465,10 @@ def build_cmds(args):
|
||||||
PARAMS += [ '--sms-number', PHONE_BASE + str(DEV - 1) ]
|
PARAMS += [ '--sms-number', PHONE_BASE + str(DEV - 1) ]
|
||||||
if args.SMS_FAIL_PCT > 0:
|
if args.SMS_FAIL_PCT > 0:
|
||||||
PARAMS += [ '--sms-fail-pct', args.SMS_FAIL_PCT ]
|
PARAMS += [ '--sms-fail-pct', args.SMS_FAIL_PCT ]
|
||||||
if DEV > 1:
|
if DEV == 1:
|
||||||
PARAMS += [ '--server-sms-number', PHONE_BASE + '0' ]
|
PARAMS += [ '--force-invite' ]
|
||||||
|
for dev in range(2, NDEVS + 1):
|
||||||
|
PARAMS += [ '--invitee-sms-number', PHONE_BASE + str(dev - 1) ]
|
||||||
|
|
||||||
if args.UNDO_PCT > 0:
|
if args.UNDO_PCT > 0:
|
||||||
PARAMS += ['--undo-pct', args.UNDO_PCT]
|
PARAMS += ['--undo-pct', args.UNDO_PCT]
|
||||||
|
|
3
xwords4/linux/scripts/show_sms_inplay.sh
Executable file
3
xwords4/linux/scripts/show_sms_inplay.sh
Executable file
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
ls -l /tmp/xw_sms
|
Loading…
Reference in a new issue