/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package neembuu.uploader.accounts;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import neembuu.uploader.translation.Translation;
import neembuu.uploader.exceptions.NUException;
import neembuu.uploader.exceptions.accounts.NUInvalidPasswordException;
import neembuu.uploader.exceptions.accounts.NUInvalidUserException;
import neembuu.uploader.httpclient.NUHttpClient;
import neembuu.uploader.httpclient.httprequest.NUHttpPost;
import neembuu.uploader.interfaces.abstractimpl.AbstractAccount;
import neembuu.uploader.utils.CookieUtils;
import neembuu.uploader.utils.NULogger;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.CookieStore;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.protocol.ClientContext;
import org.apache.http.impl.client.BasicCookieStore;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.protocol.BasicHttpContext;
import org.apache.http.util.EntityUtils;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
/**
*
* @author dinesh
*/
public class FileDenAccount extends AbstractAccount {
private static StringBuilder cookies = null;
private HttpClient httpclient = NUHttpClient.getHttpClient();
private HttpResponse httpResponse;
private NUHttpPost httpPost;
private CookieStore cookieStore;
private String stringResponse;
public FileDenAccount() {
KEY_USERNAME = "fdusername";
KEY_PASSWORD = "fdpassword";
HOSTNAME = "FileDen.com";
}
public StringBuilder getCookies() {
return cookies;
}
@Override
public void disableLogin() {
resetLogin();
//These code are necessary for account only sites.
hostsAccountUI().hostUI(HOSTNAME).setEnabled(false);
hostsAccountUI().hostUI(HOSTNAME).setSelected(false);
updateSelectedHostsLabel();
NULogger.getLogger().log(Level.INFO, "{0} account disabled", getHOSTNAME());
}
@Override
public void login() {
httpContext = new BasicHttpContext();
cookieStore = new BasicCookieStore();
httpContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
loginsuccessful = false;
try {
cookies = new StringBuilder();
NULogger.getLogger().info("Trying to log in to fileden.com");
httpPost = new NUHttpPost("http://www.fileden.com/account.php?action=login");
List<NameValuePair> formparams = new ArrayList<NameValuePair>();
formparams.add(new BasicNameValuePair("action", "login"));
formparams.add(new BasicNameValuePair("task", "login"));
formparams.add(new BasicNameValuePair("username", getUsername()));
formparams.add(new BasicNameValuePair("password", getPassword()));
UrlEncodedFormEntity entity = new UrlEncodedFormEntity(formparams, "UTF-8");
httpPost.setEntity(entity);
httpResponse = httpclient.execute(httpPost, httpContext);
stringResponse = EntityUtils.toString(httpResponse.getEntity());
NULogger.getLogger().info("Getting cookies........");
cookies = new StringBuilder(CookieUtils.getAllCookies(httpContext));
//FileUtils.saveInFile("FileDenAccount.html", stringResponse);
if (CookieUtils.existCookie(httpContext, "uploader_username")) {
loginsuccessful = true;
NULogger.getLogger().info("FileDen Login success :)");
NULogger.getLogger().info(cookies.toString());
hostsAccountUI().hostUI(HOSTNAME).setEnabled(true);
username = getUsername();
password = getPassword();
} else {
//Handle errors
String error;
Document doc = Jsoup.parse(stringResponse);
error = doc.select("div#wrapper table tbody tr td div#sub-content1 div div ul li h3").first().text();
NULogger.getLogger().log(Level.INFO, "FileDenAccount Login error: {0}", error);
if("That user does not exist.".equals(error)){
throw new NUInvalidUserException(getUsername(), getHOSTNAME());
}
if("The password you entered is incorrect, OR ...".equals(error)){
throw new NUInvalidPasswordException(getUsername(), getHOSTNAME());
}
//Generic error
throw new Exception("FileDen Login failed with this error: "+error);
}
} catch(NUException ex){
resetLogin();
ex.printError();
accountUIShow().setVisible(true);
} catch (Exception e) {
resetLogin();
NULogger.getLogger().log(Level.SEVERE, "{0}: Error in FileDen Login {1}", new Object[]{ getClass().getName(), e});
showWarningMessage( Translation.T().loginerror(), HOSTNAME);
accountUIShow().setVisible(true);
}
}
private void resetLogin(){
loginsuccessful = false;
username = "";
password = "";
}
}