/* Copyright (C) 2012 Nullbyte <http://nullbyte.eu>
* Zidisha support by Per Wigren <per.wigren@gmail.com>
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.liato.bankdroid.banking.banks;
import com.liato.bankdroid.Helpers;
import com.liato.bankdroid.banking.Account;
import com.liato.bankdroid.banking.Bank;
import com.liato.bankdroid.banking.exceptions.BankChoiceException;
import com.liato.bankdroid.banking.exceptions.BankException;
import com.liato.bankdroid.banking.exceptions.LoginException;
import com.liato.bankdroid.legacy.R;
import com.liato.bankdroid.provider.IBankTypes;
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import android.content.Context;
import android.text.InputType;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import eu.nullbyte.android.urllib.CertificateReader;
import eu.nullbyte.android.urllib.Urllib;
public class Zidisha extends Bank {
private static final String NAME = "Zidisha";
private static final String URL = "https://www.zidisha.org/";
private static final int BANKTYPE_ID = IBankTypes.ZIDISHA;
private static final int INPUT_TYPE_USERNAME = InputType.TYPE_CLASS_TEXT;
private static final int INPUT_TYPE_PASSWORD = InputType.TYPE_CLASS_TEXT;
private static final String INPUT_HINT_USERNAME = "Username";
private static final boolean STATIC_BALANCE = true;
String response;
private Pattern reUserGuess = Pattern
.compile("<input.*?name=\"user_guess\" value=\"([0-9a-f]+)\"", Pattern.DOTALL);
private Pattern reAccounts = Pattern.compile(
"Funds uploaded:</td>.*?USD ([^<]+).*Credit Available:.*?USD ([^<]+).*Amount Lent By Me:.*?USD ([^<]+).*Total Impact:.*?USD ([^<]+)",
Pattern.CASE_INSENSITIVE | Pattern.DOTALL);
public Zidisha(Context context) {
super(context, R.drawable.logo_zidisha);
super.url = URL;
super.inputTypeUsername = INPUT_TYPE_USERNAME;
super.inputTypePassword = INPUT_TYPE_PASSWORD;
super.inputHintUsername = INPUT_HINT_USERNAME;
super.staticBalance = STATIC_BALANCE;
super.currency = "USD";
}
@Override
public int getBanktypeId() {
return BANKTYPE_ID;
}
@Override
public String getName() {
return NAME;
}
public Zidisha(String username, String password, Context context) throws BankException,
LoginException, BankChoiceException, IOException {
this(context);
this.update(username, password);
}
@Override
protected LoginPackage preLogin() throws BankException, IOException {
urlopen = new Urllib(context,
CertificateReader.getCertificates(context, R.raw.cert_zidisha));
urlopen.setAllowCircularRedirects(true);
response = urlopen.open("https://www.zidisha.org/");
Matcher mUserGuess = reUserGuess.matcher(response);
if (!mUserGuess.find()) {
throw new BankException(
res.getText(R.string.unable_to_find).toString() + " user_guess.");
}
String userGuess = mUserGuess.group(1);
List<NameValuePair> postData = new ArrayList<NameValuePair>();
postData.add(new BasicNameValuePair("username", getUsername()));
postData.add(new BasicNameValuePair("password", getPassword()));
postData.add(new BasicNameValuePair("textpassword", getUsername()));
postData.add(new BasicNameValuePair("userlogin", ""));
postData.add(new BasicNameValuePair("user_guess", userGuess));
return new LoginPackage(urlopen, postData, response, "https://www.zidisha.org/process.php");
}
public Urllib login() throws LoginException, BankException, IOException {
LoginPackage lp = preLogin();
response = urlopen.open(lp.getLoginTarget(), lp.getPostData());
return urlopen;
}
@Override
public void update() throws BankException, LoginException, BankChoiceException, IOException {
super.update();
if (getUsername().isEmpty() || getPassword().isEmpty()) {
throw new LoginException(res.getText(R.string.invalid_username_password).toString());
}
urlopen = login();
Matcher matcher;
response = urlopen.open("https://www.zidisha.org/index.php?p=19");
matcher = reAccounts.matcher(response);
while (matcher.find()) {
/*
* 1: Funds uploaded
* 2: Available for withdrawal
* 3: Lent by me
* 4: Total Impact
*/
Account insattningar = new Account("Insättningar",
Helpers.parseBalance(matcher.group(1)), "insattningar");
Account tillgangligt = new Account("Tillgängligt",
Helpers.parseBalance(matcher.group(2)), "tillgangligt");
Account utlanat = new Account("Utlånat", Helpers.parseBalance(matcher.group(3)),
"utlanat");
Account balans = new Account("Påverkan", Helpers.parseBalance(matcher.group(4)),
"impact");
insattningar.setCurrency("USD");
tillgangligt.setCurrency("USD");
utlanat.setCurrency("USD");
balans.setCurrency("USD");
accounts.add(insattningar);
accounts.add(tillgangligt);
accounts.add(utlanat);
accounts.add(balans);
balance = balance.add(Helpers.parseBalance(matcher.group(4)));
}
if (accounts.isEmpty()) {
throw new BankException(res.getText(R.string.no_accounts_found).toString());
}
}
}