2020-04-25 17:47:07 -07:00
|
|
|
/* -*-mode: C; compile-command: "find-and-gradle.sh inXw4dDeb"; -*- */
|
2010-01-30 14:33:28 +00:00
|
|
|
/*
|
2023-01-31 08:36:49 -08:00
|
|
|
* Copyright 2001 - 2023 by Eric House (xwords@eehouse.org). All rights
|
2010-01-30 14:33:28 +00:00
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "xportwrapper.h"
|
|
|
|
#include "andutils.h"
|
2017-01-22 14:15:29 -08:00
|
|
|
#include "dbgutil.h"
|
2012-02-13 22:13:23 -08:00
|
|
|
#include "paths.h"
|
2010-01-30 14:33:28 +00:00
|
|
|
|
|
|
|
typedef struct _AndTransportProcs {
|
|
|
|
TransportProcs tp;
|
2020-04-26 13:35:11 -07:00
|
|
|
#ifdef MAP_THREAD_TO_ENV
|
|
|
|
EnvThreadInfo* ti;
|
|
|
|
#endif
|
2010-02-09 14:20:16 +00:00
|
|
|
jobject jxport;
|
2010-01-30 14:33:28 +00:00
|
|
|
MPSLOT
|
|
|
|
} AndTransportProcs;
|
|
|
|
|
2011-08-16 19:31:08 -07:00
|
|
|
static XP_U32
|
2020-04-25 17:47:07 -07:00
|
|
|
and_xport_getFlags( XWEnv xwe, void* closure )
|
2011-08-16 19:31:08 -07:00
|
|
|
{
|
2014-12-02 06:08:58 -08:00
|
|
|
jint result = COMMS_XPORT_FLAGS_NONE;
|
2011-08-16 19:31:08 -07:00
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
2020-04-26 13:35:11 -07:00
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
2011-08-16 19:31:08 -07:00
|
|
|
if ( NULL != aprocs->jxport ) {
|
2020-04-25 17:47:07 -07:00
|
|
|
JNIEnv* env = xwe;
|
2011-08-16 19:31:08 -07:00
|
|
|
const char* sig = "()I";
|
|
|
|
jmethodID mid = getMethodID( env, aprocs->jxport, "getFlags", sig );
|
|
|
|
|
|
|
|
result = (*env)->CallIntMethod( env, aprocs->jxport, mid );
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2022-08-27 17:08:54 -07:00
|
|
|
#ifdef XWFEATURE_COMMS_INVITE
|
|
|
|
static XP_S16
|
2022-09-08 09:57:11 -07:00
|
|
|
and_xport_sendInvite( XWEnv xwe, const NetLaunchInfo* nli, XP_U32 createdStamp,
|
2023-01-24 17:11:05 -08:00
|
|
|
const CommsAddrRec* addr, CommsConnType conType, void* closure )
|
2022-08-27 17:08:54 -07:00
|
|
|
{
|
2022-09-07 10:20:08 -07:00
|
|
|
LOG_FUNC();
|
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
|
|
|
if ( NULL != aprocs->jxport ) {
|
|
|
|
JNIEnv* env = xwe;
|
|
|
|
const char* sig = "(L" PKG_PATH("jni/CommsAddrRec")
|
2023-01-24 17:11:05 -08:00
|
|
|
";L" PKG_PATH("jni/CommsAddrRec$CommsConnType")
|
2022-09-07 10:20:08 -07:00
|
|
|
";L" PKG_PATH("NetLaunchInfo") ";I)Z";
|
|
|
|
|
|
|
|
jmethodID mid = getMethodID( env, aprocs->jxport, "transportSendInvt", sig );
|
|
|
|
|
|
|
|
jobject jaddr = makeJAddr( env, addr );
|
2023-01-31 08:36:49 -08:00
|
|
|
jobject jnli = makeObjectEmptyConstr( env, PKG_PATH("NetLaunchInfo") );
|
2022-09-07 10:20:08 -07:00
|
|
|
XP_ASSERT( !!jnli );
|
|
|
|
setNLI( env, jnli, nli );
|
2023-01-24 17:11:05 -08:00
|
|
|
jobject jConType =
|
|
|
|
intToJEnum( env, conType, PKG_PATH("jni/CommsAddrRec$CommsConnType"));
|
2022-09-07 10:20:08 -07:00
|
|
|
|
|
|
|
/*jboolean success = */(*env)->CallBooleanMethod( env, aprocs->jxport, mid,
|
2023-01-24 17:11:05 -08:00
|
|
|
jaddr, jConType, jnli,
|
|
|
|
createdStamp );
|
|
|
|
deleteLocalRefs( env, jaddr, jnli, jConType, DELETE_NO_REF );
|
2022-09-07 10:20:08 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
LOG_RETURN_VOID();
|
|
|
|
return -1; /* asserts otherwise */
|
2022-08-27 17:08:54 -07:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-01-30 14:33:28 +00:00
|
|
|
static XP_S16
|
2020-04-25 17:47:07 -07:00
|
|
|
and_xport_send( XWEnv xwe, const XP_U8* buf, XP_U16 len,
|
2022-06-29 12:29:32 -07:00
|
|
|
const XP_UCHAR* msgNo, XP_U32 timestamp,
|
|
|
|
const CommsAddrRec* addr, CommsConnType conType,
|
|
|
|
XP_U32 gameID, void* closure )
|
2010-01-30 14:33:28 +00:00
|
|
|
{
|
2010-02-09 14:20:16 +00:00
|
|
|
jint result = -1;
|
2010-01-30 14:33:28 +00:00
|
|
|
LOG_FUNC();
|
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
2020-04-26 13:35:11 -07:00
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
2010-02-09 14:20:16 +00:00
|
|
|
if ( NULL != aprocs->jxport ) {
|
2020-04-25 17:47:07 -07:00
|
|
|
JNIEnv* env = xwe;
|
2015-09-30 06:50:04 -07:00
|
|
|
const char* sig = "([BLjava/lang/String;L" PKG_PATH("jni/CommsAddrRec")
|
2022-06-29 12:29:32 -07:00
|
|
|
";L" PKG_PATH("jni/CommsAddrRec$CommsConnType") ";II)I";
|
2014-11-26 07:18:29 -08:00
|
|
|
|
2022-09-08 09:57:11 -07:00
|
|
|
jmethodID mid = getMethodID( env, aprocs->jxport, "transportSendMsg", sig );
|
2010-01-30 14:33:28 +00:00
|
|
|
|
2010-02-12 07:13:42 +00:00
|
|
|
jbyteArray jbytes = makeByteArray( env, len, (jbyte*)buf );
|
2010-02-09 14:20:16 +00:00
|
|
|
jobject jaddr = makeJAddr( env, addr );
|
2014-11-26 07:18:29 -08:00
|
|
|
jobject jConType =
|
|
|
|
intToJEnum(env, conType, PKG_PATH("jni/CommsAddrRec$CommsConnType"));
|
2015-09-30 06:50:04 -07:00
|
|
|
jstring jMsgNo = !!msgNo ? (*env)->NewStringUTF( env, msgNo ) : NULL;
|
2010-02-09 14:20:16 +00:00
|
|
|
result = (*env)->CallIntMethod( env, aprocs->jxport, mid,
|
2022-06-29 12:29:32 -07:00
|
|
|
jbytes, jMsgNo, jaddr, jConType,
|
|
|
|
gameID, timestamp );
|
2015-09-30 06:50:04 -07:00
|
|
|
deleteLocalRefs( env, jaddr, jbytes, jMsgNo, jConType, DELETE_NO_REF );
|
2010-02-09 14:20:16 +00:00
|
|
|
}
|
2019-02-26 18:46:55 -08:00
|
|
|
|
|
|
|
if ( result < len ) {
|
2020-12-06 21:27:12 -08:00
|
|
|
XP_LOGFF( "changing result %d to -1", result );
|
2019-02-26 18:46:55 -08:00
|
|
|
result = -1; /* signal failure. Not sure where 0's coming from */
|
|
|
|
}
|
|
|
|
|
2010-01-30 20:06:06 +00:00
|
|
|
LOG_RETURNF( "%d", result );
|
2010-01-30 14:33:28 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2022-04-28 14:35:55 -07:00
|
|
|
static void
|
|
|
|
and_xport_countChanged( XWEnv xwe, void* closure, XP_U16 count )
|
|
|
|
{
|
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
|
|
|
if ( NULL != aprocs && NULL != aprocs->jxport ) {
|
|
|
|
JNIEnv* env = xwe;
|
|
|
|
const char* sig = "(I)V";
|
|
|
|
jmethodID mid = getMethodID( env, aprocs->jxport, "countChanged", sig );
|
|
|
|
(*env)->CallVoidMethod( env, aprocs->jxport, mid, count );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XWFEATURE_RELAY
|
2010-01-30 14:33:28 +00:00
|
|
|
static void
|
2020-04-25 17:47:07 -07:00
|
|
|
and_xport_relayStatus( XWEnv XP_UNUSED(xwe), void* XP_UNUSED(closure),
|
|
|
|
CommsRelayState XP_UNUSED(newState) )
|
2010-01-30 14:33:28 +00:00
|
|
|
{
|
2022-04-27 18:05:57 -07:00
|
|
|
XP_ASSERT(0);
|
2010-01-30 14:33:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2020-04-25 17:47:07 -07:00
|
|
|
and_xport_relayConnd( XWEnv xwe, void* closure, XP_UCHAR* const room,
|
|
|
|
XP_Bool reconnect, XP_U16 devOrder, XP_Bool allHere,
|
|
|
|
XP_U16 nMissing )
|
2010-01-30 14:33:28 +00:00
|
|
|
{
|
2022-04-27 18:05:57 -07:00
|
|
|
XP_ASSERT(0);
|
2010-02-14 17:23:07 +00:00
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
2020-04-26 13:35:11 -07:00
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
2010-02-14 17:23:07 +00:00
|
|
|
if ( NULL != aprocs->jxport ) {
|
2020-04-25 17:47:07 -07:00
|
|
|
JNIEnv* env = xwe;
|
2013-07-08 06:30:26 -07:00
|
|
|
const char* sig = "(Ljava/lang/String;IZI)V";
|
2010-02-14 17:23:07 +00:00
|
|
|
jmethodID mid = getMethodID( env, aprocs->jxport, "relayConnd", sig );
|
|
|
|
|
2010-10-28 18:46:28 -07:00
|
|
|
jstring str = (*env)->NewStringUTF( env, room );
|
2010-02-14 17:23:07 +00:00
|
|
|
(*env)->CallVoidMethod( env, aprocs->jxport, mid,
|
2013-07-08 06:30:26 -07:00
|
|
|
str, devOrder, allHere, nMissing );
|
2012-09-15 15:57:38 -07:00
|
|
|
deleteLocalRef( env, str );
|
2010-02-14 17:23:07 +00:00
|
|
|
}
|
2010-01-30 14:33:28 +00:00
|
|
|
}
|
|
|
|
|
2011-08-10 18:28:34 -07:00
|
|
|
static XP_Bool
|
2020-04-25 17:47:07 -07:00
|
|
|
and_xport_sendNoConn( XWEnv xwe, const XP_U8* buf, XP_U16 len,
|
|
|
|
const XP_UCHAR* msgNo, const XP_UCHAR* relayID,
|
|
|
|
void* closure )
|
2011-08-10 18:28:34 -07:00
|
|
|
{
|
2022-04-27 18:05:57 -07:00
|
|
|
XP_ASSERT(0);
|
2011-08-10 21:06:05 -07:00
|
|
|
jboolean result = false;
|
2011-08-10 18:28:34 -07:00
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
2020-04-26 13:35:11 -07:00
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
2011-08-10 18:28:34 -07:00
|
|
|
if ( NULL != aprocs && NULL != aprocs->jxport ) {
|
2020-04-25 17:47:07 -07:00
|
|
|
JNIEnv* env = xwe;
|
2011-08-10 21:06:05 -07:00
|
|
|
|
2015-09-30 06:50:04 -07:00
|
|
|
const char* sig = "([BLjava/lang/String;Ljava/lang/String;)Z";
|
2011-08-10 21:06:05 -07:00
|
|
|
jmethodID mid = getMethodID( env, aprocs->jxport,
|
|
|
|
"relayNoConnProc", sig );
|
|
|
|
jbyteArray jbytes = makeByteArray( env, len, (jbyte*)buf );
|
2015-02-26 21:35:45 -08:00
|
|
|
jstring jRelayID = (*env)->NewStringUTF( env, relayID );
|
2015-09-30 06:50:04 -07:00
|
|
|
jstring jMsgNo = !!msgNo ? (*env)->NewStringUTF( env, msgNo ) : NULL;
|
2011-08-10 21:06:05 -07:00
|
|
|
result = (*env)->CallBooleanMethod( env, aprocs->jxport, mid,
|
2015-09-30 06:50:04 -07:00
|
|
|
jbytes, jMsgNo, jRelayID );
|
|
|
|
deleteLocalRefs( env, jbytes, jRelayID, jMsgNo, DELETE_NO_REF );
|
2011-08-10 18:28:34 -07:00
|
|
|
}
|
2017-01-22 14:15:29 -08:00
|
|
|
LOG_RETURNF( "%s", boolToStr(result) );
|
2011-08-10 21:06:05 -07:00
|
|
|
return result;
|
2011-08-10 18:28:34 -07:00
|
|
|
}
|
|
|
|
|
2010-01-30 14:33:28 +00:00
|
|
|
static void
|
2020-04-25 17:47:07 -07:00
|
|
|
and_xport_relayError( XWEnv xwe, void* closure, XWREASON relayErr )
|
2010-01-30 14:33:28 +00:00
|
|
|
{
|
2022-04-27 18:05:57 -07:00
|
|
|
XP_ASSERT(0);
|
2010-02-17 14:37:53 +00:00
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)closure;
|
2020-04-26 13:35:11 -07:00
|
|
|
ASSERT_ENV( aprocs->ti, xwe );
|
2010-02-17 14:37:53 +00:00
|
|
|
if ( NULL != aprocs->jxport ) {
|
2020-04-25 17:47:07 -07:00
|
|
|
JNIEnv* env = xwe;
|
2010-02-17 14:37:53 +00:00
|
|
|
jmethodID mid;
|
2012-02-13 22:13:23 -08:00
|
|
|
const char* sig =
|
|
|
|
"(L" PKG_PATH("jni/TransportProcs$XWRELAY_ERROR") ";)V";
|
2010-02-17 14:37:53 +00:00
|
|
|
mid = getMethodID( env, aprocs->jxport, "relayErrorProc", sig );
|
|
|
|
|
2012-02-13 22:13:23 -08:00
|
|
|
jobject jenum = intToJEnum( env, relayErr,
|
|
|
|
PKG_PATH("jni/TransportProcs$XWRELAY_ERROR") );
|
2010-02-17 14:37:53 +00:00
|
|
|
(*env)->CallVoidMethod( env, aprocs->jxport, mid, jenum );
|
|
|
|
|
2012-09-15 15:57:38 -07:00
|
|
|
deleteLocalRef( env, jenum );
|
2010-02-17 14:37:53 +00:00
|
|
|
}
|
2010-01-30 14:33:28 +00:00
|
|
|
}
|
2022-04-28 14:35:55 -07:00
|
|
|
#endif
|
2010-01-30 14:33:28 +00:00
|
|
|
|
|
|
|
TransportProcs*
|
2020-04-26 13:35:11 -07:00
|
|
|
makeXportProcs( MPFORMAL JNIEnv* env,
|
|
|
|
#ifdef MAP_THREAD_TO_ENV
|
|
|
|
EnvThreadInfo* ti,
|
|
|
|
#endif
|
|
|
|
jobject jxport )
|
2010-01-30 14:33:28 +00:00
|
|
|
{
|
2023-01-04 14:13:18 -08:00
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)
|
|
|
|
XP_CALLOC( mpool, sizeof(*aprocs) );
|
2020-04-26 13:35:11 -07:00
|
|
|
#ifdef MAP_THREAD_TO_ENV
|
|
|
|
aprocs->ti = ti;
|
|
|
|
#endif
|
2010-01-30 14:33:28 +00:00
|
|
|
if ( NULL != jxport ) {
|
2010-02-09 14:20:16 +00:00
|
|
|
aprocs->jxport = (*env)->NewGlobalRef( env, jxport );
|
2010-01-30 14:33:28 +00:00
|
|
|
}
|
2010-02-09 14:20:16 +00:00
|
|
|
MPASSIGN( aprocs->mpool, mpool );
|
|
|
|
|
2011-08-16 19:31:08 -07:00
|
|
|
#ifdef COMMS_XPORT_FLAGSPROC
|
|
|
|
aprocs->tp.getFlags = and_xport_getFlags;
|
|
|
|
#endif
|
2022-08-27 17:08:54 -07:00
|
|
|
aprocs->tp.sendMsg = and_xport_send;
|
|
|
|
#ifdef XWFEATURE_COMMS_INVITE
|
|
|
|
aprocs->tp.sendInvt = and_xport_sendInvite;
|
|
|
|
#endif
|
2022-04-28 14:35:55 -07:00
|
|
|
#ifdef XWFEATURE_RELAY
|
2010-02-09 14:20:16 +00:00
|
|
|
aprocs->tp.rstatus = and_xport_relayStatus;
|
|
|
|
aprocs->tp.rconnd = and_xport_relayConnd;
|
|
|
|
aprocs->tp.rerror = and_xport_relayError;
|
2011-08-10 18:28:34 -07:00
|
|
|
aprocs->tp.sendNoConn = and_xport_sendNoConn;
|
2022-04-28 14:35:55 -07:00
|
|
|
#endif
|
2019-12-10 14:42:54 -08:00
|
|
|
aprocs->tp.countChanged = and_xport_countChanged;
|
2010-02-09 14:20:16 +00:00
|
|
|
aprocs->tp.closure = aprocs;
|
2010-01-30 14:33:28 +00:00
|
|
|
|
|
|
|
return (TransportProcs*)aprocs;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2020-04-25 17:47:07 -07:00
|
|
|
destroyXportProcs( TransportProcs** xport, JNIEnv* env )
|
2010-01-30 14:33:28 +00:00
|
|
|
{
|
2022-09-28 07:24:45 -07:00
|
|
|
if ( !!*xport ) {
|
|
|
|
AndTransportProcs* aprocs = (AndTransportProcs*)*xport;
|
|
|
|
if ( NULL != aprocs->jxport ) {
|
|
|
|
(*env)->DeleteGlobalRef( env, aprocs->jxport );
|
|
|
|
}
|
2010-02-09 14:20:16 +00:00
|
|
|
|
2022-09-28 07:24:45 -07:00
|
|
|
XP_FREE( aprocs->mpool, aprocs );
|
|
|
|
*xport = NULL;
|
|
|
|
}
|
2010-01-30 14:33:28 +00:00
|
|
|
}
|