mirror of
https://github.com/pierre42100/ComunicWeb
synced 2024-12-26 02:48:51 +00:00
204 lines
4.6 KiB
JavaScript
204 lines
4.6 KiB
JavaScript
/**
|
|
* Account data export worker
|
|
*
|
|
* @author Pierre HUBERT
|
|
*/
|
|
|
|
ComunicWeb.components.account.export.worker = {
|
|
|
|
/**
|
|
* Start account export
|
|
*
|
|
* @param {String} password The password of the user
|
|
*/
|
|
start: function(password){
|
|
|
|
//Get all user text data from the interface
|
|
ComunicWeb.components.account.interface.exportData(password, function(result){
|
|
|
|
//Check for errors
|
|
if(result.error){
|
|
return ComunicWeb.components.account.export.ui.exportFatalError("Could not get text data! Please check your password...");
|
|
}
|
|
|
|
//Update progress
|
|
ComunicWeb.components.account.export.ui.updateMessage("Got text data");
|
|
ComunicWeb.components.account.export.ui.updateProgress(10);
|
|
|
|
//Parse data
|
|
ComunicWeb.components.account.export.worker.parse(result);
|
|
});
|
|
|
|
},
|
|
|
|
/**
|
|
* Parse account text data into ZIP file
|
|
*
|
|
* @param {Object} data Text data about the account
|
|
*/
|
|
parse: function(data){
|
|
|
|
//Get UI shorcut
|
|
var ui = ComunicWeb.components.account.export.ui;
|
|
|
|
var Promise = window.Promise;
|
|
if (!Promise) {
|
|
Promise = JSZip.external.Promise;
|
|
}
|
|
|
|
/**
|
|
* Fetch the content and return the associated promise.
|
|
* @param {String} url the url of the content to fetch.
|
|
* @return {Promise} the promise containing the data.
|
|
*/
|
|
function urlToPromise(url) {
|
|
return new Promise(function(resolve, reject) {
|
|
JSZipUtils.getBinaryContent(url, function (err, data) {
|
|
if(err) {
|
|
reject(err);
|
|
} else {
|
|
resolve(data);
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Transform an URL into a path in the archive
|
|
*
|
|
* @param {String} url The URL to transform
|
|
* @return {String} Generated file path
|
|
*/
|
|
function urlToPath(url) {
|
|
var path = url.replace("://", "/");
|
|
return "files/" + path;
|
|
}
|
|
|
|
//Determine the list of files to download
|
|
var files_list = this._generate_files_list(data);
|
|
|
|
//Create zip file
|
|
var zip = new JSZip();
|
|
|
|
//Add raw json file
|
|
zip.file("source.json", JSON.stringify(data));
|
|
|
|
//Add the files to download
|
|
files_list.forEach(function(url){
|
|
var path = urlToPath(url);
|
|
zip.file(path, urlToPromise(url), {binary:true});
|
|
});
|
|
|
|
//Generated zip archive
|
|
zip.generateAsync({type:"blob"}, function updateCallback(metadata) {
|
|
var msg = "progression : " + metadata.percent.toFixed(2) + " %";
|
|
if(metadata.currentFile) {
|
|
msg += ", current file = " + metadata.currentFile;
|
|
}
|
|
ui.updateMessage(msg);
|
|
ui.updateProgress(metadata.percent.toFixed(2));
|
|
})
|
|
|
|
//Trigger download
|
|
.then(function callback(blob) {
|
|
|
|
//Download file
|
|
saveAs(blob, "accountData.zip");
|
|
|
|
//Update progress
|
|
ui.updateProgress(100);
|
|
ui.updateMessage("Done !");
|
|
|
|
}, function (e) {
|
|
//In case of error
|
|
ComunicWeb.components.account.export.ui.exportFatalError(e);
|
|
|
|
//Update progress
|
|
ui.updateProgress(100);
|
|
ui.updateMessage("Error !");
|
|
});
|
|
|
|
},
|
|
|
|
/**
|
|
* Determine the list of files to download
|
|
*
|
|
* @param {Object} data Dataset to parse
|
|
* @return {Array} Generated dataset
|
|
*/
|
|
_generate_files_list: function(data){
|
|
|
|
var files = [];
|
|
|
|
/**
|
|
* Parse a comment to find potential files to download
|
|
*
|
|
* @param {Object} info Information about the comment to parse
|
|
*/
|
|
var parseComment = function(info){
|
|
if(info.img_url != null)
|
|
if(!files.includes(info.img_url))
|
|
files.push(info.img_url);
|
|
}
|
|
|
|
/**
|
|
* Parse a post to find potential files to download
|
|
*
|
|
* @param {Object} info Information about the post to parse
|
|
*/
|
|
var parsePost = function(post){
|
|
|
|
if(post.kind != "youtube"){
|
|
if(post.file_path_url != null){
|
|
if(!files.includes(post.file_path_url))
|
|
files.push(post.file_path_url);
|
|
}
|
|
}
|
|
|
|
//Parse comments
|
|
post.comments.forEach(parseComment);
|
|
}
|
|
|
|
/**
|
|
* Parse a movie to find potential files to download
|
|
*
|
|
* @param {Object} info Information about the movie to parse
|
|
*/
|
|
var parseMovie = function(info){
|
|
if(info.url != null)
|
|
if(!files.includes(info.url))
|
|
files.push(info.url);
|
|
}
|
|
|
|
/**
|
|
* Parse a conversation message to find potential files to download
|
|
*
|
|
* @param {Object} info Information about the movie to parse
|
|
*/
|
|
var parseConversationMessage = function(info){
|
|
if(info.image_path != null)
|
|
if(!files.includes(info.image_path))
|
|
files.push(info.image_path);
|
|
}
|
|
|
|
|
|
//Main account information
|
|
files.push(data.advanced_info.accountImage);
|
|
files.push(data.advanced_info.backgroundImage);
|
|
|
|
//Posts
|
|
data.posts.forEach(parsePost);
|
|
|
|
//Comments
|
|
data.comments.forEach(parseComment);
|
|
|
|
//Movie
|
|
data.movies.forEach(parseMovie);
|
|
|
|
//Conversation message
|
|
data.conversation_messages.forEach(parseConversationMessage);
|
|
|
|
return files;
|
|
}
|
|
|
|
} |