当使用gcm和sinch sdk时,android没有在另一端接到电话

时间:2015-03-14 19:48:33

标签: android sinch

我尝试使用gcm在sinch中启动调用,我发送推送通知,然后我在另一端获取它,但是当我尝试启动调用时,我在{{{ 1}}

这是gcm意向服务的一部分,我收到通知并启动sinch服务:

mCall.addCallListener( );

这就是我在sinch服务中所做的事情:

{
            String callId = intent.getExtras().getString("callId");
            Intent intent3 = new Intent(this, SinchClientService.class);
            intent3.setAction(SinchClientService.ACTION_START_CALL);
            intent3.putExtra(SinchClientService.INTENT_EXTRA_CALLID, callId);
            startService(intent3);
        }

这就是我启动sinch客户端的方式:

else if(intent.getAction().equals(ACTION_START_CALL))
            {
                String callId = intent.getStringExtra(INTENT_EXTRA_CALLID);
                if(callId != null)
                {
                    startCall(callId);
                }
            }

public void startCall(String callId) {
        if (mCallClient != null) {
            Call call = mCallClient.getCall(callId);
            CurrentCall.currentCall = call;

            Intent intent = new Intent(this, CallService.class);
            startService(intent);
        }
    }

这是我的onIcommingCall方法:

private void startSinchClient(String id, String userName) {
        mSinchClient = Sinch.getSinchClientBuilder().context(this).userId(id).
                applicationKey(APP_KEY).applicationSecret(APP_SECRET).environmentHost(ENVIRONMENT).build();

        mSinchClient.addSinchClientListener(this);

        mSinchClient.setSupportCalling(true);
        mSinchClient.setSupportMessaging(true);
        mSinchClient.setSupportPushNotifications(true);

        mSinchClient.setSupportActiveConnectionInBackground(false);
        //mSinchClient.startListeningOnActiveConnection();

        mMessageClient = mSinchClient.getMessageClient();
        mMessageClient.addMessageClientListener(this);

        mCallClient = mSinchClient.getCallClient();
        mCallClient.addCallClientListener(this);

        mSinchClient.checkManifest();
        mSinchClient.start();
    }

这是我的调用服务的一部分,我得到空指针异常:

@Override
    public void onIncomingCall(CallClient client, Call call) {
        Log.d(TAG, "Incoming call");

        CurrentCall.currentCall = call;


        Intent intent = new Intent(this, CallService.class);
        startService(intent);
    }

注意:我的呼叫服务实现了呼叫监听器

我从来没有接到电话,有人能帮帮我吗?

修改这是我初始化通话的方式:

在sinch服务中:

if(CurrentCall.currentCall == null)
            stopSelf();

        mCall = CurrentCall.currentCall;
        mCall.addCallListener(this);

在通话服务中:

public void callFriend(String id) {
        if (mCallClient != null) {
            Call call = mCallClient.callUser(id);
            CurrentCall.currentCall = call;

            Intent intent = new Intent(this, CallService.class);
            startService(intent);
        }
    }

最新编辑所以我做了你说的话我只接听了短信活动,我的新代码是:

在通话服务中:

@Override
    public void onShouldSendPushNotification(Call call, List<PushPair> pushPairs) {
        Log.d(LOG_TAG, "Should send push notification");
        Log.d("payload", pushPairs.get(0).getPushPayload());

        asyncTask = new sendPushNotifications(this, call.getRemoteUserId(), pushPairs, call.getCallId());
        asyncTask.execute();
    }

    class sendPushNotifications extends AutoAsyncTask {

        List<PushPair> pushPairs;

        String message;

        String senderId;
        String message_id;
        String time_stamp;
        String callId;

        public sendPushNotifications(Context context, String senderId, List<PushPair> pushPairs, String callId) {
            super(context, false);

            this.pushPairs = pushPairs;
            this.senderId = senderId;
            this.callId = callId;
        }

        @Override
        protected Integer doInBackground(Void... params) {
            boolean connectedToInternet = connManager.getNetworkInfo( ConnectivityManager.TYPE_WIFI).isConnected()
                    || connManager.getNetworkInfo(ConnectivityManager.TYPE_MOBILE).isConnected();
            if (connectedToInternet) 
            {   
                String regId;
                //JSONArray arrayList = new JSONArray();

                for(PushPair p: pushPairs)
                {
                    regId = new String(p.getPushData());
                    //arrayList.put(regId);

                    UserFunctions.sendCallPushNotifications(senderId, regId, "call", callId);
                }

                asyncTask = null;
                return 0;
            } 
            else 
            {
                asyncTask = null;
                return 1;
            }
        }

        @Override
        protected void onPostExecute(Integer result) {
            super.onPostExecute(result);

            if (result == 0) 
            {
                Log.d("call push sent", "sent");
            } 
            else if (result == 1) 
            {
                Toast.makeText(getApplicationContext(),
                        "No Network Connection !!", Toast.LENGTH_SHORT).show();
            } 
            else 
            {
                Toast.makeText(
                        getApplicationContext(),
                        "Error occured,Please Try Again Later !!",
                        Toast.LENGTH_SHORT).show();
            }
        }
    }

}

gcm意向服务:

@Override
    public void onShouldSendPushNotification(Call call, List<PushPair> pushPairs) {
        Log.d(LOG_TAG, "Should send push notification");
        Log.d("payload", pushPairs.get(0).getPushPayload());

        asyncTask = new sendPushNotifications(this, call.getRemoteUserId(), pushPairs, call.getCallId());
        asyncTask.execute();
    }

    class sendPushNotifications extends AutoAsyncTask {

        List<PushPair> pushPairs;

        String message;

        String senderId;
        String message_id;
        String time_stamp;
        String callId;

        public sendPushNotifications(Context context, String senderId, List<PushPair> pushPairs, String callId) {
            super(context, false);

            this.pushPairs = pushPairs;
            this.senderId = senderId;
            this.callId = callId;
        }

        @Override
        protected Integer doInBackground(Void... params) {
            boolean connectedToInternet = connManager.getNetworkInfo( ConnectivityManager.TYPE_WIFI).isConnected()
                    || connManager.getNetworkInfo(ConnectivityManager.TYPE_MOBILE).isConnected();
            if (connectedToInternet) 
            {   
                String regId;
                String payload;
                //JSONArray arrayList = new JSONArray();

                for(PushPair p: pushPairs)
                {
                    regId = new String(p.getPushData());
                    payload = new String(p.getPushPayload());
                    //arrayList.put(regId);

                    UserFunctions.sendCallPushNotifications(senderId, regId, "call", callId, payload);
                }

                asyncTask = null;
                return 0;
            } 
            else 
            {
                asyncTask = null;
                return 1;
            }
        }

        @Override
        protected void onPostExecute(Integer result) {
            super.onPostExecute(result);

            if (result == 0) 
            {
                Log.d("call push sent", "sent");
            } 
            else if (result == 1) 
            {
                Toast.makeText(getApplicationContext(),
                        "No Network Connection !!", Toast.LENGTH_SHORT).show();
            } 
            else 
            {
                Toast.makeText(
                        getApplicationContext(),
                        "Error occured,Please Try Again Later !!",
                        Toast.LENGTH_SHORT).show();
            }
        }
    }

sinch服务:

else
        {
            String callId = intent.getExtras().getString("callId");
            String payload = intent.getExtras().getString("payload");
            Intent intent3 = new Intent(this, SinchClientService.class);
            intent3.setAction(SinchClientService.ACTION_START_CALL);
            intent3.putExtra(SinchClientService.INTENT_EXTRA_CALLID, callId);
            intent3.putExtra(SinchClientService.INTENT_EXTRA_PAYLOAD, payload);
            startService(intent3);
        }

这也是我在绑定和取消绑定服务时所做的事情:

else if(intent.getAction().equals(ACTION_START_CALL))
            {
                String callId = intent.getStringExtra(INTENT_EXTRA_CALLID);
                if(callId != null)
                {
                    startCall(callId);
                }
            }

public void startCall(String callId) {
        /*if (mCallClient != null) {
            Call call = mCallClient.getCall(callId);
            CurrentCall.currentCall = call;

            Intent intent = new Intent(this, CallService.class);
            startService(intent);
        }*/
        if(INTENT_EXTRA_PAYLOAD != null)
        {
            if(mSinchClient.isStarted())
            mSinchClient.relayRemotePushNotificationPayload(INTENT_EXTRA_PAYLOAD);
            else
            {
                DatabaseHandler handler = new DatabaseHandler(this);
                UserInfo info = handler.getUserDetails();
                startSinchClient(String.valueOf(info.uid), info.name);

                String gcm_regId = ChatDatabaseHandler.getInstance(this).getGcmRegId();

                mSinchClient.registerPushNotificationData(gcm_regId.getBytes());
            }
        }
    }

@Override
    public void onIncomingCall(CallClient client, Call call) {
        Log.d(TAG, "Incoming call");
        /*if(INTENT_EXTRA_CALLID != null)
        {
        CurrentCall.currentCall = mCallClient.getCall(INTENT_EXTRA_CALLID);
        INTENT_EXTRA_CALLID = null;
        }*/
        CurrentCall.currentCall = call;

        Intent intent = new Intent(this, CallService.class);
        startService(intent);
    }

1 个答案:

答案 0 :(得分:3)

您似乎错过了实际在推送中发送Sinch特定负载的代码,您应该使用PushPair.getPushPayload()onShouldSendPushNotification回调中检索它,并确保将其包含在推送信息  添加后,您需要在接收方检索有效负载并传入relayRemotePushNotificationPayload(String payload)。这将在接收方提供onIncomingCall回调。