mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-03 23:04:08 +01:00
use new DB api to build list of relayIDs to send; set summary DB field
and post notification on response.
This commit is contained in:
parent
3bbbd65077
commit
e855b51491
1 changed files with 36 additions and 44 deletions
|
@ -46,14 +46,15 @@ public class RelayService extends Service {
|
||||||
public void onCreate()
|
public void onCreate()
|
||||||
{
|
{
|
||||||
super.onCreate();
|
super.onCreate();
|
||||||
Utils.logf( "RelayService::onCreate() called" );
|
|
||||||
|
m_nm = (NotificationManager)getSystemService( NOTIFICATION_SERVICE );
|
||||||
|
|
||||||
Thread thread = new Thread( null, new Runnable() {
|
Thread thread = new Thread( null, new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
|
|
||||||
int[] nBytes = new int[1];
|
int[] nBytes = new int[1];
|
||||||
ArrayList<String>ids = collectIDs( nBytes );
|
String[] ids = collectIDs( nBytes );
|
||||||
if ( null != ids && 0 < ids.size() ) {
|
if ( null != ids && 0 < ids.length ) {
|
||||||
try {
|
try {
|
||||||
Socket socket =
|
Socket socket =
|
||||||
NetUtils.MakeProxySocket( RelayService.this,
|
NetUtils.MakeProxySocket( RelayService.this,
|
||||||
|
@ -62,22 +63,19 @@ public class RelayService extends Service {
|
||||||
new DataOutputStream( socket.getOutputStream() );
|
new DataOutputStream( socket.getOutputStream() );
|
||||||
|
|
||||||
// total packet size
|
// total packet size
|
||||||
outStream.writeShort( 2 + nBytes[0] + ids.size() + 1 );
|
outStream.writeShort( 2 + nBytes[0] + ids.length + 1 );
|
||||||
Utils.logf( "total packet size: %d",
|
Utils.logf( "total packet size: %d",
|
||||||
2 + nBytes[0] + ids.size() );
|
2 + nBytes[0] + ids.length );
|
||||||
|
|
||||||
outStream.writeByte( NetUtils.PROTOCOL_VERSION );
|
outStream.writeByte( NetUtils.PROTOCOL_VERSION );
|
||||||
outStream.writeByte( NetUtils.PRX_HAS_MSGS );
|
outStream.writeByte( NetUtils.PRX_HAS_MSGS );
|
||||||
|
|
||||||
// number of ids
|
// number of ids
|
||||||
outStream.writeShort( ids.size() );
|
outStream.writeShort( ids.length );
|
||||||
Utils.logf( "wrote count %d to proxy socket",
|
Utils.logf( "wrote count %d to proxy socket",
|
||||||
ids.size() );
|
ids.length );
|
||||||
|
|
||||||
for ( String id : ids ) {
|
for ( String id : ids ) {
|
||||||
// outStream.writeShort( id.length );
|
|
||||||
// Utils.logf( "wrote length %d to proxy socket",
|
|
||||||
// id.length );
|
|
||||||
outStream.writeBytes( id );
|
outStream.writeBytes( id );
|
||||||
outStream.write( '\n' );
|
outStream.write( '\n' );
|
||||||
}
|
}
|
||||||
|
@ -89,7 +87,7 @@ public class RelayService extends Service {
|
||||||
short result = dis.readShort();
|
short result = dis.readShort();
|
||||||
short nameCount = dis.readShort();
|
short nameCount = dis.readShort();
|
||||||
short[] msgCounts = null;
|
short[] msgCounts = null;
|
||||||
if ( nameCount == ids.size() ) {
|
if ( nameCount == ids.length ) {
|
||||||
msgCounts = new short[nameCount];
|
msgCounts = new short[nameCount];
|
||||||
for ( int ii = 0; ii < nameCount; ++ii ) {
|
for ( int ii = 0; ii < nameCount; ++ii ) {
|
||||||
msgCounts[ii] = dis.readShort();
|
msgCounts[ii] = dis.readShort();
|
||||||
|
@ -106,10 +104,12 @@ public class RelayService extends Service {
|
||||||
String msg =
|
String msg =
|
||||||
String.format("%d messages for %s",
|
String.format("%d messages for %s",
|
||||||
msgCounts[ii],
|
msgCounts[ii],
|
||||||
ids.get(ii).toString() );
|
ids[ii] );
|
||||||
Utils.logf( msg );
|
Utils.logf( msg );
|
||||||
|
DBUtils.setHasMsgs( ids[ii] );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
setupNotification();
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch( java.net.UnknownHostException uhe ) {
|
} catch( java.net.UnknownHostException uhe ) {
|
||||||
|
@ -150,40 +150,32 @@ public class RelayService extends Service {
|
||||||
// return 0;
|
// return 0;
|
||||||
// }
|
// }
|
||||||
|
|
||||||
// private void setupNotification()
|
private void setupNotification()
|
||||||
// {
|
|
||||||
// m_nm = (NotificationManager)getSystemService( NOTIFICATION_SERVICE );
|
|
||||||
|
|
||||||
// Notification notification =
|
|
||||||
// new Notification( R.drawable.icon48x48, "foo",
|
|
||||||
// System.currentTimeMillis());
|
|
||||||
|
|
||||||
// PendingIntent intent = PendingIntent
|
|
||||||
// .getActivity( this, 0, new Intent(this, BoardActivity.class), 0);
|
|
||||||
|
|
||||||
// notification.setLatestEventInfo( this, "bazz", "bar", intent );
|
|
||||||
|
|
||||||
// m_nm.notify( R.string.running_notification, notification );
|
|
||||||
// }
|
|
||||||
|
|
||||||
private ArrayList<String> collectIDs( int[] nBytes )
|
|
||||||
{
|
{
|
||||||
nBytes[0] = 0;
|
Notification notification =
|
||||||
ArrayList<String> ids = new ArrayList<String>();
|
new Notification( R.drawable.icon48x48,
|
||||||
String[] games = GameUtils.gamesList( this );
|
getString(R.string.notify_title),
|
||||||
for ( String path : games ) {
|
System.currentTimeMillis());
|
||||||
Utils.logf( "looking at %s", path );
|
|
||||||
GameSummary summary = DBUtils.getSummary( this, path );
|
|
||||||
if ( null != summary && null != summary.relayID ) {
|
|
||||||
Utils.logf( "adding id %s with length %d", summary.relayID,
|
|
||||||
summary.relayID.length() );
|
|
||||||
ids.add( summary.relayID );
|
|
||||||
nBytes[0] += summary.relayID.length();
|
|
||||||
} else {
|
|
||||||
Utils.logf( "no summary" );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
Intent intent = new Intent(this, GamesList.class);
|
||||||
|
PendingIntent pi = PendingIntent.getActivity( this, 0, intent, 0);
|
||||||
|
|
||||||
|
notification.setLatestEventInfo( this, "bazz", "bar", pi );
|
||||||
|
|
||||||
|
m_nm.notify( R.string.running_notification, notification );
|
||||||
|
}
|
||||||
|
|
||||||
|
private String[] collectIDs( int[] nBytes )
|
||||||
|
{
|
||||||
|
Utils.logf( "collectIDs" );
|
||||||
|
String[] ids = DBUtils.getRelayIDNoMsgs( this );
|
||||||
|
|
||||||
|
int len = 0;
|
||||||
|
for ( String id : ids ) {
|
||||||
|
Utils.logf( "got relayID: %s", id );
|
||||||
|
len += id.length();
|
||||||
|
}
|
||||||
|
nBytes[0] = len;
|
||||||
return ids;
|
return ids;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue