/* * Jitsi, the OpenSource Java VoIP and Instant Messaging client. * * Copyright @ 2015 Atlassian Pty Ltd * * 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 net.java.sip.communicator.plugin.sip2sipaccregwizz; import java.util.*; import net.java.sip.communicator.plugin.sipaccregwizz.*; import net.java.sip.communicator.service.gui.*; import net.java.sip.communicator.service.protocol.sip.*; /** * The Sip2SipAccountRegistrationWizard is an implementation of the * AccountRegistrationWizard for the SIP protocol. It should allow * the user to create and configure a new IP Tel SIP account. * * @author Yana Stamcheva */ public class Sip2SipAccountRegistrationWizard extends SIPAccountRegistrationWizard { /** * A constant pointing to the IP Tel protocol logo image. */ private static final String PROTOCOL_ICON = "service.protocol.sip2sip.SIP2SIP_16x16"; /** * A constant pointing to the IP Tel protocol wizard page image. */ private static final String PAGE_IMAGE = "service.protocol.sip2sip.SIP2SIP_64x64"; /** * The protocol name. */ public static final String PROTOCOL = "sip2sip.info"; /** * The create account form. */ CreateSip2SipAccountForm createAccountForm = new CreateSip2SipAccountForm(); /** * Creates an instance of IptelAccountRegistrationWizard. * @param wizardContainer the wizard container */ public Sip2SipAccountRegistrationWizard(WizardContainer wizardContainer) { super(wizardContainer); } /** * Returns the set of pages contained in this wizard. * @return Iterator */ @Override public Iterator getPages() { SIPAccountRegistration reg = new SIPAccountRegistration(); setPredefinedProperties(reg); return getPages(reg); } /** * Returns a simple account registration form that would be the first form * shown to the user. Only if the user needs more settings she'll choose * to open the advanced wizard, consisted by all pages. * * @param isCreateAccount indicates if the simple form should be opened as * a create account form or as a login form * @return a simple account registration form */ @Override public Object getSimpleForm(boolean isCreateAccount) { SIPAccountRegistration reg = new SIPAccountRegistration(); setPredefinedProperties(reg); return getSimpleForm(reg, isCreateAccount); } /** * Sets all predefined properties specific for this account wizard. * * @param reg the registration object */ private void setPredefinedProperties(SIPAccountRegistration reg) { // set properties common for sip2sip reg.setKeepAliveMethod("NONE"); reg.setDefaultDomain("sip2sip.info"); reg.setXCapEnable(true); reg.setClistOptionServerUri( "https://xcap.sipthor.net/xcap-root@sip2sip.info"); reg.setClistOptionUseSipCredentials(true); } /** * Implements the AccountRegistrationWizard.getIcon method. * Returns the icon to be used for this wizard. * @return byte[] */ @Override public byte[] getIcon() { return Sip2SipAccRegWizzActivator.getResources() .getImageInBytes(PROTOCOL_ICON); } /** * Implements the AccountRegistrationWizard.getPageImage method. * Returns the image used to decorate the wizard page * * @return byte[] the image used to decorate the wizard page */ @Override public byte[] getPageImage() { return Sip2SipAccRegWizzActivator.getResources() .getImageInBytes(PAGE_IMAGE); } /** * Implements the AccountRegistrationWizard.getProtocolName * method. Returns the protocol name for this wizard. * @return String */ @Override public String getProtocolName() { return Resources.getString( "plugin.sip2sipaccregwizz.PROTOCOL_NAME"); } /** * Implements the AccountRegistrationWizard.getProtocolDescription * method. Returns the description of the protocol for this wizard. * @return String */ @Override public String getProtocolDescription() { return Resources.getString( "plugin.sip2sipaccregwizz.PROTOCOL_DESCRIPTION"); } /** * Returns an example string, which should indicate to the user how the * user name should look like. * @return an example string, which should indicate to the user how the * user name should look like. */ @Override public String getUserNameExample() { return "Ex: myusername or myusername@sip2sip.info"; } /** * Returns the protocol name as listed in "ProtocolNames" or just the name * of the service. * @return the protocol name */ @Override public String getProtocol() { return PROTOCOL; } /** * Returns the protocol icon path. * @return the protocol icon path */ @Override public String getProtocolIconPath() { return "resources/images/protocol/sip2sip"; } /** * Returns the account icon path. * @return the account icon path */ @Override public String getAccountIconPath() { return "resources/images/protocol/sip2sip/sip32x32.png"; } /** * Opens the browser on the page sign up */ @Override public void webSignup() { Sip2SipAccRegWizzActivator.getBrowserLauncher() .openURL("http://wiki.sip2sip.info"); } /** * Returns the name of the web sign up link. * @return the name of the web sign up link */ @Override public String getWebSignupLinkName() { return Resources.getString("plugin.sip2sipaccregwizz.NEW_ACCOUNT_TITLE"); } /** * Returns an instance of CreateAccountService through which the * user could create an account. This method is meant to be implemented by * specific protocol provider wizards. * @return an instance of CreateAccountService */ @Override protected SIPAccountCreationFormService getCreateAccountService() { return createAccountForm; } /** * Returns the display label used for the sip id field. * @return the sip id display label string. */ @Override protected String getUsernameLabel() { return Resources.getString("plugin.sip2sipaccregwizz.USERNAME"); } /** * Return the string for add existing account button. * @return the string for add existing account button. */ @Override protected String getExistingAccountLabel() { return Resources.getString("plugin.sip2sipaccregwizz.EXISTING_ACCOUNT"); } /** * Return the string for create new account button. * @return the string for create new account button. */ @Override protected String getCreateAccountLabel() { return Resources.getString("plugin.sip2sipaccregwizz.CREATE_ACCOUNT"); } }