In-app view ask user for phone number and password
This commit is contained in:
parent
6eab3e71b9
commit
5270bd8a5f
3 changed files with 348 additions and 25 deletions
|
@ -1,19 +1,125 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
|
||||||
android:id="@+id/topLayout"
|
|
||||||
android:background="@drawable/background"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent"
|
||||||
|
android:background="@drawable/background"
|
||||||
|
android:orientation="vertical" >
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
|
android:contentDescription="@string/content_description_welcome"
|
||||||
android:paddingTop="40dp"
|
android:paddingTop="40dp"
|
||||||
android:textSize="20sp"
|
android:textSize="20sp"
|
||||||
android:textStyle="bold"
|
android:textStyle="bold"
|
||||||
android:textColor="@android:color/black"
|
android:textColor="@android:color/black"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="In-app store"/>
|
android:text="@string/setup_title_assistant"/>
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:paddingTop="10dp"
|
||||||
|
android:gravity="center"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:id="@+id/setup_error"
|
||||||
|
android:textColor="#ffff0000"/>
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:paddingTop="40dp"
|
||||||
|
android:paddingLeft="10dp"
|
||||||
|
android:paddingRight="10dp"
|
||||||
|
android:gravity="center"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:textCursorDrawable="@null"
|
||||||
|
android:id="@+id/setup_username"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:hint="@string/setup_username_hint"
|
||||||
|
android:inputType="textEmailAddress"
|
||||||
|
android:paddingLeft="10dp"
|
||||||
|
android:paddingRight="10dp"
|
||||||
|
android:singleLine="true"
|
||||||
|
android:textColor="@android:color/black"
|
||||||
|
android:background="@drawable/setup_field_background" />
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:contentDescription="@string/content_description_setup_ok"
|
||||||
|
android:id="@+id/setup_username_ok"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:layout_centerVertical="true"
|
||||||
|
android:layout_alignParentRight="true"
|
||||||
|
android:src="@drawable/wizard_notok"/>
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_marginTop="5dp"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:textCursorDrawable="@null"
|
||||||
|
android:id="@+id/setup_password"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:hint="@string/setup_password_hint"
|
||||||
|
android:inputType="textPassword"
|
||||||
|
android:paddingLeft="10dp"
|
||||||
|
android:paddingRight="10dp"
|
||||||
|
android:singleLine="true"
|
||||||
|
android:textColor="@android:color/black"
|
||||||
|
android:background="@drawable/setup_field_background" />
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:contentDescription="@string/content_description_setup_ok"
|
||||||
|
android:id="@+id/setup_password_ok"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:layout_alignParentRight="true"
|
||||||
|
android:layout_centerVertical="true"
|
||||||
|
android:src="@drawable/wizard_notok"/>
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_marginTop="5dp"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:textCursorDrawable="@null"
|
||||||
|
android:id="@+id/setup_password_confirm"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:hint="@string/setup_password_confirm_hint"
|
||||||
|
android:inputType="textPassword"
|
||||||
|
android:paddingLeft="10dp"
|
||||||
|
android:paddingRight="10dp"
|
||||||
|
android:singleLine="true"
|
||||||
|
android:textColor="@android:color/black"
|
||||||
|
android:background="@drawable/setup_field_background" />
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:contentDescription="@string/content_description_setup_ok"
|
||||||
|
android:id="@+id/setup_confirm_password_ok"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:layout_alignParentRight="true"
|
||||||
|
android:layout_centerVertical="true"
|
||||||
|
android:src="@drawable/wizard_notok"/>
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:id="@+id/purchasable_items"
|
android:id="@+id/purchasable_items"
|
||||||
|
@ -23,4 +129,12 @@
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
android:orientation="vertical"/>
|
android:orientation="vertical"/>
|
||||||
|
|
||||||
</RelativeLayout>
|
<View
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:paddingLeft="10dp"
|
||||||
|
android:paddingRight="10dp" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
|
@ -18,20 +18,34 @@ along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import org.linphone.LinphoneManager;
|
||||||
import org.linphone.R;
|
import org.linphone.R;
|
||||||
|
import org.linphone.core.LinphoneProxyConfig;
|
||||||
import org.linphone.mediastream.Log;
|
import org.linphone.mediastream.Log;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.text.Editable;
|
||||||
|
import android.text.InputFilter;
|
||||||
|
import android.text.Spanned;
|
||||||
|
import android.text.TextWatcher;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
import android.view.View.OnClickListener;
|
||||||
|
import android.widget.EditText;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
import de.timroes.axmlrpc.XMLRPCCallback;
|
||||||
|
import de.timroes.axmlrpc.XMLRPCClient;
|
||||||
|
import de.timroes.axmlrpc.XMLRPCException;
|
||||||
|
import de.timroes.axmlrpc.XMLRPCServerException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Sylvain Berfini
|
* @author Sylvain Berfini
|
||||||
|
@ -40,6 +54,15 @@ public class InAppPurchaseActivity extends Activity implements InAppPurchaseList
|
||||||
private InAppPurchaseHelper inAppPurchaseHelper;
|
private InAppPurchaseHelper inAppPurchaseHelper;
|
||||||
private LinearLayout purchasableItemsLayout;
|
private LinearLayout purchasableItemsLayout;
|
||||||
private ArrayList<Purchasable> purchasedItems;
|
private ArrayList<Purchasable> purchasedItems;
|
||||||
|
private ImageView buyItemButton;
|
||||||
|
|
||||||
|
private EditText username, password, passwordConfirm;
|
||||||
|
private TextView errorMessage;
|
||||||
|
private Handler mHandler = new Handler();
|
||||||
|
private char[] acceptedChars = new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '-', '+' };
|
||||||
|
private boolean usernameOk = false;
|
||||||
|
private boolean passwordOk = false;
|
||||||
|
private boolean confirmPasswordOk = false;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
@ -49,6 +72,31 @@ public class InAppPurchaseActivity extends Activity implements InAppPurchaseList
|
||||||
|
|
||||||
setContentView(R.layout.in_app_store);
|
setContentView(R.layout.in_app_store);
|
||||||
purchasableItemsLayout = (LinearLayout) findViewById(R.id.purchasable_items);
|
purchasableItemsLayout = (LinearLayout) findViewById(R.id.purchasable_items);
|
||||||
|
|
||||||
|
username = (EditText) findViewById(R.id.setup_username);
|
||||||
|
ImageView usernameOkIV = (ImageView) findViewById(R.id.setup_username_ok);
|
||||||
|
addXMLRPCUsernameHandler(username, usernameOkIV);
|
||||||
|
InputFilter filter = new InputFilter(){
|
||||||
|
@Override
|
||||||
|
public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
|
||||||
|
if (end > start) {
|
||||||
|
for (int index = start; index < end; index++) {
|
||||||
|
if (!new String(acceptedChars).contains(String.valueOf(source.charAt(index)))) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
username.setFilters(new InputFilter[] { filter });
|
||||||
|
password = (EditText) findViewById(R.id.setup_password);
|
||||||
|
passwordConfirm = (EditText) findViewById(R.id.setup_password_confirm);
|
||||||
|
ImageView passwordOkIV = (ImageView) findViewById(R.id.setup_password_ok);
|
||||||
|
addXMLRPCPasswordHandler(password, passwordOkIV);
|
||||||
|
ImageView passwordConfirmOkIV = (ImageView) findViewById(R.id.setup_confirm_password_ok);
|
||||||
|
addXMLRPCConfirmPasswordHandler(password, passwordConfirm, passwordConfirmOkIV);
|
||||||
|
errorMessage = (TextView) findViewById(R.id.setup_error);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -59,6 +107,7 @@ public class InAppPurchaseActivity extends Activity implements InAppPurchaseList
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onServiceAvailableForQueries() {
|
public void onServiceAvailableForQueries() {
|
||||||
|
inAppPurchaseHelper.getAvailableItemsForPurchaseAsync();
|
||||||
inAppPurchaseHelper.getPurchasedItemsAsync();
|
inAppPurchaseHelper.getPurchasedItemsAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,25 +118,22 @@ public class InAppPurchaseActivity extends Activity implements InAppPurchaseList
|
||||||
for (Purchasable item : items) {
|
for (Purchasable item : items) {
|
||||||
View layout = LayoutInflater.from(this).inflate(R.layout.in_app_purchasable, purchasableItemsLayout);
|
View layout = LayoutInflater.from(this).inflate(R.layout.in_app_purchasable, purchasableItemsLayout);
|
||||||
TextView text = (TextView) layout.findViewById(R.id.text);
|
TextView text = (TextView) layout.findViewById(R.id.text);
|
||||||
text.setText(item.getTitle() + " " + item.getPrice());
|
text.setText("Buy account (" + item.getPrice() + ")");
|
||||||
ImageView image = (ImageView) layout.findViewById(R.id.image);
|
ImageView image = (ImageView) layout.findViewById(R.id.image);
|
||||||
image.setTag(item);
|
image.setTag(item);
|
||||||
image.setOnClickListener(this);
|
image.setOnClickListener(this);
|
||||||
|
|
||||||
for (Purchasable purchasedItem : purchasedItems) {
|
buyItemButton = image;
|
||||||
Log.d("[In-app purchase] Found already bought item, expires " + purchasedItem.getExpireDate());
|
buyItemButton.setEnabled(usernameOk && passwordOk && confirmPasswordOk);
|
||||||
if (purchasedItem.getId().equals(item.getId())) {
|
|
||||||
image.setEnabled(false);
|
|
||||||
text.setEnabled(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPurchasedItemsQueryFinished(ArrayList<Purchasable> items) {
|
public void onPurchasedItemsQueryFinished(ArrayList<Purchasable> items) {
|
||||||
purchasedItems = items;
|
purchasedItems = items;
|
||||||
inAppPurchaseHelper.getAvailableItemsForPurchaseAsync();
|
for (Purchasable purchasedItem : purchasedItems) {
|
||||||
|
Log.d("[In-app purchase] Found already bought item, expires " + purchasedItem.getExpireDate());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -100,11 +146,174 @@ public class InAppPurchaseActivity extends Activity implements InAppPurchaseList
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
Purchasable item = (Purchasable) v.getTag();
|
Purchasable item = (Purchasable) v.getTag();
|
||||||
inAppPurchaseHelper.purchaseItemAsync(item.getId(), "sylvain@sip.linphone.org");
|
inAppPurchaseHelper.purchaseItemAsync(item.getId(), getUsername());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
|
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||||
inAppPurchaseHelper.parseAndVerifyPurchaseItemResultAsync(requestCode, resultCode, data);
|
inAppPurchaseHelper.parseAndVerifyPurchaseItemResultAsync(requestCode, resultCode, data, getUsername(), password.getText().toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getUsername() {
|
||||||
|
String username = this.username.getText().toString();
|
||||||
|
LinphoneProxyConfig lpc = LinphoneManager.getLc().createProxyConfig();
|
||||||
|
username = lpc.normalizePhoneNumber(username);
|
||||||
|
return username.toLowerCase(Locale.getDefault());
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isUsernameCorrect(String username) {
|
||||||
|
return username.matches("^(\\+)?(\\d-)?(\\d{3}-)?(\\d{3}-)?\\d{4,}$");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void isUsernameRegistred(String username, final ImageView icon) {
|
||||||
|
final Runnable runNotReachable = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
errorMessage.setText(R.string.wizard_server_unavailable);
|
||||||
|
usernameOk = false;
|
||||||
|
icon.setImageResource(R.drawable.wizard_notok);
|
||||||
|
buyItemButton.setEnabled(usernameOk && passwordOk && confirmPasswordOk);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
try {
|
||||||
|
XMLRPCClient client = new XMLRPCClient(new URL(getString(R.string.wizard_url)));
|
||||||
|
|
||||||
|
XMLRPCCallback listener = new XMLRPCCallback() {
|
||||||
|
Runnable runNotOk = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
errorMessage.setText(R.string.wizard_username_unavailable);
|
||||||
|
usernameOk = false;
|
||||||
|
icon.setImageResource(R.drawable.wizard_notok);
|
||||||
|
buyItemButton.setEnabled(usernameOk && passwordOk && confirmPasswordOk);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
Runnable runOk = new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
errorMessage.setText("");
|
||||||
|
usernameOk = true;
|
||||||
|
icon.setImageResource(R.drawable.wizard_ok);
|
||||||
|
buyItemButton.setEnabled(usernameOk && passwordOk && confirmPasswordOk);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public void onResponse(long id, Object result) {
|
||||||
|
int answer = (Integer) result;
|
||||||
|
if (answer != 0) {
|
||||||
|
mHandler.post(runNotOk);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
mHandler.post(runOk);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onError(long id, XMLRPCException error) {
|
||||||
|
mHandler.post(runNotReachable);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onServerError(long id, XMLRPCServerException error) {
|
||||||
|
mHandler.post(runNotReachable);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
client.callAsync(listener, "check_account", username);
|
||||||
|
}
|
||||||
|
catch(Exception ex) {
|
||||||
|
mHandler.post(runNotReachable);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isPasswordCorrect(String password) {
|
||||||
|
return password.length() >= 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addXMLRPCUsernameHandler(final EditText field, final ImageView icon) {
|
||||||
|
field.addTextChangedListener(new TextWatcher() {
|
||||||
|
public void afterTextChanged(Editable s) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onTextChanged(CharSequence s, int start, int count, int after) {
|
||||||
|
usernameOk = false;
|
||||||
|
String username = field.getText().toString().toLowerCase(Locale.getDefault());
|
||||||
|
if (isUsernameCorrect(username)) {
|
||||||
|
LinphoneProxyConfig lpc = LinphoneManager.getLc().createProxyConfig();
|
||||||
|
username = lpc.normalizePhoneNumber(username);
|
||||||
|
isUsernameRegistred(username, icon);
|
||||||
|
} else {
|
||||||
|
errorMessage.setText(R.string.wizard_username_incorrect);
|
||||||
|
icon.setImageResource(R.drawable.wizard_notok);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addXMLRPCPasswordHandler(final EditText field1, final ImageView icon) {
|
||||||
|
TextWatcher passwordListener = new TextWatcher() {
|
||||||
|
public void afterTextChanged(Editable s) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onTextChanged(CharSequence s, int start, int count, int after)
|
||||||
|
{
|
||||||
|
passwordOk = false;
|
||||||
|
if (isPasswordCorrect(field1.getText().toString())) {
|
||||||
|
passwordOk = true;
|
||||||
|
icon.setImageResource(R.drawable.wizard_ok);
|
||||||
|
errorMessage.setText("");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
errorMessage.setText(R.string.wizard_password_incorrect);
|
||||||
|
icon.setImageResource(R.drawable.wizard_notok);
|
||||||
|
}
|
||||||
|
buyItemButton.setEnabled(usernameOk && passwordOk && confirmPasswordOk);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
field1.addTextChangedListener(passwordListener);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addXMLRPCConfirmPasswordHandler(final EditText field1, final EditText field2, final ImageView icon) {
|
||||||
|
TextWatcher passwordListener = new TextWatcher() {
|
||||||
|
public void afterTextChanged(Editable s) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onTextChanged(CharSequence s, int start, int count, int after)
|
||||||
|
{
|
||||||
|
confirmPasswordOk = false;
|
||||||
|
if (field1.getText().toString().equals(field2.getText().toString())) {
|
||||||
|
confirmPasswordOk = true;
|
||||||
|
icon.setImageResource(R.drawable.wizard_ok);
|
||||||
|
|
||||||
|
if (!isPasswordCorrect(field1.getText().toString())) {
|
||||||
|
errorMessage.setText(R.string.wizard_password_incorrect);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
errorMessage.setText("");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
errorMessage.setText(R.string.wizard_passwords_unmatched);
|
||||||
|
icon.setImageResource(R.drawable.wizard_notok);
|
||||||
|
}
|
||||||
|
buyItemButton.setEnabled(usernameOk && passwordOk && confirmPasswordOk);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
field1.addTextChangedListener(passwordListener);
|
||||||
|
field2.addTextChangedListener(passwordListener);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -293,7 +293,7 @@ public class InAppPurchaseHelper {
|
||||||
}).start();
|
}).start();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void parseAndVerifyPurchaseItemResultAsync(int requestCode, int resultCode, Intent data) {
|
public void parseAndVerifyPurchaseItemResultAsync(int requestCode, int resultCode, Intent data, String username, String password) {
|
||||||
if (requestCode == ACTIVITY_RESULT_CODE_PURCHASE_ITEM) {
|
if (requestCode == ACTIVITY_RESULT_CODE_PURCHASE_ITEM) {
|
||||||
int responseCode = data.getIntExtra(RESPONSE_CODE, 0);
|
int responseCode = data.getIntExtra(RESPONSE_CODE, 0);
|
||||||
String purchaseData = data.getStringExtra(RESPONSE_INAPP_PURCHASE_DATA);
|
String purchaseData = data.getStringExtra(RESPONSE_INAPP_PURCHASE_DATA);
|
||||||
|
@ -307,7 +307,7 @@ public class InAppPurchaseHelper {
|
||||||
mListener.onPurchasedItemConfirmationQueryFinished(item);
|
mListener.onPurchasedItemConfirmationQueryFinished(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, purchaseData, signature);
|
}, purchaseData, signature, username, password);
|
||||||
} else {
|
} else {
|
||||||
Log.e("[In-app purchase] Error: resultCode is " + resultCode + " and responseCode is " + responseCodeToErrorMessage(responseCode));
|
Log.e("[In-app purchase] Error: resultCode is " + resultCode + " and responseCode is " + responseCodeToErrorMessage(responseCode));
|
||||||
}
|
}
|
||||||
|
@ -369,7 +369,7 @@ public class InAppPurchaseHelper {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void verifySignatureAndCreateAccountAsync(final VerifiedSignatureListener listener, final String purchasedData, String signature) {
|
private void verifySignatureAndCreateAccountAsync(final VerifiedSignatureListener listener, final String purchasedData, String signature, String username, String password) {
|
||||||
XMLRPCClient client = null;
|
XMLRPCClient client = null;
|
||||||
try {
|
try {
|
||||||
client = new XMLRPCClient(new URL(LinphonePreferences.instance().getInAppPurchaseValidatingServerUrl()));
|
client = new XMLRPCClient(new URL(LinphonePreferences.instance().getInAppPurchaseValidatingServerUrl()));
|
||||||
|
@ -414,7 +414,7 @@ public class InAppPurchaseHelper {
|
||||||
Log.e(error);
|
Log.e(error);
|
||||||
Log.e("[In-app purchase] Server can't validate the payload and it's signature !");
|
Log.e("[In-app purchase] Server can't validate the payload and it's signature !");
|
||||||
}
|
}
|
||||||
}, "create_account_from_in_app_purchase", mGmailAccount, "sylvain@sip.linphone.org", "toto", purchasedData, signature, "google");
|
}, "create_account_from_in_app_purchase", mGmailAccount, username + "@sip.linphone.org", password, purchasedData, signature, "google");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue