I'm trying to write a small add-on for firefox using the WebExtensions structure.
This add-on should read a local file content by it's absolute path:
"/home/saba/desktop/test.txt"  
manifest.json
{
    "manifest_version": 2,
    "name": "Test - load files",
    "version": "0.0.1",
    "description": "Test - load files",
    "permissions": [ "<all_urls>" ],
    "background": {
        "scripts": [ "main.js" ]
    }
}
Here what I tried so far (inside the main.js):
XMLHttpRequest
function readFileAjax(_path){
    var xhr = new XMLHttpRequest();
    xhr.onloadend = function(event) {
        console.log("onloadend", this);
    };
    xhr.overrideMimeType("text/plain");
    xhr.open("GET", "file:///"+_path);
    xhr.send();
}
readFileAjax("/home/saba/desktop/test.txt");
Failed. 
I can't figure out why it always return an empty response
(test.txt contains "test", the path is correct)
onloadend XMLHttpRequest { 
    onreadystatechange: null, 
    readyState: 4, 
    timeout: 0, 
    withCredentials: false, 
    upload: XMLHttpRequestUpload, 
    responseURL: "", 
    status: 0, 
    statusText: "", 
    responseType: "", 
    response: "" 
}
FileReader
function readFileFR(_path){
    var reader  = new FileReader();
    reader.addEventListener("loadend", function() {
       console.log("loadend", this.result)
    });
    reader.readAsText(file);  // file ???? 
}
readFileFR("/home/saba/desktop/test.txt");
but here I got stuck because of the file argument.
This method usually get along with an input type="file" tag which gives back a .files array. (but I only have a local path string)  
I searched if was possible to create a new Blob or File var using an absolute local file path but seams like it's not possible.  
WebExtensions API
I didn't find any clue form the documentation pages on how to do this.
Isn't there (maybe) some kind of WebExtensions API which makes this possible like in the SDK?
https://developer.mozilla.org/en-US/Add-ons/SDK/Low-Level_APIs/io_file
https://developer.mozilla.org/en-US/Add-ons/SDK/Low-Level_APIs/io_text-streams
What am I doing wrong or missing?
..is it possible to get the content of a local file by it's absolute path with a WE Add-on?
I finally found the way to do this using the Fetch requests and FileReader APIs.
Here what I came up to:
function readFile(_path, _cb){
    fetch(_path, {mode:'same-origin'})   // <-- important
    .then(function(_res) {
        return _res.blob();
    })
    .then(function(_blob) {
        var reader = new FileReader();
        reader.addEventListener("loadend", function() {
            _cb(this.result);
        });
        reader.readAsText(_blob); 
    });
};
Using the example in my question this is how to use it:
readFile('file:///home/saba/desktop/test.txt', function(_res){
    console.log(_res); // <--  result (file content)
});
If you prefer to use Promises rather than callbacks:
let readFile = (_path) => {
    return new Promise((resolve, reject) => {
        fetch(_path, {mode:'same-origin'})
            .then(function(_res) {
                return _res.blob();
            })
            .then(function(_blob) {
                var reader = new FileReader();
                reader.addEventListener("loadend", function() {
                    resolve(this.result);
                });
                reader.readAsText(_blob);
            })
            .catch(error => {
                reject(error);
            });
    });
};
Using it:
readFile('file:///home/saba/desktop/test.txt')
    .then(_res => {
        console.log(_res); // <--  result (file content)
    })
    .catch(_error => {
        console.log(_error );
    });
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With