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

code simplification

This commit is contained in:
Nikolay Pultsin 2011-10-03 00:08:08 +01:00
parent a53ed813fb
commit 319fe52aa4
3 changed files with 45 additions and 81 deletions

View file

@ -30,7 +30,6 @@ import org.geometerplus.zlibrary.core.network.ZLNetworkException;
import org.geometerplus.fbreader.network.*;
import org.geometerplus.fbreader.network.authentication.NetworkAuthenticationManager;
import org.geometerplus.fbreader.network.authentication.litres.LitResAuthenticationManager;
import org.geometerplus.fbreader.network.urlInfo.UrlInfo;
import org.geometerplus.fbreader.network.urlInfo.BookUrlInfo;
@ -64,31 +63,24 @@ public abstract class Util implements UserRegistrationConstants {
}, activity);
}
private static boolean testService(Activity activity, String action, String url) {
return url != null && PackageUtil.canBeStarted(activity, new Intent(action, Uri.parse(url)), true);
static Intent authorizationIntent(INetworkLink link, Uri id) {
final Intent intent = new Intent(AUTHORIZATION_ACTION, id);
intent.putExtra(CATALOG_URL, link.getUrl(UrlInfo.Type.Catalog));
intent.putExtra(SIGNUP_URL, link.getUrl(UrlInfo.Type.SignUp));
return intent;
}
private static Intent registrationIntent(INetworkLink link) {
return authorizationIntent(link, Uri.parse(link.getUrl(UrlInfo.Type.Catalog) + "/register"));
}
public static boolean isRegistrationSupported(Activity activity, INetworkLink link) {
return testService(
activity,
AUTHORIZATION_ACTION,
link.getUrl(UrlInfo.Type.Catalog) + "/register"
);
}
static void addAuthorizationData(Intent intent, INetworkLink link) {
intent.putExtra(CATALOG_URL, link.getUrl(UrlInfo.Type.Catalog));
intent.putExtra(SIGNUP_URL, link.getUrl(UrlInfo.Type.SignUp));
return PackageUtil.canBeStarted(activity, registrationIntent(link), true);
}
public static void runRegistrationDialog(Activity activity, INetworkLink link) {
try {
final NetworkAuthenticationManager mgr = link.authenticationManager();
final Intent intent = new Intent(
AUTHORIZATION_ACTION,
Uri.parse(link.getUrl(UrlInfo.Type.Catalog) + "/register")
);
addAuthorizationData(intent, link);
final Intent intent = registrationIntent(link);
if (PackageUtil.canBeStarted(activity, intent, true)) {
activity.startActivity(intent);
}
@ -107,61 +99,6 @@ public abstract class Util implements UserRegistrationConstants {
activity.startActivity(intent);
}
static void processSignup(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;
}
} catch (ZLNetworkException e) {
// TODO: show an error message
}
}
}
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(Activity activity, String url) {
if (url != null) {
url = NetworkLibrary.Instance().rewriteUrl(url, true);