Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 8fb2e6e4 authored by Hung-ying Tyan's avatar Hung-ying Tyan
Browse files

PhoneFactory: add makeSipPhone()

Change-Id: I8e7abb0623724d24c6f82829ff06663a31ba32fb
parent d122805b
Loading
Loading
Loading
Loading
+11 −0
Original line number Diff line number Diff line
@@ -24,6 +24,8 @@ import android.util.Log;

import com.android.internal.telephony.cdma.CDMAPhone;
import com.android.internal.telephony.gsm.GSMPhone;
import com.android.internal.telephony.sip.SipPhone;
import com.android.internal.telephony.sip.SipPhoneFactory;

/**
 * {@hide}
@@ -175,4 +177,13 @@ public class PhoneFactory {
            return phone;
        }
    }

    /**
     * Makes a {@link SipPhone} object.
     * @param sipUri the local SIP URI the phone runs on
     * @return the {@code SipPhone} object or null if the SIP URI is not valid
     */
    public static SipPhone makeSipPhone(String sipUri) {
        return SipPhoneFactory.makePhone(sipUri, sContext, sPhoneNotifier);
    }
}
+14 −32
Original line number Diff line number Diff line
@@ -16,7 +16,6 @@

package com.android.internal.telephony.sip;

import com.android.internal.telephony.Phone;
import com.android.internal.telephony.PhoneNotifier;

import android.content.Context;
@@ -26,42 +25,25 @@ import android.util.Log;
import java.text.ParseException;

/**
 * @hide
 * {@hide}
 */
public class SipPhoneFactory {
    private static PhoneNotifier sPhoneNotifier = makeDefaultPhoneNotifier();
    private static Context sContext;

    public static void makeDefaultPhones(Context context) {
        makeDefaultPhone(context);
    }

    public static void makeDefaultPhone(Context context) {
        sContext = context;
        SipPhoneProxy.getInstance().setPhone(
                makePhone("sip:anonymous@localhost"));
    }

    public static Phone getDefaultPhone() {
       return SipPhoneProxy.getInstance();
    }

    public static SipPhone makePhone(String sipProfileUri) {
    /**
     * Makes a {@link SipPhone} object.
     * @param sipUri the local SIP URI the phone runs on
     * @param context {@code Context} needed to create a Phone object
     * @param phoneNotifier {@code PhoneNotifier} needed to create a Phone
     *      object
     * @return the {@code SipPhone} object or null if the SIP URI is not valid
     */
    public static SipPhone makePhone(String sipUri, Context context,
            PhoneNotifier phoneNotifier) {
        try {
            SipProfile profile = new SipProfile.Builder(sipProfileUri).build();
            return new SipPhone(sContext, sPhoneNotifier, profile);
            SipProfile profile = new SipProfile.Builder(sipUri).build();
            return new SipPhone(context, phoneNotifier, profile);
        } catch (ParseException e) {
            Log.v("SipPhoneProxy", "setPhone", e);
            Log.w("SipPhoneProxy", "setPhone", e);
            return null;
        }
    }

    private static PhoneNotifier makeDefaultPhoneNotifier() {
        try {
            return new com.android.internal.telephony.SipPhoneNotifier();
        } catch (Error e) {
            Log.e("SipPhoneProxy", "makeDefaultPhoneNotifier", e);
            throw e;
        }
    }
}