VancedMicroG/play-services-core/src/main/java/org/microg/gms/gcm/PushRegisterService.java

205 lines
8.2 KiB
Java
Raw Normal View History

2015-02-23 23:16:03 +00:00
/*
* Copyright 2013-2015 microG Project Team
2015-02-23 23:16:03 +00:00
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.microg.gms.gcm;
import android.app.IntentService;
import android.app.PendingIntent;
2015-03-23 01:14:07 +00:00
import android.content.Context;
2015-02-23 23:16:03 +00:00
import android.content.Intent;
import android.os.Build;
2015-03-09 23:22:28 +00:00
import android.os.Message;
import android.os.Messenger;
2015-02-23 23:16:03 +00:00
import android.util.Log;
2016-03-23 21:42:53 +00:00
import org.microg.gms.checkin.CheckinService;
2015-03-23 01:14:07 +00:00
import org.microg.gms.checkin.LastCheckinInfo;
import org.microg.gms.common.PackageUtils;
import org.microg.gms.common.Utils;
import java.io.IOException;
import static org.microg.gms.gcm.GcmConstants.ACTION_C2DM_REGISTER;
import static org.microg.gms.gcm.GcmConstants.ACTION_C2DM_REGISTRATION;
import static org.microg.gms.gcm.GcmConstants.ACTION_C2DM_UNREGISTER;
import static org.microg.gms.gcm.GcmConstants.ERROR_SERVICE_NOT_AVAILABLE;
import static org.microg.gms.gcm.GcmConstants.EXTRA_APP;
2016-03-23 21:42:53 +00:00
import static org.microg.gms.gcm.GcmConstants.EXTRA_DELETE;
import static org.microg.gms.gcm.GcmConstants.EXTRA_ERROR;
import static org.microg.gms.gcm.GcmConstants.EXTRA_MESSENGER;
import static org.microg.gms.gcm.GcmConstants.EXTRA_REGISTRATION_ID;
import static org.microg.gms.gcm.GcmConstants.EXTRA_RETRY_AFTER;
import static org.microg.gms.gcm.GcmConstants.EXTRA_SENDER;
import static org.microg.gms.gcm.GcmConstants.EXTRA_UNREGISTERED;
2015-02-23 23:16:03 +00:00
public class PushRegisterService extends IntentService {
2015-03-01 13:54:31 +00:00
private static final String TAG = "GmsGcmRegisterSvc";
2016-03-23 21:42:53 +00:00
private static final String EXTRA_SKIP_TRY_CHECKIN = "skip_checkin";
private GcmData gcmStorage = new GcmData(this);
2015-02-23 23:16:03 +00:00
public PushRegisterService() {
super(TAG);
setIntentRedelivery(false);
}
public static RegisterResponse register(Context context, String app, String appSignature, String sender, String info) {
RegisterResponse response = register(context, app, appSignature, sender, info, false);
String regId = response.token;
if (regId != null) {
2016-09-17 00:22:04 +00:00
(new GcmData(context)).noteAppRegistered(app, appSignature, regId);
} else {
2016-09-17 00:22:04 +00:00
(new GcmData(context)).noteAppRegistrationError(app, appSignature);
}
return response;
}
public static RegisterResponse unregister(Context context, String app, String appSignature, String sender, String info) {
RegisterResponse response = register(context, app, appSignature, sender, info, true);
if (!app.equals(response.deleted)) {
2016-09-17 00:22:04 +00:00
(new GcmData(context)).noteAppUnregistrationError(app, appSignature);
} else {
2016-09-17 00:22:04 +00:00
(new GcmData(context)).noteAppUnregistered(app, appSignature);
}
return response;
2015-02-23 23:16:03 +00:00
}
@Override
protected void onHandleIntent(Intent intent) {
Log.d(TAG, "onHandleIntent: " + intent);
2016-03-23 21:42:53 +00:00
if (LastCheckinInfo.read(this).lastCheckin > 0) {
try {
if (ACTION_C2DM_UNREGISTER.equals(intent.getAction()) ||
(ACTION_C2DM_REGISTER.equals(intent.getAction()) && "1".equals(intent.getStringExtra(EXTRA_DELETE)))) {
unregister(intent);
} else if (ACTION_C2DM_REGISTER.equals(intent.getAction())) {
register(intent);
}
} catch (Exception e) {
Log.w(TAG, e);
2015-02-23 23:16:03 +00:00
}
2016-03-23 21:42:53 +00:00
} else if (!intent.getBooleanExtra(EXTRA_SKIP_TRY_CHECKIN, false)) {
Log.d(TAG, "No checkin yet, trying to checkin");
intent.putExtra(EXTRA_SKIP_TRY_CHECKIN, true);
Intent subIntent = new Intent(this, CheckinService.class);
subIntent.putExtra(CheckinService.EXTRA_FORCE_CHECKIN, true);
subIntent.putExtra(CheckinService.EXTRA_CALLBACK_INTENT, intent);
startService(subIntent);
2015-02-23 23:16:03 +00:00
}
}
@SuppressWarnings("deprecation")
private String packageFromPendingIntent(PendingIntent pi) {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.JELLY_BEAN_MR1) {
return pi.getTargetPackage();
} else {
return pi.getCreatorPackage();
}
}
private void register(Intent intent) {
PendingIntent pendingIntent = intent.getParcelableExtra(EXTRA_APP);
String sender = intent.getStringExtra(EXTRA_SENDER);
2015-02-23 23:16:03 +00:00
String app = packageFromPendingIntent(pendingIntent);
Log.d(TAG, "register[req]: " + intent.toString() + " extras=" + intent.getExtras());
Intent outIntent = new Intent(ACTION_C2DM_REGISTRATION);
String appSignature = PackageUtils.firstSignatureDigest(this, app);
String regId = register(this, app, appSignature, sender, null).token;
2015-02-23 23:16:03 +00:00
if (regId != null) {
outIntent.putExtra(EXTRA_REGISTRATION_ID, regId);
2015-02-23 23:16:03 +00:00
} else {
outIntent.putExtra(EXTRA_ERROR, ERROR_SERVICE_NOT_AVAILABLE);
2015-02-23 23:16:03 +00:00
}
Log.d(TAG, "register[res]: " + outIntent + " extras=" + outIntent.getExtras());
2015-03-09 23:22:28 +00:00
try {
if (intent.hasExtra(EXTRA_MESSENGER)) {
Messenger messenger = intent.getParcelableExtra(EXTRA_MESSENGER);
2015-03-09 23:22:28 +00:00
Message message = Message.obtain();
message.obj = outIntent;
messenger.send(message);
return;
}
} catch (Exception e) {
Log.w(TAG, e);
}
outIntent.setPackage(app);
2015-02-23 23:16:03 +00:00
sendOrderedBroadcast(outIntent, null);
}
public static RegisterResponse register(Context context, String app, String appSignature, String sender, String info, boolean delete) {
2015-03-23 01:14:07 +00:00
try {
RegisterResponse response = new RegisterRequest()
2015-03-23 01:14:07 +00:00
.build(Utils.getBuild(context))
.sender(sender)
.info(info)
.checkin(LastCheckinInfo.read(context))
.app(app, appSignature, PackageUtils.versionCode(context, app))
.delete(delete)
.getResponse();
Log.d(TAG, "received response: " + response);
return response;
2015-03-23 01:14:07 +00:00
} catch (IOException e) {
Log.w(TAG, e);
}
return new RegisterResponse();
2015-03-23 01:14:07 +00:00
}
2015-02-23 23:16:03 +00:00
private void unregister(Intent intent) {
PendingIntent pendingIntent = intent.getParcelableExtra(EXTRA_APP);
String app = packageFromPendingIntent(pendingIntent);
Log.d(TAG, "unregister[req]: " + intent.toString() + " extras=" + intent.getExtras());
Intent outIntent = new Intent(ACTION_C2DM_REGISTRATION);
String appSignature = PackageUtils.firstSignatureDigest(this, app);
if (!gcmStorage.getAppInfo(app, appSignature).isRemoved()) {
outIntent.putExtra(EXTRA_UNREGISTERED, app);
} else {
RegisterResponse response = unregister(this, app, appSignature, null, null);
if (!app.equals(response.deleted)) {
outIntent.putExtra(EXTRA_ERROR, ERROR_SERVICE_NOT_AVAILABLE);
if (response.retryAfter != null && !response.retryAfter.contains(":")) {
outIntent.putExtra(EXTRA_RETRY_AFTER, Long.parseLong(response.retryAfter));
}
} else {
outIntent.putExtra(EXTRA_UNREGISTERED, app);
}
}
2015-02-23 23:16:03 +00:00
Log.d(TAG, "unregister[res]: " + outIntent.toString() + " extras=" + outIntent.getExtras());
try {
if (intent.hasExtra(EXTRA_MESSENGER)) {
Messenger messenger = intent.getParcelableExtra(EXTRA_MESSENGER);
Message message = Message.obtain();
message.obj = outIntent;
messenger.send(message);
return;
}
} catch (Exception e) {
Log.w(TAG, e);
}
outIntent.setPackage(app);
sendOrderedBroadcast(outIntent, null);
2015-02-23 23:16:03 +00:00
}
}