mirror of
https://github.com/geometer/FBReaderJ.git
synced 2025-10-04 10:19:33 +02:00
code simplification
This commit is contained in:
parent
a53ed813fb
commit
319fe52aa4
3 changed files with 45 additions and 81 deletions
|
@ -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);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue