include port and proto

Pretty sure couldn't have played against an older build without this.
This commit is contained in:
Eric House 2018-07-26 21:13:09 -07:00
parent 9ddc6e4b89
commit e637f49b95
6 changed files with 73 additions and 36 deletions

View file

@ -482,7 +482,8 @@ public class SMSService extends XWService {
private void receiveBuffer( byte[] buffer, String senderPhone ) private void receiveBuffer( byte[] buffer, String senderPhone )
{ {
SMSProtoMsg[] msgs = XwJNI.smsproto_prepInbound( buffer, senderPhone ); SMSProtoMsg[] msgs = XwJNI.smsproto_prepInbound( buffer, senderPhone,
getNBSPort() );
if ( null != msgs ) { if ( null != msgs ) {
for ( SMSProtoMsg msg : msgs ) { for ( SMSProtoMsg msg : msgs ) {
receive( msg, senderPhone ); receive( msg, senderPhone );

View file

@ -418,9 +418,10 @@ public class XwJNI {
port, forceNow, waitSecs ); port, forceNow, waitSecs );
} }
public static SMSProtoMsg[] smsproto_prepInbound( byte[] data, String fromPhone ) public static SMSProtoMsg[] smsproto_prepInbound( byte[] data,
String fromPhone, int wantPort )
{ {
return smsproto_prepInbound( getJNI().m_ptr, data, fromPhone ); return smsproto_prepInbound( getJNI().m_ptr, data, fromPhone, wantPort );
} }
// Dicts // Dicts
@ -516,7 +517,8 @@ public class XwJNI {
private static native SMSProtoMsg[] smsproto_prepInbound( int jniState, private static native SMSProtoMsg[] smsproto_prepInbound( int jniState,
byte[] data, byte[] data,
String fromPhone ); String fromPhone,
int wantPort);
private static native boolean haveEnv( int jniState ); private static native boolean haveEnv( int jniState );
} }

View file

@ -850,7 +850,8 @@ Java_org_eehouse_android_xw4_jni_XwJNI_smsproto_1prepOutbound
JNIEXPORT jobjectArray JNICALL JNIEXPORT jobjectArray JNICALL
Java_org_eehouse_android_xw4_jni_XwJNI_smsproto_1prepInbound Java_org_eehouse_android_xw4_jni_XwJNI_smsproto_1prepInbound
( JNIEnv* env, jclass C, jint jniGlobalPtr, jbyteArray jData, jstring jFromPhone ) ( JNIEnv* env, jclass C, jint jniGlobalPtr, jbyteArray jData,
jstring jFromPhone, jint jWantPort )
{ {
jobjectArray result = NULL; jobjectArray result = NULL;
@ -863,7 +864,7 @@ Java_org_eehouse_android_xw4_jni_XwJNI_smsproto_1prepInbound
const char* fromPhone = (*env)->GetStringUTFChars( env, jFromPhone, NULL ); const char* fromPhone = (*env)->GetStringUTFChars( env, jFromPhone, NULL );
SMSMsgArray* arr = smsproto_prepInbound( globalState->smsProto, fromPhone, SMSMsgArray* arr = smsproto_prepInbound( globalState->smsProto, fromPhone,
(XP_U8*)data, len ); jWantPort, (XP_U8*)data, len );
if ( !!arr ) { if ( !!arr ) {
result = msgArrayToJMsgArray( env, arr ); result = msgArrayToJMsgArray( env, arr );
smsproto_freeMsgArray( globalState->smsProto, arr ); smsproto_freeMsgArray( globalState->smsProto, arr );

View file

@ -31,6 +31,10 @@
/* PENDING: Might want to make SEND_NOW_SIZE smaller; might as well send now /* PENDING: Might want to make SEND_NOW_SIZE smaller; might as well send now
if even the smallest new message is likely to put us over. */ if even the smallest new message is likely to put us over. */
# define SEND_NOW_SIZE MAX_LEN_BINARY # define SEND_NOW_SIZE MAX_LEN_BINARY
/* To match the SMSService format */
# define SMS_PROTO_VERSION_JAVA 1
# define SMS_PROTO_VERSION 1 # define SMS_PROTO_VERSION 1
# define SMS_PROTO_VERSION_COMBO 2 # define SMS_PROTO_VERSION_COMBO 2
@ -87,12 +91,13 @@ static SMSMsgArray* toNetMsgs( SMSProto* state, ToPhoneRec* rec, XP_Bool forceOl
static ToPhoneRec* getForPhone( SMSProto* state, const XP_UCHAR* phone, static ToPhoneRec* getForPhone( SMSProto* state, const XP_UCHAR* phone,
XP_Bool create ); XP_Bool create );
static void addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd, static void addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd,
XP_U32 gameID, const XP_U8* buf, XP_U16 buflen, XP_U16 port, XP_U32 gameID, const XP_U8* buf,
XP_U32 nowSeconds ); XP_U16 buflen, XP_U32 nowSeconds );
static void addMessage( SMSProto* state, const XP_UCHAR* fromPhone, int msgID, static void addMessage( SMSProto* state, const XP_UCHAR* fromPhone, int msgID,
int indx, int count, const XP_U8* data, XP_U16 len ); int indx, int count, const XP_U8* data, XP_U16 len );
static SMSMsgArray* completeMsgs( SMSProto* state, SMSMsgArray* arr, static SMSMsgArray* completeMsgs( SMSProto* state, SMSMsgArray* arr,
const XP_UCHAR* fromPhone, int msgID ); const XP_UCHAR* fromPhone, XP_U16 wantPort,
int msgID );
static void savePartials( SMSProto* state ); static void savePartials( SMSProto* state );
static void restorePartials( SMSProto* state ); static void restorePartials( SMSProto* state );
static void rmFromPhoneRec( SMSProto* state, int fromPhoneIndex ); static void rmFromPhoneRec( SMSProto* state, int fromPhoneIndex );
@ -152,9 +157,11 @@ smsproto_free( SMSProto* state )
} }
static void static void
headerToStream( XWStreamCtxt* stream, SMS_CMD cmd, XP_U32 gameID ) headerToStream( XWStreamCtxt* stream, SMS_CMD cmd, XP_U16 port, XP_U32 gameID )
{ {
// XP_LOGF( "%s(cmd: %d; gameID: %d)", __func__, cmd, gameID ); // XP_LOGF( "%s(cmd: %d; gameID: %d)", __func__, cmd, gameID );
stream_putU8( stream, SMS_PROTO_VERSION_JAVA );
stream_putU16( stream, port );
stream_putU8( stream, cmd ); stream_putU8( stream, cmd );
switch ( cmd ) { switch ( cmd ) {
case NONE: case NONE:
@ -168,12 +175,15 @@ headerToStream( XWStreamCtxt* stream, SMS_CMD cmd, XP_U32 gameID )
} }
static XP_Bool static XP_Bool
headerFromStream( XWStreamCtxt* stream, SMS_CMD* cmd, XP_U32* gameID ) headerFromStream( XWStreamCtxt* stream, SMS_CMD* cmd, XP_U16* port, XP_U32* gameID )
{ {
XP_Bool success = XP_FALSE; XP_Bool success = XP_FALSE;
XP_U8 tmp; XP_U8 tmp;
if ( stream_gotU8( stream, &tmp ) ) { if ( stream_gotU8( stream, &tmp )
&& tmp == SMS_PROTO_VERSION_JAVA
&& stream_gotU16( stream, port )
&& stream_gotU8( stream, &tmp ) ) {
*cmd = tmp; *cmd = tmp;
switch( *cmd ) { switch( *cmd ) {
case INVITE: case INVITE:
@ -218,7 +228,7 @@ smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd, XP_U32 gameID,
/* First, add the new message (if present) to the array */ /* First, add the new message (if present) to the array */
XP_U32 nowSeconds = dutil_getCurSeconds( state->dutil ); XP_U32 nowSeconds = dutil_getCurSeconds( state->dutil );
if ( cmd != NONE ) { if ( cmd != NONE ) {
addToOutRec( state, rec, cmd, gameID, buf, buflen, nowSeconds ); addToOutRec( state, rec, cmd, toPort, gameID, buf, buflen, nowSeconds );
} }
/* rec will be non-null if there's something in it */ /* rec will be non-null if there's something in it */
@ -280,7 +290,7 @@ appendNetMsg( SMSProto* state, SMSMsgArray* arr, SMSMsgNet* msg )
SMSMsgArray* SMSMsgArray*
smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone, smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
const XP_U8* data, XP_U16 len ) XP_U16 wantPort, const XP_U8* data, XP_U16 len )
{ {
XP_LOGF( "%s(): len=%d, fromPhone=%s", __func__, len, fromPhone ); XP_LOGF( "%s(): len=%d, fromPhone=%s", __func__, len, fromPhone );
checkThread( state ); checkThread( state );
@ -302,7 +312,7 @@ smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
XP_U8 buf[len]; XP_U8 buf[len];
stream_getBytes( stream, buf, len ); stream_getBytes( stream, buf, len );
addMessage( state, fromPhone, msgID, indx, count, buf, len ); addMessage( state, fromPhone, msgID, indx, count, buf, len );
result = completeMsgs( state, result, fromPhone, msgID ); result = completeMsgs( state, result, fromPhone, wantPort, msgID );
savePartials( state ); savePartials( state );
} }
} }
@ -318,11 +328,13 @@ smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
stream_putBytes( msgStream, tmp, oneLen ); stream_putBytes( msgStream, tmp, oneLen );
XP_U32 gameID; XP_U32 gameID;
XP_U16 port;
SMS_CMD cmd; SMS_CMD cmd;
if ( headerFromStream( msgStream, &cmd, &gameID ) ) { if ( headerFromStream( msgStream, &cmd, &port, &gameID ) ) {
XP_U16 msgLen = stream_getSize( msgStream ); XP_U16 msgLen = stream_getSize( msgStream );
XP_U8 buf[msgLen]; XP_U8 buf[msgLen];
if ( stream_gotBytes( msgStream, buf, msgLen ) ) { if ( stream_gotBytes( msgStream, buf, msgLen ) ) {
if ( port == wantPort ) {
SMSMsgLoc msg = { .len = msgLen, SMSMsgLoc msg = { .len = msgLen,
.cmd = cmd, .cmd = cmd,
.gameID = gameID, .gameID = gameID,
@ -330,6 +342,10 @@ smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
}; };
XP_MEMCPY( msg.data, buf, msgLen ); XP_MEMCPY( msg.data, buf, msgLen );
result = appendLocMsg( state, result, &msg ); result = appendLocMsg( state, result, &msg );
} else {
XP_LOGF( "%s(): expected port %d, got %d", __func__,
wantPort, port );
}
} }
} }
stream_destroy( msgStream ); stream_destroy( msgStream );
@ -440,11 +456,11 @@ freeForPhone( SMSProto* state, const XP_UCHAR* phone )
static void static void
addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd, addToOutRec( SMSProto* state, ToPhoneRec* rec, SMS_CMD cmd,
XP_U32 gameID, const XP_U8* buf, XP_U16 buflen, XP_U16 port, XP_U32 gameID, const XP_U8* buf, XP_U16 buflen,
XP_U32 nowSeconds ) XP_U32 nowSeconds )
{ {
XWStreamCtxt* stream = mkStream( state ); XWStreamCtxt* stream = mkStream( state );
headerToStream( stream, cmd, gameID ); headerToStream( stream, cmd, port, gameID );
stream_putBytes( stream, buf, buflen ); stream_putBytes( stream, buf, buflen );
MsgRec* mRec = XP_CALLOC( state->mpool, sizeof(*rec) ); MsgRec* mRec = XP_CALLOC( state->mpool, sizeof(*rec) );
@ -677,7 +693,7 @@ restorePartials( SMSProto* state )
static SMSMsgArray* static SMSMsgArray*
completeMsgs( SMSProto* state, SMSMsgArray* arr, const XP_UCHAR* fromPhone, completeMsgs( SMSProto* state, SMSMsgArray* arr, const XP_UCHAR* fromPhone,
int msgID ) XP_U16 wantPort, int msgID )
{ {
int fromPhoneIndex, msgIDIndex; int fromPhoneIndex, msgIDIndex;
MsgIDRec* rec = getMsgIDRec( state, fromPhone, msgID, XP_FALSE, MsgIDRec* rec = getMsgIDRec( state, fromPhone, msgID, XP_FALSE,
@ -705,16 +721,22 @@ completeMsgs( SMSProto* state, SMSMsgArray* arr, const XP_UCHAR* fromPhone,
} }
XP_U32 gameID; XP_U32 gameID;
XP_U16 port;
SMS_CMD cmd; SMS_CMD cmd;
if ( headerFromStream( stream, &cmd, &gameID ) ) { if ( headerFromStream( stream, &cmd, &port, &gameID ) ) {
XP_U16 len = stream_getSize( stream ); XP_U16 len = stream_getSize( stream );
SMSMsgLoc msg = { .len = len, SMSMsgLoc msg = { .len = len,
.cmd = cmd, .cmd = cmd,
.gameID = gameID, .gameID = gameID,
.data = XP_MALLOC( state->mpool, len ), .data = XP_MALLOC( state->mpool, len ),
}; };
stream_getBytes( stream, msg.data, len ); if ( stream_gotBytes( stream, msg.data, len ) && port == wantPort ) {
arr = appendLocMsg( state, arr, &msg ); arr = appendLocMsg( state, arr, &msg );
} else {
XP_LOGF( "%s(): expected port %d, got %d", __func__,
wantPort, port );
XP_FREEP( state->mpool, &msg.data );
}
} }
stream_destroy( stream ); stream_destroy( stream );
@ -884,7 +906,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
if (!!arrs[ii] && indx < arrs[ii]->nMsgs) { if (!!arrs[ii] && indx < arrs[ii]->nMsgs) {
XP_ASSERT( arrs[ii]->format == FORMAT_NET ); XP_ASSERT( arrs[ii]->format == FORMAT_NET );
haveOne = XP_TRUE; haveOne = XP_TRUE;
SMSMsgArray* outArr = smsproto_prepInbound( state, phones[ii], SMSMsgArray* outArr = smsproto_prepInbound( state, phones[ii], port,
arrs[ii]->u.msgsNet[indx].data, arrs[ii]->u.msgsNet[indx].data,
arrs[ii]->u.msgsNet[indx].len ); arrs[ii]->u.msgsNet[indx].len );
if ( !!outArr ) { if ( !!outArr ) {
@ -922,7 +944,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
XP_ASSERT( sendArr->format == FORMAT_NET ); XP_ASSERT( sendArr->format == FORMAT_NET );
int totalBack = 0; int totalBack = 0;
for ( int jj = 0; jj < sendArr->nMsgs; ++jj ) { for ( int jj = 0; jj < sendArr->nMsgs; ++jj ) {
SMSMsgArray* recvArr = smsproto_prepInbound( state, phones[0], SMSMsgArray* recvArr = smsproto_prepInbound( state, phones[0], port,
sendArr->u.msgsNet[jj].data, sendArr->u.msgsNet[jj].data,
sendArr->u.msgsNet[jj].len ); sendArr->u.msgsNet[jj].len );
@ -955,7 +977,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
XP_ASSERT( !!arr && arr->nMsgs > 1 ); XP_ASSERT( !!arr && arr->nMsgs > 1 );
/* add only part 1 */ /* add only part 1 */
SMSMsgArray* out = smsproto_prepInbound( state, "33333", arr->u.msgsNet[0].data, SMSMsgArray* out = smsproto_prepInbound( state, "33333", port, arr->u.msgsNet[0].data,
arr->u.msgsNet[0].len ); arr->u.msgsNet[0].len );
XP_ASSERT( !out ); XP_ASSERT( !out );
smsproto_freeMsgArray( state, arr ); smsproto_freeMsgArray( state, arr );
@ -965,7 +987,7 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
arr = smsproto_prepOutbound( state, DEATH, gameID, NULL, 0, "33333", arr = smsproto_prepOutbound( state, DEATH, gameID, NULL, 0, "33333",
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
XP_ASSERT( arr->format == FORMAT_NET ); XP_ASSERT( arr->format == FORMAT_NET );
out = smsproto_prepInbound( state, "33333", out = smsproto_prepInbound( state, "33333", port,
arr->u.msgsNet[0].data, arr->u.msgsNet[0].data,
arr->u.msgsNet[0].len ); arr->u.msgsNet[0].len );
XP_ASSERT( out->format == FORMAT_LOC ); XP_ASSERT( out->format == FORMAT_LOC );
@ -975,12 +997,23 @@ smsproto_runTests( MPFORMAL XW_DUtilCtxt* dutil )
smsproto_freeMsgArray( state, out ); smsproto_freeMsgArray( state, out );
XP_LOGF( "%s(): DEATH checked out", __func__ ); XP_LOGF( "%s(): DEATH checked out", __func__ );
/* Test port mismatch */
arr = smsproto_prepOutbound( state, DEATH, gameID, NULL, 0, "33333",
port, XP_TRUE, &waitSecs );
XP_ASSERT( arr->format == FORMAT_NET );
out = smsproto_prepInbound( state, "33333", port + 1,
arr->u.msgsNet[0].data,
arr->u.msgsNet[0].len );
XP_ASSERT( out == NULL );
smsproto_freeMsgArray( state, arr );
XP_LOGF( "%s(): mismatched port test done", __func__ );
/* now a message that's unpacked across multiple sessions to test store/load */ /* now a message that's unpacked across multiple sessions to test store/load */
XP_LOGF( "%s(): testing store/restore", __func__ ); XP_LOGF( "%s(): testing store/restore", __func__ );
arr = smsproto_prepOutbound( state, DATA, gameID, (XP_U8*)buf, 200, "33333", arr = smsproto_prepOutbound( state, DATA, gameID, (XP_U8*)buf, 200, "33333",
port, XP_TRUE, &waitSecs ); port, XP_TRUE, &waitSecs );
for ( int ii = 0; ii < arr->nMsgs; ++ii ) { for ( int ii = 0; ii < arr->nMsgs; ++ii ) {
SMSMsgArray* out = smsproto_prepInbound( state, "33333", SMSMsgArray* out = smsproto_prepInbound( state, "33333", port,
arr->u.msgsNet[ii].data, arr->u.msgsNet[ii].data,
arr->u.msgsNet[ii].len ); arr->u.msgsNet[ii].len );
if ( !!out ) { if ( !!out ) {

View file

@ -98,7 +98,7 @@ SMSMsgArray* smsproto_prepOutbound( SMSProto* state, SMS_CMD cmd,
/* When a message is received, pass it in for reassambly. Non-null return /* When a message is received, pass it in for reassambly. Non-null return
means one or more messages is ready for consumption. */ means one or more messages is ready for consumption. */
SMSMsgArray* smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone, SMSMsgArray* smsproto_prepInbound( SMSProto* state, const XP_UCHAR* fromPhone,
const XP_U8* data, XP_U16 len ); XP_U16 wantPort, const XP_U8* data, XP_U16 len );
void smsproto_freeMsgArray( SMSProto* state, SMSMsgArray* arr ); void smsproto_freeMsgArray( SMSProto* state, SMSMsgArray* arr );

View file

@ -233,7 +233,7 @@ parseAndDispatch( LaunchParams* params, uint8_t* buf, int len,
LinSMSData* storage = getStorage( params ); LinSMSData* storage = getStorage( params );
const XP_UCHAR* fromPhone = addr->u.sms.phone; const XP_UCHAR* fromPhone = addr->u.sms.phone;
SMSMsgArray* arr = smsproto_prepInbound( storage->protoState, fromPhone, SMSMsgArray* arr = smsproto_prepInbound( storage->protoState, fromPhone,
buf, len ); storage->myPort, buf, len );
if ( NULL != arr ) { if ( NULL != arr ) {
XP_ASSERT( arr->format == FORMAT_LOC ); XP_ASSERT( arr->format == FORMAT_LOC );
for ( XP_U16 ii = 0; ii < arr->nMsgs; ++ii ) { for ( XP_U16 ii = 0; ii < arr->nMsgs; ++ii ) {