1
0
Fork 0
mirror of https://github.com/geometer/FBReaderJ.git synced 2025-10-05 19:42:17 +02:00

AutoSignIn dialog implementation

This commit is contained in:
Vasiliy Bout 2011-08-29 22:28:09 +04:00
parent 886fb90d5c
commit 53f5438509
6 changed files with 52 additions and 21 deletions

View file

@ -403,6 +403,9 @@ public class NetworkBookInfoActivity extends Activity implements NetworkLibrary.
case NetworkLibraryActivity.SIGNUP_CODE:
Util.processSignup(myBook.Link, resultCode, data);
break;
case NetworkLibraryActivity.AUTO_SIGNIN_CODE:
Util.processAutoSignIn(this, myBook.Link, resultCode, data);
break;
}
}
}

View file

@ -41,6 +41,7 @@ import org.geometerplus.android.fbreader.network.action.*;
public class NetworkLibraryActivity extends BaseActivity implements NetworkLibrary.ChangeListener {
protected static final int BASIC_AUTHENTICATION_CODE = 1;
protected static final int SIGNUP_CODE = 2;
protected static final int AUTO_SIGNIN_CODE = 3;
BookDownloaderServiceConnection Connection;
@ -268,6 +269,9 @@ public class NetworkLibraryActivity extends BaseActivity implements NetworkLibra
case SIGNUP_CODE:
Util.processSignup(((NetworkCatalogTree)getCurrentTree()).Item.Link, resultCode, intent);
break;
case AUTO_SIGNIN_CODE:
Util.processAutoSignIn(this, ((NetworkCatalogTree)getCurrentTree()).Item.Link, resultCode, intent);
break;
}
}

View file

@ -38,8 +38,8 @@ import org.geometerplus.android.util.PackageUtil;
public abstract class Util implements UserRegistrationConstants {
private static final String REGISTRATION_ACTION =
"android.fbreader.action.NETWORK_LIBRARY_REGISTER";
private static final String AUTOREGISTRATION_ACTION =
"android.fbreader.action.NETWORK_LIBRARY_AUTOREGISTER";
private static final String AUTO_SIGNIN_ACTION =
"android.fbreader.action.NETWORK_LIBRARY_AUTOSIGNIN";
static INetworkLink linkByIntent(Intent intent) {
return NetworkLibrary.Instance().getLinkByUrl(intent.getData().toString());
@ -61,10 +61,10 @@ public abstract class Util implements UserRegistrationConstants {
);
}
public static boolean isAutoregistrationSupported(Activity activity, INetworkLink link) {
public static boolean isAutoSignInSupported(Activity activity, INetworkLink link) {
return testService(
activity,
AUTOREGISTRATION_ACTION,
AUTO_SIGNIN_ACTION,
link.getUrl(UrlInfo.Type.SignUp)
);
}
@ -82,14 +82,14 @@ public abstract class Util implements UserRegistrationConstants {
}
}
public static void runAutoregistrationDialog(Activity activity, INetworkLink link) {
public static void runAutoSignInDialog(Activity activity, INetworkLink link) {
try {
final Intent intent = new Intent(
AUTOREGISTRATION_ACTION,
Uri.parse(link.getUrl(UrlInfo.Type.SignUp))
AUTO_SIGNIN_ACTION,
Uri.parse(link.getUrl(UrlInfo.Type.SignIn))
);
if (PackageUtil.canBeStarted(activity, intent, true)) {
activity.startActivityForResult(intent, NetworkLibraryActivity.SIGNUP_CODE);
activity.startActivityForResult(intent, NetworkLibraryActivity.AUTO_SIGNIN_CODE);
}
} catch (ActivityNotFoundException e) {
}
@ -133,6 +133,35 @@ public abstract class Util implements UserRegistrationConstants {
}
}
public static void processAutoSignIn(Activity activity, INetworkLink link, int resultCode, Intent data) {
if (resultCode == Activity.RESULT_OK && data != null) {
try {
final NetworkAuthenticationManager mgr = link.authenticationManager();
if (mgr instanceof LitResAuthenticationManager) {
((LitResAuthenticationManager)mgr).initUser(
data.getStringExtra(USER_REGISTRATION_USERNAME),
data.getStringExtra(USER_REGISTRATION_LITRES_SID),
"",
false
);
}
if (!mgr.isAuthorised(true)) {
throw new ZLNetworkException(NetworkException.ERROR_AUTHENTICATION_FAILED);
}
try {
mgr.initialize();
} catch (ZLNetworkException e) {
mgr.logOut();
throw e;
}
// TODO: implement postRunnable (e.g. buying book on "quick buy")
} catch (ZLNetworkException e) {
// TODO: show an error message
}
}
}
public static void openInBrowser(Context context, String url) {
if (url != null) {
url = NetworkLibrary.Instance().rewriteUrl(url, true);

View file

@ -381,15 +381,15 @@ public abstract class NetworkBookActions {
} else {
final String signInKey = "signIn";
final String registerKey = "signUp";
final String autoregisterKey = "quickBuy";
final String quickBuyKey = "quickBuy";
final ArrayList<String> items = new ArrayList<String>();
items.add(signInKey);
if (Util.isRegistrationSupported(activity, book.Link)) {
items.add(registerKey);
}
if (Util.isAutoregistrationSupported(activity, book.Link)) {
items.add(autoregisterKey);
if (Util.isAutoSignInSupported(activity, book.Link)) {
items.add(quickBuyKey);
}
if (items.size() > 1) {
@ -415,12 +415,13 @@ public abstract class NetworkBookActions {
} else if (registerKey.equals(item)) {
Util.runRegistrationDialog(activity, book.Link);
// TODO: buy on success
} else if (autoregisterKey.equals(item)) {
Util.runAutoregistrationDialog(activity, book.Link);
} else if (quickBuyKey.equals(item)) {
Util.runAutoSignInDialog(activity, book.Link);
// TODO: buy on success
}
}
})
.setNegativeButton(buttonResource.getResource("cancel").getValue(), null)
.create().show();
} else {
Util.runAuthenticationDialog(activity, book.Link, new Runnable() {

View file

@ -35,10 +35,6 @@ class LitResAuthenticationXMLReader extends ZLXMLReaderAdapter {
myException = e;
}
protected void setErrorMessage(String errorMessage) {
myException = new ZLNetworkException(true, errorMessage);
}
public ZLNetworkException getException() {
return myException;
}

View file

@ -22,8 +22,6 @@ package org.geometerplus.fbreader.network.authentication.litres;
import org.geometerplus.zlibrary.core.xml.ZLStringMap;
import org.geometerplus.zlibrary.core.network.ZLNetworkException;
import org.geometerplus.fbreader.network.NetworkException;
class LitResLoginXMLReader extends LitResAuthenticationXMLReader {
private static final String TAG_AUTHORIZATION_OK = "catalit-authorization-ok";
private static final String TAG_AUTHORIZATION_FAILED = "catalit-authorization-failed";
@ -42,7 +40,7 @@ class LitResLoginXMLReader extends LitResAuthenticationXMLReader {
public boolean startElementHandler(String tag, ZLStringMap attributes) {
tag = tag.toLowerCase().intern();
if (TAG_AUTHORIZATION_FAILED == tag) {
setException(new ZLNetworkException(NetworkException.ERROR_AUTHENTICATION_FAILED));
setException(new ZLNetworkException(ZLNetworkException.ERROR_AUTHENTICATION_FAILED));
} else if (TAG_AUTHORIZATION_OK == tag) {
FirstName = attributes.getValue("first-name");
LastName = attributes.getValue("first-name");
@ -54,7 +52,7 @@ class LitResLoginXMLReader extends LitResAuthenticationXMLReader {
}
CanRebill = stringCanRebill != null && !"0".equals(stringCanRebill) && !"no".equalsIgnoreCase(stringCanRebill);
} else {
setException(new ZLNetworkException(NetworkException.ERROR_SOMETHING_WRONG, HostName));
setException(new ZLNetworkException(ZLNetworkException.ERROR_SOMETHING_WRONG, HostName));
}
return true;
}