Use fs-extra instead of node-json-db

This commit is contained in:
HirokiUchikawa 2018-06-07 20:17:51 +09:00
parent f44487338d
commit ed1d34e678
2 changed files with 52 additions and 57 deletions

View File

@ -57,7 +57,6 @@
"mqtt": "2.18.0",
"multer": "1.3.0",
"mustache": "2.3.0",
"node-json-db": "0.7.5",
"node-red-node-email": "0.1.*",
"node-red-node-feedparser": "0.1.*",
"node-red-node-rbe": "0.2.*",

View File

@ -14,25 +14,25 @@
* limitations under the License.
**/
var JsonDB = require('node-json-db');
var fs = require('fs-extra');
var path = require("path");
var when = require("when");
var util = require("../../util");
function createStorage(storageBaseDir, scope) {
function getStoragePath(storageBaseDir, scope) {
if(scope.indexOf(":") === -1){
if(scope === "global"){
return new JsonDB(path.join(storageBaseDir,"global",scope), true, true);
return path.join(storageBaseDir,"global",scope);
}else{ // scope:flow
return new JsonDB(path.join(storageBaseDir,scope,"flow"), true, true);
return path.join(storageBaseDir,scope,"flow");
}
}else{ // scope:local
var ids = scope.split(":")
return new JsonDB(path.join(storageBaseDir,ids[1],ids[0]), true, true);
return path.join(storageBaseDir,ids[1],ids[0]);
}
}
function getStoragePath(config) {
function getBasePath(config) {
var base = config.base || "contexts";
var storageBaseDir;
if (!config.dir) {
@ -62,10 +62,21 @@ function getStoragePath(config) {
return storageBaseDir;
}
function loadFile(storagePath){
return fs.pathExists(storagePath).then(function(exists){
if(exists === true){
return fs.readFile(storagePath, "utf8");
}else{
return when.resolve(undefined);
}
}).catch(function(err){
throw when.reject(err);
});
}
function LocalFileSystem(config){
this.config = config;
this.storageBaseDir = getStoragePath(this.config);
this.storages = {};
this.storageBaseDir = getBasePath(this.config);
}
LocalFileSystem.prototype.open = function(){
@ -76,63 +87,49 @@ LocalFileSystem.prototype.close = function(){
return when.resolve();
}
LocalFileSystem.prototype.get = function (scope, key) {
if(!this.storages[scope]){
this.storages[scope] = createStorage(this.storageBaseDir ,scope);
}
try{
this.storages[scope].reload();
return this.storages[scope].getData("/" + key.replace(/\./g,"/"));
}catch(err){
if(err.name === "DataError"){
return undefined;
}else{
throw err;
}
}
}
LocalFileSystem.prototype.set = function(scope, key, value) {
if(!this.storages[scope]){
this.storages[scope] = createStorage(this.storageBaseDir ,scope);
}
if(value){
this.storages[scope].push("/" + key.replace(/\./g,"/"), value);
}else{
this.storages[scope].delete("/" + key.replace(/\./g,"/"));
}
}
LocalFileSystem.prototype.keys = function(scope) {
if(!this.storages[scope]){
this.storages[scope] = createStorage(this.storageBaseDir ,scope);
}
return Object.keys(this.storages[scope].getData("/"));
}
LocalFileSystem.prototype.getAsync = function(scope, key) {
return when.resolve(this.get(scope, key));
var storagePath = getStoragePath(this.storageBaseDir ,scope);
return loadFile(storagePath).then(function(data){
if(data){
return util.getMessageProperty(JSON.parse(data),key);
}else{
return undefined
}
}).catch(function(err){
return when.reject(err);
});
};
LocalFileSystem.prototype.setAsync =function(scope, key, value) {
return when.resolve(this.set(scope, key, value));
var storagePath = getStoragePath(this.storageBaseDir ,scope);
return loadFile(storagePath).then(function(data){
var obj = data ? JSON.parse(data) : {}
util.setMessageProperty(obj,key,value);
return obj;
}).then(function(obj){
var str = JSON.stringify(obj, undefined, 4);
return fs.outputFile(storagePath, str, "utf8");
}).catch(function(err){
return when.reject(err);
});
};
LocalFileSystem.prototype.keysAsync = function(scope){
return when.resolve(this.keys(scope));
var storagePath = getStoragePath(this.storageBaseDir ,scope);
return loadFile(storagePath).then(function(data){
if(data){
return Object.keys(JSON.parse(data));
}else{
return []
}
}).catch(function(err){
return when.reject(err);
});
};
LocalFileSystem.prototype.delete = function(scope){
var self = this;
if(this.storages[scope]){
this.storages[scope].delete("/");
return fs.remove(this.storages[scope].filename).then(function(){
delete self.storages[scope];
return when.resolve();
});
}else{
return when.resolve();
}
var storagePath = getStoragePath(this.storageBaseDir ,scope);
return fs.remove(storagePath);
}
LocalFileSystem.prototype.clean = function(activeNodes){
@ -141,7 +138,6 @@ LocalFileSystem.prototype.clean = function(activeNodes){
return when.all(dirs.reduce(function(result, item){
if(item !== "global" && activeNodes.indexOf(item) === -1){
result.push(fs.remove(path.join(self.storageBaseDir,item)));
delete self.storages[item];
}
return result;
},[]));