// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. function moduleDidLoad() { common.hideModule(); } function $(id) { return document.getElementById(id); } /* * file system functions * */ window.requestFileSystem = window.requestFileSystem || window.webkitRequestFileSystem; function errorHandler(e,callback,name) { var msg = ''; switch (e.code) { case FileError.QUOTA_EXCEEDED_ERR: msg = 'QUOTA_EXCEEDED_ERR'; break; case FileError.NOT_FOUND_ERR: msg = 'NOT_FOUND_ERR'; if(callback){ callback(name);} break; case FileError.SECURITY_ERR: msg = 'SECURITY_ERR'; break; case FileError.INVALID_MODIFICATION_ERR: msg = 'INVALID_MODIFICATION_ERR'; break; case FileError.INVALID_STATE_ERR: msg = 'INVALID_STATE_ERR'; break; default: msg = 'Unknown Error'; break; }; console.log('Error: ' + msg); } var fileSystem=null; var files={}; function copyHelpFiles(callback) { var helpFiles = [ 'agent.md', 'bootstrap-theme.min.css', 'bootstrap.min.css', 'bootstrap.min.js', 'field.html', 'field.md', 'footer.html', 'footer.md', 'formfooter.html', 'formfooter.md', 'formheader.html', 'formheader.md', 'header.html', 'header.md', 'html5shiv.min.js', 'jquery-ui.css', 'jquery-ui.min.js', 'jquery.min.js', 'mime.json', 'respond.min.js' ]; var rootDir='help'; var $dfds = $.map(helpFiles,function(fname){ var $dfd=$.Deferred(); $.get(chrome.runtime.getURL(rootDir+'/'+fname)) .done(function(str){ fileSystem.root.getFile('/'+rootDir+'/'+fname, { create: true }, function(fileEntry) { // Create a FileWriter object for our FileEntry (log.txt). fileEntry.createWriter(function(fileWriter) { fileWriter.onwriteend = function() { console.log('Write completed.',fname,str.length); $dfd.resolve(true); }; fileWriter.onerror = function(e) { console.log('Write failed: ',fname, e.toString()); $dfd.resolve(false); }; // Create a new Blob and write it to log.txt. var blob = new Blob([str], { type: 'text/plain' }); fileWriter.write(blob); // $dfd.resolve(true); }, function(createWriterErr){ console.log('createWriterErr for',fname,createWriterErr); $dfd.resolve(false); }); }, function(createFileErr){ console.log('createFileErr for',fname,createFileErr); $dfd.resolve(false); }); }); return $dfd; }); return $.when.apply($,$dfds); } // Called by the common.js module. function domContentLoaded(name, tc, config, width, height) { navigator.webkitPersistentStorage.requestQuota(10000000000, function(bytes) { window.requestFileSystem(PERSISTENT, bytes, function(fs) { console.log('Opened file system: ' + fs.name); fileSystem = fs; common.updateStatus( 'Allocated ' + bytes + ' bytes of persistent storage. Running the first time will take 17 seconds to load'); common.attachDefaultListeners(); common.createNaClModule(name, tc, config, width, height); setTimeout(function(){ copyHelpFiles(); },2000); }, errorHandler); }, function(e) { console.log('Error', e); }); } var check_files=function(){ var coins= coinManagement.getCoinSymbols(); var files=["_hdrs.txt","_peers.txt"]; for(var i=0;i<coins.length;i++){ for(var j=0;j<files.length;j++){ var name="confs/"+coins[i]+files[j]; console.log("checking file "+name); check_if_file_present(name); } } }; var check_if_file_present=function(filename,callback){ var contents=""; fileSystem.root.getFile(filename, {}, function(fileEntry) { //console.log("entered file fu"); // Get a File object representing the file, // then use FileReader to read its contents. fileEntry.file(function(file) { var reader = new FileReader(); reader.onloadend = function(e) { //var txtArea = document.createElement('textarea'); //console.log("Configuration file text: "+this.result.toString()); console.log("File already present in HTML5 system:"+fileEntry.fullPath); //SPNAPI.conf_files[filename]=this.result.toString(); }; reader.readAsText(file); }, function(e){ errorHandler(e,access_and_save_conf_file,filename); }); }, function(e){ errorHandler(e,access_and_save_conf_file,filename); }); }; var access_and_save_conf_file=function(name){ console.log("access file called for "+name); $.ajax({ type: "GET", url: name, //async: false, success: function (data){ save_contents(data,name); } }); }; var save_contents=function(contents,name){ fileSystem.root.getFile(name, {create: true}, function(fileEntry) { // Create a FileWriter object for our FileEntry (log.txt). fileEntry.createWriter(function(fileWriter) { fileWriter.onwriteend = function(e) { console.log(name+' saved!'); }; fileWriter.onerror = function(e) { console.log('Write failed: ' + e.toString()); }; // Create a new Blob and write it to log.txt. var blob = new Blob([contents], {type: 'text/plain'}); fileWriter.write(blob); }, errorHandler); }, errorHandler); }; var delete_file=function(name){ fileSystem.root.getFile(name, {create: false}, function(fileEntry) { fileEntry.remove(function() { console.log(name+' removed.'); }, errorHandler); }, errorHandler); }; var reset_conf_files=function(){ var coins= coinManagement.getCoinSymbols(); var files=["_hdrs.txt","_peers.txt"]; for(var i=0;i<coins.length;i++){ for(var j=0;j<files.length;j++){ var name="confs/"+coins[i]+files[j]; delete_file(name); access_and_save_conf_file(name); } } }; // Called by the common.js module. function attachListeners() { var radioEls = document.querySelectorAll('input[type="radio"]'); for (var i = 0; i < radioEls.length; ++i) { radioEls[i].addEventListener('click', onRadioClicked); } // Wire up the 'click' event for each function's button. var functionEls = document.querySelectorAll('.function'); for (var i = 0; i < functionEls.length; ++i) { var functionEl = functionEls[i]; var id = functionEl.getAttribute('id'); var buttonEl = functionEl.querySelector('button'); // The function name matches the element id. var func = window[id]; buttonEl.addEventListener('click', func); } //$('pipe_input_box').addEventListener('keypress', onPipeInput) //$('pipe_output').disabled = true; //$('pipe_name').addEventListener('change', function() { $('pipe_output').value = ''; }) } // Called with keypress events on the pipe input box function onPipeInput(e) { // Create an arraybuffer containing the 16-bit char code // from the keypress event. var buffer = new ArrayBuffer(1*2); var bufferView = new Uint16Array(buffer); bufferView[0] = e.charCode; // Pass the buffer in a dictionary over the NaCl module var pipeSelect = $('pipe_name'); var pipeName = pipeSelect[pipeSelect.selectedIndex].value; var message = { pipe: pipeName, operation: 'write', payload: buffer, }; nacl_module.postMessage(message); e.preventDefault(); return false; } function onRadioClicked(e) { var divId = this.id.slice(5); // skip "radio" var functionEls = document.querySelectorAll('.function'); for (var i = 0; i < functionEls.length; ++i) { var visible = functionEls[i].id === divId; if (functionEls[i].id === divId) functionEls[i].removeAttribute('hidden'); else functionEls[i].setAttribute('hidden', ''); } } function addNameToSelectElements(cssClass, handle, name) { var text = '[' + handle + '] ' + name; var selectEls = document.querySelectorAll(cssClass); for (var i = 0; i < selectEls.length; ++i) { var optionEl = document.createElement('option'); optionEl.setAttribute('value', handle); optionEl.appendChild(document.createTextNode(text)); selectEls[i].appendChild(optionEl); } } function removeNameFromSelectElements(cssClass, handle) { var optionEls = document.querySelectorAll(cssClass + ' > option'); for (var i = 0; i < optionEls.length; ++i) { var optionEl = optionEls[i]; if (optionEl.value == handle) { var selectEl = optionEl.parentNode; selectEl.removeChild(optionEl); } } } var funcToCallback = {}; function postCall(func) { var callback = arguments[arguments.length - 1]; funcToCallback[func] = callback; nacl_module.postMessage({ cmd: func, args: Array.prototype.slice.call(arguments, 1, -1) }); } function ArrayBufferToString(buf) { return String.fromCharCode.apply(null, new Uint16Array(buf)); } // Called by the common.js module. function handleMessage(message_event) { var data = message_event.data; if ((typeof(data) === 'string' || data instanceof String)) { check_if_pexe_7778_working(data); common.logMessage(data); } else if (data instanceof Object) { var pipeName = data['pipe'] if ( pipeName !== undefined ) { // Message for JavaScript I/O pipe var operation = data['operation']; if (operation == 'write') { $('pipe_output').value += ArrayBufferToString(data['payload']); } else if (operation == 'ack') { common.logMessage(pipeName + ": ack:" + data['payload']); } else { common.logMessage('Got unexpected pipe operation: ' + operation); } } else { // Result from a function call. var params = data.args; var funcName = data.cmd; var callback = funcToCallback[funcName]; if (!callback) { common.logMessage('Error: Bad message ' + funcName + ' received from NaCl module.'); return; } delete funcToCallback[funcName]; callback.apply(null, params); } } else { common.logMessage('Error: Unknow message `' + data + '` received from NaCl module.'); } } var APPLICATION={pexe:"not loaded",port7778:"Not binded"}; var check_if_pexe_7778_working=function(string){ var if_changed=0; if(string.indexOf("iguana_rpcloop")>-1 && string.indexOf("bind sock")>-1 ){ APPLICATION.port7778="successfully binded"; setTimeout(initialization_commands,3000); if_changed=1; }else if(string.indexOf("finished DidCreate iguana")>-1){ APPLICATION.pexe="Loaded"; if_changed=1; setTimeout(initialization_commands,3000); }else if(string.indexOf("ERROR BINDING PORT.7778")>-1){ //APPLICATION.state="Loading.."; APPLICATION.port7778="Retrying"; /*if(APPLICATION.pexe.indexOf("not loaded")>-1 || APPLICATION.pexe.indexOf("crashed")>-1){ APPLICATION.state="not working"; }*/ if_changed=1; }else if(string.indexOf("NaCl module crashed")>-1){ APPLICATION.pexe="crashed"; if_changed=1; }else if(string.indexOf("try again: Address already in use")>-1){ APPLICATION.port7778="bind failed"; if_changed=1; } if(if_changed){change_app_status();} //finished DidCreate iguana // ERROR BINDING PORT.7778. will exit. wait up to a minute and try again. dont worry, this is normal // NativeClient: NaCl module crashed //string.indexOf(substring) > -1 //bind(127.0.0.1) port.7778 try again: Address already in use sock.4. errno.98 }; var change_app_status=function(){ var html="<tr><td>Parameter</td><td>Status</td></tr>"; //html=html+"<tr><td>Application state:</td><td>"+APPLICATION.state+"</td></tr>"; html=html+"<tr><td>Pexe state:</td><td>"+APPLICATION.pexe+"</td></tr>"; html=html+"<tr><td>Port 7778 state:</td><td>"+APPLICATION.port7778+"</td></tr>"; $("#appstatus").html(html); }; var initialization_commands=function(){ addInitCoins(); load_peers_to_pool(); ListAllExchanges(); };