Search in sources :

Example 1 with CallState

use of com.sun.voip.CallState in project Openfire by igniterealtime.

the class CallMigrator method run.

/*
     * Migrate a call.  Set up the new call, join the conference and
     * terminate the original call.
     */
public void run() {
    // call to migrate
    String callId = cp.getCallId();
    CallHandler callHandler = CallHandler.findMigratingCall(callId);
    if (callHandler != null) {
        /*
	     * Call migration is in progess.
	     * Cancel previous migration request.
	     */
        callHandler.cancelRequest("new migration requested");
    }
    CallHandler previousCall = CallHandler.findCall(callId);
    if (previousCall == null) {
        if (cp.getConferenceId() == null) {
            Logger.println("Call migrator can't find call Id " + callId);
            return;
        }
        /*
	     * Treat it like a new call
	     */
        migrateWithNoPreviousCall(requestHandler, cp);
        return;
    }
    if (false) {
        if (previousCall.isCallEstablished() == false) {
            Logger.println("Call migrator can't migrate call which is not established");
            return;
        }
    }
    CallParticipant previousCp = previousCall.getCallParticipant();
    String previousEndTreatment = previousCp.getCallEndTreatment();
    String previousLeaveTreatment = previousCp.getConferenceLeaveTreatment();
    previousCp.setCallEndTreatment(null);
    previousCp.setConferenceLeaveTreatment(null);
    // preserve mute
    cp.setMuted(previousCp.isMuted());
    Logger.println("Call migrating " + previousCp + " preserving mute " + previousCp.isMuted());
    if (cp.getConferenceId() == null) {
        cp.setConferenceId(previousCp.getConferenceId());
    }
    if (cp.getName() == null) {
        cp.setName(previousCp.getName());
    }
    /*
	 * SecondPartyNumber is the new number to call.
	 * If it starts with "Id-", it's a callId of
	 * a call already in progress.  Otherwise, it's a phone number to call.
	 */
    String secondParty = cp.getSecondPartyNumber();
    if (secondParty.indexOf("Id-") == 0) {
        callHandler = CallHandler.findCall(secondParty.substring(3));
        if (callHandler == null) {
            Logger.println("Can't find existing call to " + secondParty);
            //Logger.logLevel = logLevel;
            return;
        }
        cp = callHandler.getCallParticipant();
        cp.setCallId(previousCp.getCallId());
    } else {
        /*
	     * Invite the secondParty if call is not already setup.
	     * After the party answers terminate the previous call.
	     */
        cp.setPhoneNumber(cp.getSecondPartyNumber());
        cp.setConferenceJoinTreatment(null);
        /*
	     * Use the request handler from the previous call (if there
	     * is one) so that status changes will be sent to the same socket
	     * as the previous call.  This will make the migration seemless.
	     */
        CallEventListener previousCallEventListener = (CallEventListener) previousCall.getRequestHandler();
        if (previousCallEventListener != null) {
            requestHandler = previousCallEventListener;
        }
        /*
	     * Previous call is migrating.  It will probably be
	     * common for someone to hangup their cell phone before
	     * answering the new call.  In this case we need to
	     * suppress status from the previous call.
	     * However, if the previous call ends and then migration fails,
	     * we need to send call ending status back.
	     */
        previousCall.suppressStatus = true;
        OutgoingCallHandler newCall = new OutgoingCallHandler(requestHandler, cp);
        previousCall.getMember().migrating();
        synchronized (this) {
            newCall.suppressStatus = true;
            // call new party
            newCall.start();
            /*
	         * Wait for call to be established
	         */
            if (newCall.waitForCallToBeEstablished() == false) {
                String reason = newCall.getReasonCallEnded();
                Logger.println("Migration failed: " + reason);
                previousCp.setConferenceLeaveTreatment(previousLeaveTreatment);
                previousCp.setCallEndTreatment(previousEndTreatment);
                CallEvent callEvent = new CallEvent(CallEvent.STATE_CHANGED);
                callEvent.setCallState(new CallState(CallState.ENDED));
                callEvent.setInfo("Migration failed: " + reason);
                newCall.suppressStatus = false;
                newCall.sendCallEventNotification(callEvent);
                previousCall.suppressStatus = false;
                if (!previousCall.isCallEstablished()) {
                    previousCall.sendCallEventNotification(callEvent);
                }
                //Logger.logLevel = logLevel;
                return;
            }
            newCall.suppressStatus = false;
        }
        if (previousCall.isCallEstablished() == true) {
            Logger.println("migrate mix descriptors for " + previousCall);
            newCall.getMember().migrate(previousCall.getMember());
        } else {
            Logger.println("migrate:  previous call is not established " + previousCall);
        }
    }
    Logger.println("Call " + previousCp + " migrated to " + cp.getPhoneNumber());
    previousCall.suppressStatus = false;
    // call is no longer migrating
    cp.setMigrateCall(false);
    /*
	 * If the previous call ended early, we need to re-add
	 * it as a call status listener so that it will get the MIGRATED status
	 */
    if (!previousCall.isCallEstablished()) {
        previousCall.addCallEventListener(previousCall.getRequestHandler());
    }
    CallEvent callEvent = new CallEvent(CallEvent.MIGRATED);
    callEvent.setInfo(previousCp + " migrated to " + cp);
    previousCall.sendCallEventNotification(callEvent);
    previousCall.suppressStatus = true;
    /*
	 * Suppress conference leave treatment.  No other calls should
	 * know that this call migrated.
	 */
    previousCp.setCallEndTreatment(null);
    previousCp.setConferenceLeaveTreatment(null);
    previousCall.cancelRequest("Call " + previousCp + " migrated to " + cp.getPhoneNumber());
}
Also used : CallEventListener(com.sun.voip.CallEventListener) CallParticipant(com.sun.voip.CallParticipant) CallEvent(com.sun.voip.CallEvent) CallState(com.sun.voip.CallState)

Example 2 with CallState

use of com.sun.voip.CallState in project Openfire by igniterealtime.

the class CallSetupAgent method setState.

protected void setState(int state, String info) {
    callState = new CallState(state);
    CallEvent callEvent = new CallEvent(CallEvent.STATE_CHANGED);
    callEvent.setCallState(callState);
    String s = "";
    if (state == CallState.INVITED || state == CallState.ESTABLISHED) {
        s += "ConferenceReceiverPort='" + callHandler.getReceiveAddress().getPort() + "'";
        MediaInfo mediaInfo = callHandler.getConferenceManager().getMediaInfo();
        s += " ConferencePayload='" + mediaInfo.getPayload() + "'";
        s += " BridgeIPAddress='" + Bridge.getPrivateHost() + "'";
        s += " BridgeInfo='" + Bridge.getPrivateHost() + ":" + Bridge.getPrivateControlPort() + ":" + Bridge.getPrivateSipPort() + ":" + Bridge.getPublicHost() + ":" + Bridge.getPublicControlPort() + ":" + Bridge.getPublicSipPort() + "'";
    }
    if (info != null) {
        s = info + " " + s;
    }
    callEvent.setInfo(s);
    Logger.println("Call " + callHandler + " " + callState);
    sendCallEventNotification(callEvent);
    if (state == CallState.ESTABLISHED) {
        String treatment = cp.getCallEstablishedTreatment();
        if (treatment != null) {
            callEstablishedTreatment = initializeTreatment(treatment, 0);
            if (callEstablishedTreatment != null) {
                addTreatment(callEstablishedTreatment);
            }
        }
    }
    if (inviteTimeoutThread == null && state == CallState.INVITED) {
        inviteTimeoutThread = new Thread(this);
        // start invite timeout thread
        inviteTimeoutThread.start();
    }
}
Also used : MediaInfo(com.sun.voip.MediaInfo) CallEvent(com.sun.voip.CallEvent) CallState(com.sun.voip.CallState)

Example 3 with CallState

use of com.sun.voip.CallState in project Openfire by igniterealtime.

the class CallHandler method sendCallEventNotification.

public void sendCallEventNotification(CallEvent callEvent) {
    if (cp.getCallId() != null) {
        callEvent.setCallId(cp.getCallId());
    } else {
        callEvent.setCallId("CallIdNotInitialized");
    }
    callEvent.setConferenceId(cp.getConferenceId());
    callEvent.setCallInfo(cp.getCallOwner());
    if (csa != null) {
        callEvent.setCallState(csa.getCallState());
    } else {
        callEvent.setCallState(new CallState(CallState.UNINITIALIZED));
    }
    synchronized (callEventListeners) {
        for (int i = 0; i < callEventListeners.size(); i++) {
            CallEventListener listener = (CallEventListener) callEventListeners.elementAt(i);
            listener.callEventNotification(callEvent);
        }
    }
}
Also used : CallEventListener(com.sun.voip.CallEventListener) CallState(com.sun.voip.CallState)

Aggregations

CallState (com.sun.voip.CallState)3 CallEvent (com.sun.voip.CallEvent)2 CallEventListener (com.sun.voip.CallEventListener)2 CallParticipant (com.sun.voip.CallParticipant)1 MediaInfo (com.sun.voip.MediaInfo)1