2018-04-30 22:07:37 +10:00
|
|
|
/*global web3 */
|
2018-04-30 15:56:43 +10:00
|
|
|
let __embarkSwarm = {};
|
|
|
|
const bytes = require("eth-lib/lib/bytes");
|
|
|
|
|
2018-05-01 09:38:13 -04:00
|
|
|
__embarkSwarm.setProvider = function (options) {
|
2018-04-30 15:56:43 +10:00
|
|
|
this.bzz = web3.bzz;
|
|
|
|
this.protocol = options.protocol;
|
|
|
|
this.host = options.host;
|
|
|
|
this.port = options.port;
|
|
|
|
this.connectUrl = `${options.protocol}://${options.host}:${options.port}`;
|
|
|
|
this.connectError = new Error(`Cannot connect to Swarm node on ${this.connectUrl}`);
|
|
|
|
this._getUrl = options.getUrl || `${this.connectUrl}/bzzr:/`;
|
|
|
|
|
2018-05-01 10:20:27 -04:00
|
|
|
return new Promise((resolve, reject) => {
|
2018-04-30 15:56:43 +10:00
|
|
|
try {
|
2018-05-01 09:38:13 -04:00
|
|
|
if (!this.bzz.currentProvider) {
|
2018-04-30 15:56:43 +10:00
|
|
|
this.bzz.setProvider(`${options.protocol}://${options.host}:${options.port}`);
|
|
|
|
}
|
|
|
|
resolve(this);
|
|
|
|
} catch (err) {
|
|
|
|
console.log(err);
|
|
|
|
reject(this.connectError);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2018-05-01 09:38:13 -04:00
|
|
|
__embarkSwarm.isAvailable = function () {
|
2018-04-30 15:56:43 +10:00
|
|
|
return new Promise((resolve, reject) => {
|
2018-05-01 09:38:13 -04:00
|
|
|
if (!this.bzz) {
|
|
|
|
return resolve(false);
|
|
|
|
}
|
2018-04-30 15:56:43 +10:00
|
|
|
this.bzz.isAvailable()
|
|
|
|
.then(resolve)
|
2018-05-01 09:38:13 -04:00
|
|
|
.catch(() => {
|
|
|
|
reject(this.connectError);
|
|
|
|
});
|
2018-04-30 15:56:43 +10:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2018-05-01 09:38:13 -04:00
|
|
|
__embarkSwarm.saveText = function (text) {
|
2018-04-30 15:56:43 +10:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
this.isAvailable().then((isAvailable) => {
|
2018-05-01 09:38:13 -04:00
|
|
|
if (!isAvailable) {
|
|
|
|
return reject(this.connectError);
|
|
|
|
}
|
2018-04-30 15:56:43 +10:00
|
|
|
this.bzz.upload(text)
|
|
|
|
.then(resolve)
|
|
|
|
.catch(reject);
|
|
|
|
}).catch(reject);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2018-05-01 09:38:13 -04:00
|
|
|
__embarkSwarm.get = function (hash) {
|
2018-04-30 15:56:43 +10:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
this.isAvailable().then((isAvailable) => {
|
2018-05-01 09:38:13 -04:00
|
|
|
if (!isAvailable) {
|
|
|
|
return reject(this.connectError);
|
|
|
|
}
|
2018-04-30 15:56:43 +10:00
|
|
|
this.bzz.download(hash)
|
|
|
|
.then((uint8Array) => resolve(bytes.toString(bytes.fromUint8Array(uint8Array))))
|
|
|
|
.catch(reject);
|
|
|
|
}).catch(reject);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2018-05-01 09:38:13 -04:00
|
|
|
__embarkSwarm.uploadFile = function (inputSelector) {
|
2018-04-30 15:56:43 +10:00
|
|
|
let file = inputSelector[0].files[0];
|
|
|
|
|
|
|
|
if (file === undefined) {
|
|
|
|
throw new Error('no file found');
|
|
|
|
}
|
|
|
|
|
|
|
|
return new Promise((resolve, reject) => {
|
2018-05-01 10:20:27 -04:00
|
|
|
const reader = new FileReader();
|
2018-04-30 15:56:43 +10:00
|
|
|
reader.onloadend = (event) => {
|
2018-05-01 10:20:27 -04:00
|
|
|
const fileContent = new Uint8Array(event.target.result);
|
2018-04-30 15:56:43 +10:00
|
|
|
this.isAvailable().then((isAvailable) => {
|
2018-05-01 09:38:13 -04:00
|
|
|
if (!isAvailable) {
|
|
|
|
return reject(this.connectError);
|
|
|
|
}
|
2018-04-30 15:56:43 +10:00
|
|
|
this.bzz.upload(fileContent)
|
2018-05-01 09:38:13 -04:00
|
|
|
.then(resolve)
|
|
|
|
.catch(reject);
|
2018-04-30 15:56:43 +10:00
|
|
|
}).catch(reject);
|
|
|
|
};
|
|
|
|
reader.onerror = reject;
|
|
|
|
reader.readAsArrayBuffer(file);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2018-05-01 09:38:13 -04:00
|
|
|
__embarkSwarm.getUrl = function (hash) {
|
2018-04-30 15:56:43 +10:00
|
|
|
return this._getUrl + hash;
|
|
|
|
};
|
|
|
|
|