void PeerConnectionImpl::onCallEvent(ccapi_call_event_e aCallEvent, CSF::CC_CallPtr aCall, CSF::CC_CallInfoPtr aInfo) { PC_AUTO_ENTER_API_CALL_NO_CHECK(); MOZ_ASSERT(aCall.get()); MOZ_ASSERT(aInfo.get()); cc_call_state_t event = aInfo->getCallState(); std::string statestr = aInfo->callStateToString(event); if (CCAPI_CALL_EV_CREATED != aCallEvent && CCAPI_CALL_EV_STATE != aCallEvent) { CSFLogDebug(logTag, "%s: **** CALL HANDLE IS: %s, **** CALL STATE IS: %s", __FUNCTION__, mHandle.c_str(), statestr.c_str()); return; } switch (event) { case SETLOCALDESC: case UPDATELOCALDESC: mLocalSDP = aInfo->getSDP(); break; case SETREMOTEDESC: case ADDICECANDIDATE: mRemoteSDP = aInfo->getSDP(); break; case CONNECTED: CSFLogDebug(logTag, "Setting PeerConnnection state to kActive"); ChangeReadyState(kActive); break; default: break; } nsCOMPtr<IPeerConnectionObserver> pco = do_QueryReferent(mPCObserver); if (!pco) { return; } PeerConnectionObserverDispatch* runnable = new PeerConnectionObserverDispatch(aInfo, this, pco); if (mThread) { mThread->Dispatch(runnable, NS_DISPATCH_NORMAL); return; } runnable->Run(); delete runnable; }
void PeerConnectionImpl::onCallEvent(ccapi_call_event_e aCallEvent, CSF::CC_CallPtr aCall, CSF::CC_CallInfoPtr aInfo) { PC_AUTO_ENTER_API_CALL_NO_CHECK(); MOZ_ASSERT(aCall.get()); MOZ_ASSERT(aInfo.get()); cc_call_state_t event = aInfo->getCallState(); std::string statestr = aInfo->callStateToString(event); if (CCAPI_CALL_EV_CREATED != aCallEvent && CCAPI_CALL_EV_STATE != aCallEvent) { CSFLogDebugS(logTag, ": **** CALL HANDLE IS: " << mHandle << ": **** CALL STATE IS: " << statestr); return; } switch (event) { case SETLOCALDESC: case UPDATELOCALDESC: mLocalSDP = aInfo->getSDP(); break; case SETREMOTEDESC: case UPDATEREMOTEDESC: mRemoteSDP = aInfo->getSDP(); break; case CONNECTED: CSFLogDebugS(logTag, "Setting PeerConnnection state to kActive"); ChangeReadyState(kActive); break; default: break; } if (mPCObserver) { PeerConnectionObserverDispatch* runnable = new PeerConnectionObserverDispatch(aInfo, this, mPCObserver); if (mThread) { mThread->Dispatch(runnable, NS_DISPATCH_NORMAL); return; } runnable->Run(); } }