/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package neembuu.uploader.uploaders;
import shashaank.smallmodule.SmallModule;
import neembuu.uploader.interfaces.Uploader;
import neembuu.uploader.interfaces.Account;
import java.util.logging.Level;
import java.util.logging.Logger;
import neembuu.uploader.accounts.MediaFireAccount;
import neembuu.uploader.exceptions.NUException;
import neembuu.uploader.exceptions.uploaders.NUMaxFileSizeException;
import neembuu.uploader.httpclient.NUHttpClient;
import neembuu.uploader.httpclient.httprequest.NUHttpPost;
import neembuu.uploader.interfaces.UploadStatus;
import neembuu.uploader.interfaces.abstractimpl.AbstractUploader;
import neembuu.uploader.utils.NUHttpClientUtils;
import neembuu.uploader.utils.NULogger;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.entity.mime.HttpMultipartMode;
import org.apache.http.entity.mime.MultipartEntity;
import org.apache.http.protocol.BasicHttpContext;
import org.apache.http.protocol.HttpContext;
import org.apache.http.util.EntityUtils;
import neembuu.uploader.interfaces.UploaderAccountNecessary;
import neembuu.uploader.uploaders.common.StringUtils;
/**
*
* @author Paralytic (rewritten completely, original script by Davide)
*/
@SmallModule(
exports={MediaFire.class,MediaFireAccount.class},
interfaces={Uploader.class,Account.class},
name="MediaFire.com"
)
public class MediaFire extends AbstractUploader implements UploaderAccountNecessary{
MediaFireAccount mediaFireAccount = (MediaFireAccount) getAccountsProvider().getAccount("MediaFire.com");
private final HttpClient httpclient = NUHttpClient.getHttpClient();
private HttpContext httpContext = new BasicHttpContext();
private HttpResponse httpResponse;
private NUHttpPost httpPost;
private String responseString;
private String uploadURL;
private String uploadKey = "";
private String uploadStatus = "";
private String downloadlink = "";
private String deletelink = "";
public MediaFire() {
downURL = UploadStatus.PLEASEWAIT.getLocaleSpecificString();
delURL = UploadStatus.PLEASEWAIT.getLocaleSpecificString();
host = "MediaFire.com";
if (mediaFireAccount.loginsuccessful) {
host = mediaFireAccount.username + " | MediaFire.com";
}
maxFileSizeLimit = 209715200L; // 200 MB
}
private void initialize() throws Exception {
uploadURL = "http://www.mediafire.com/api/1.3/upload/simple.php?session_token=" +mediaFireAccount.sessionToken;
}
@Override
public void run() {
try {
if (mediaFireAccount.loginsuccessful) {
if(mediaFireAccount.isPremium()){
httpContext = mediaFireAccount.getHttpContext();
// PREMIUM user
maxFileSizeLimit = 21474836480L; // 20 GB
NULogger.getLogger().info("** MediaFire.com ** => Proceeding as a premium user.");
} else {
// Regular user
httpContext = mediaFireAccount.getHttpContext();
maxFileSizeLimit = 209715200L; // 200 MB
NULogger.getLogger().info("** MediaFire.com ** => Proceeding as a regular user (non-premium)");
}
} else {
host = "MediaFire.com";
uploadInvalid();
return;
}
if (file.length() > maxFileSizeLimit) {
throw new NUMaxFileSizeException(maxFileSizeLimit, file.getName(), host);
}
uploadInitialising();
initialize();
httpPost = new NUHttpPost(uploadURL);
MultipartEntity mpEntity = new MultipartEntity(HttpMultipartMode.BROWSER_COMPATIBLE);
mpEntity.addPart("Filedata", createMonitoredFileBody());
httpPost.setEntity(mpEntity);
NULogger.getLogger().log(Level.INFO, "executing request {0}", httpPost.getRequestLine());
NULogger.getLogger().info("** MediaFire.com ** => Uploading your file now ...");
uploading();
httpResponse = httpclient.execute(httpPost, httpContext);
responseString = EntityUtils.toString(httpResponse.getEntity());
uploadKey = StringUtils.stringBetweenTwoStrings(responseString, "<key>", "</key>");
responseString = StringUtils.stringStartingFromString(responseString, "</doupload>");
responseString = StringUtils.stringBetweenTwoStrings(responseString, "<result>", "</result>");
if (responseString.equals("Success") && !uploadKey.isEmpty()){
NULogger.getLogger().info("** MediaFire.com ** => Received the upload key ... now retrieving the link");
//Read the links
gettingLink();
int i=0;
do {
responseString = "https://www.mediafire.com/api/upload/poll_upload.php?key=" +uploadKey;
responseString = NUHttpClientUtils.getData(responseString, httpContext);
uploadStatus = StringUtils.stringBetweenTwoStrings(responseString, "<status>", "</status>");
if (!uploadStatus.equals("99")) {
NULogger.getLogger().log(Level.INFO, "** MediaFire.com ** => Attempt {0}: File not processed yet at MediaFire's end.", i+1);
}
i++;
Thread.sleep(1000);
} while(!uploadStatus.equals("99") && i<10);
responseString = StringUtils.stringBetweenTwoStrings(responseString, "<quickkey>", "</quickkey>");
if (!responseString.isEmpty()){
NULogger.getLogger().info("** MediaFire.com ** => File uploaded successfully!");
} else {
NULogger.getLogger().log(Level.INFO, "** MediaFire.com ** => Retry timeout! Server did not send back a proper response even after {0} retries", i);
uploadFailed();
}
downloadlink = "http://www.mediafire.com/download/" +responseString+ "/";
deletelink = UploadStatus.NA.getLocaleSpecificString();
NULogger.getLogger().log(Level.INFO, "Delete link : {0}", deletelink);
NULogger.getLogger().log(Level.INFO, "Download link : {0}", downloadlink);
downURL = downloadlink;
delURL = deletelink;
uploadFinished();
}
} catch(NUException ex){
ex.printError();
uploadInvalid();
} catch (Exception e) {
Logger.getLogger(getClass().getName()).log(Level.SEVERE, null, e);
uploadFailed();
}
}
}