KVV not available implemented
This commit is contained in:
@@ -17,6 +17,7 @@ import de.sebse.fuplanner.R;
|
||||
import de.sebse.fuplanner.services.kvv.sync.BBLogin;
|
||||
import de.sebse.fuplanner.services.kvv.sync.FULogin;
|
||||
import de.sebse.fuplanner.services.kvv.sync.KVVLogin;
|
||||
import de.sebse.fuplanner.services.kvv.types.LoginTokenKVV;
|
||||
import de.sebse.fuplanner.tools.logging.Logger;
|
||||
import de.sebse.fuplanner.tools.network.NetworkError;
|
||||
import de.sebse.fuplanner.tools.network.NetworkErrorCallback;
|
||||
@@ -76,7 +77,17 @@ public class UserLoginTask extends AsyncTask<Void, Void, String> {
|
||||
login.set(success1.toJsonString());
|
||||
latch.countDown();
|
||||
}, errorFunc);
|
||||
}, errorFunc);
|
||||
}, error -> {
|
||||
if (error.getCode() == 100101) {
|
||||
// KVV never used
|
||||
LoginTokenKVV loginTokenKVV = new LoginTokenKVV(mUsername, "");
|
||||
loginTokenKVV.setNotAvailable();
|
||||
login.set(loginTokenKVV.toJsonString());
|
||||
latch.countDown();
|
||||
} else {
|
||||
errorFunc.onError(error);
|
||||
}
|
||||
});
|
||||
break;
|
||||
case AccountGeneral.AUTHTOKEN_TYPE_BLACKBOARD:
|
||||
mBBLogin.doLogin(mUsername, mPassword, success -> {
|
||||
|
||||
@@ -68,6 +68,7 @@ public class KVVLogin extends HTTPService {
|
||||
|
||||
|
||||
public void doLogin(String username, String password, NetworkCallback<LoginTokenKVV> callback, NetworkErrorCallback error) {
|
||||
step0(username, success -> {
|
||||
step1(success1 -> {
|
||||
String samlLocation = success1.get("Location");
|
||||
mFULogin.fulogin(samlLocation, username, password, samlResponse -> {
|
||||
@@ -82,6 +83,19 @@ public class KVVLogin extends HTTPService {
|
||||
}, error);
|
||||
}, error);
|
||||
}, error);
|
||||
}, error);
|
||||
}
|
||||
|
||||
private void step0(String username, final NetworkCallback<Boolean> callback, final NetworkErrorCallback errorCallback) {
|
||||
get(String.format("https://kvv.imp.fu-berlin.de/direct/profile/%s", username), null, result -> {
|
||||
callback.onResponse(true);
|
||||
}, error -> {
|
||||
if (error.networkResponse.statusCode == 500) {
|
||||
errorCallback.onError(new NetworkError(100101, error.networkResponse.statusCode, "KVV not available!"));
|
||||
} else {
|
||||
callback.onResponse(true);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
Reference in New Issue
Block a user