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:
Andy2 2010-10-08 06:52:43 -07:00
parent 3bbbd65077
commit e855b51491

View file

@ -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 ); Intent intent = new Intent(this, GamesList.class);
if ( null != summary && null != summary.relayID ) { PendingIntent pi = PendingIntent.getActivity( this, 0, intent, 0);
Utils.logf( "adding id %s with length %d", summary.relayID,
summary.relayID.length() ); notification.setLatestEventInfo( this, "bazz", "bar", pi );
ids.add( summary.relayID );
nBytes[0] += summary.relayID.length(); m_nm.notify( R.string.running_notification, notification );
} else {
Utils.logf( "no summary" );
}
} }
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;
} }