mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-02 20:16:04 +01:00
removed the setName from sorted sets and stored them with _key like everything else
This commit is contained in:
@@ -46,7 +46,7 @@
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(collection) {
|
if(collection) {
|
||||||
collection.ensureIndex({_key :1, setName:1}, {background:true}, function(err, name){
|
collection.ensureIndex({_key :1}, {background:true}, function(err, name){
|
||||||
if(err) {
|
if(err) {
|
||||||
winston.error("Error creating index " + err.message);
|
winston.error("Error creating index " + err.message);
|
||||||
}
|
}
|
||||||
@@ -73,6 +73,39 @@
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// helper functions
|
||||||
|
//
|
||||||
|
function removeHiddenFields(item) {
|
||||||
|
if(item) {
|
||||||
|
if(item._id) {
|
||||||
|
delete item._id;
|
||||||
|
}
|
||||||
|
if(item._key) {
|
||||||
|
delete item._key;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
|
function findItem(data, key) {
|
||||||
|
if(!data) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(var i=0; i<data.length; ++i) {
|
||||||
|
if(data[i]._key === key) {
|
||||||
|
var item = data.splice(i, 1);
|
||||||
|
if(item && item.length) {
|
||||||
|
return item[0];
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Exported functions
|
// Exported functions
|
||||||
@@ -165,7 +198,7 @@
|
|||||||
// key
|
// key
|
||||||
|
|
||||||
module.exists = function(key, callback) {
|
module.exists = function(key, callback) {
|
||||||
db.collection('objects').findOne({$or:[{_key:key}, {setName:key}]}, function(err, item) {
|
db.collection('objects').findOne({_key:key}, function(err, item) {
|
||||||
callback(err, item !== undefined && item !== null);
|
callback(err, item !== undefined && item !== null);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -180,16 +213,8 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(result === 0) {
|
if(callback) {
|
||||||
db.collection('objects').remove({setName:key}, function(err, result) {
|
callback(null, result);
|
||||||
if(callback) {
|
|
||||||
callback(err, result);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if(callback) {
|
|
||||||
callback(null, result);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -210,21 +235,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
//hashes
|
//hashes
|
||||||
function removeHiddenFields(item) {
|
|
||||||
if(item) {
|
|
||||||
if(item._id) {
|
|
||||||
delete item._id;
|
|
||||||
}
|
|
||||||
if(item._key) {
|
|
||||||
delete item._key;
|
|
||||||
}
|
|
||||||
if(item.setName) {
|
|
||||||
delete item.setName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return item;
|
|
||||||
}
|
|
||||||
|
|
||||||
module.setObject = function(key, data, callback) {
|
module.setObject = function(key, data, callback) {
|
||||||
data['_key'] = key;
|
data['_key'] = key;
|
||||||
db.collection('objects').update({_key:key}, {$set:data}, {upsert:true, w: 1}, function(err, result) {
|
db.collection('objects').update({_key:key}, {$set:data}, {upsert:true, w: 1}, function(err, result) {
|
||||||
@@ -262,30 +272,10 @@
|
|||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
var returnData = [],
|
var returnData = [];
|
||||||
resultIndex = 0;
|
|
||||||
|
|
||||||
|
|
||||||
function findData(key) {
|
|
||||||
if(!data) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(var i=0; i<data.length; ++i) {
|
|
||||||
if(data[i]._key === key) {
|
|
||||||
var item = data.splice(i, 1);
|
|
||||||
if(item && item.length) {
|
|
||||||
return item[0];
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(var i=0; i<keys.length; ++i) {
|
for(var i=0; i<keys.length; ++i) {
|
||||||
returnData.push(findData(keys[i]));
|
returnData.push(findItem(data, keys[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(err, returnData);
|
callback(err, returnData);
|
||||||
@@ -505,15 +495,18 @@
|
|||||||
value:value
|
value:value
|
||||||
};
|
};
|
||||||
|
|
||||||
data.setName = key;
|
db.collection('objects').update({_key:key, value:value}, {$set:data}, {upsert:true, w: 1}, function(err, result) {
|
||||||
module.setObject(key + ':' + value, data, callback);
|
if(callback) {
|
||||||
|
callback(err, result);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
module.sortedSetRemove = function(key, value, callback) {
|
module.sortedSetRemove = function(key, value, callback) {
|
||||||
if(value !== null && value !== undefined) {
|
if(value !== null && value !== undefined) {
|
||||||
value = value.toString();
|
value = value.toString();
|
||||||
}
|
}
|
||||||
db.collection('objects').remove({setName:key, value:value}, function(err, result) {
|
db.collection('objects').remove({_key:key, value:value}, function(err, result) {
|
||||||
if(callback) {
|
if(callback) {
|
||||||
callback(err, result);
|
callback(err, result);
|
||||||
}
|
}
|
||||||
@@ -521,7 +514,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
function getSortedSetRange(key, start, stop, sort, callback) {
|
function getSortedSetRange(key, start, stop, sort, callback) {
|
||||||
db.collection('objects').find({setName:key}, {fields:{value:1}})
|
db.collection('objects').find({_key:key}, {fields:{value:1}})
|
||||||
.limit(stop - start + 1)
|
.limit(stop - start + 1)
|
||||||
.skip(start)
|
.skip(start)
|
||||||
.sort({score: sort})
|
.sort({score: sort})
|
||||||
@@ -557,7 +550,7 @@
|
|||||||
stop = args[5];
|
stop = args[5];
|
||||||
|
|
||||||
|
|
||||||
db.collection('objects').find({setName:key, score: {$gt:min, $lt:max}}, {fields:{value:1}})
|
db.collection('objects').find({_key:key, score: {$gte:min, $lte:max}}, {fields:{value:1}})
|
||||||
.limit(stop - start + 1)
|
.limit(stop - start + 1)
|
||||||
.skip(start)
|
.skip(start)
|
||||||
.sort({score: -1})
|
.sort({score: -1})
|
||||||
@@ -576,7 +569,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
module.sortedSetCount = function(key, min, max, callback) {
|
module.sortedSetCount = function(key, min, max, callback) {
|
||||||
db.collection('objects').count({setName:key, score: {$gt:min, $lt:max}}, function(err, count) {
|
db.collection('objects').count({_key:key, score: {$gte:min, $lte:max}}, function(err, count) {
|
||||||
if(err) {
|
if(err) {
|
||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
@@ -609,7 +602,7 @@
|
|||||||
if(value !== null && value !== undefined) {
|
if(value !== null && value !== undefined) {
|
||||||
value = value.toString();
|
value = value.toString();
|
||||||
}
|
}
|
||||||
db.collection('objects').findOne({setName:key, value: value}, {fields:{score:1}}, function(err, result) {
|
db.collection('objects').findOne({_key:key, value: value}, {fields:{score:1}}, function(err, result) {
|
||||||
if(err) {
|
if(err) {
|
||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
@@ -625,22 +618,17 @@
|
|||||||
if(value !== null && value !== undefined) {
|
if(value !== null && value !== undefined) {
|
||||||
value = value.toString();
|
value = value.toString();
|
||||||
}
|
}
|
||||||
db.collection('objects').find({setName:{$in:keys}, value: value}).toArray(function(err, result) {
|
db.collection('objects').find({_key:{$in:keys}, value: value}).toArray(function(err, result) {
|
||||||
if(err) {
|
if(err) {
|
||||||
return callback(err);
|
return callback(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
var returnData = [],
|
var returnData = [],
|
||||||
resultIndex = 0;
|
item;
|
||||||
|
|
||||||
for(var i=0; i<keys.length; ++i) {
|
for(var i=0; i<keys.length; ++i) {
|
||||||
|
item = findItem(result, keys[i]);
|
||||||
if(result && resultIndex < result.length && keys[i] === result[resultIndex].setName) {
|
returnData.push(item ? item.score : null);
|
||||||
returnData.push(result[resultIndex].score);
|
|
||||||
++resultIndex;
|
|
||||||
} else {
|
|
||||||
returnData.push(null);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
callback(null, returnData);
|
callback(null, returnData);
|
||||||
|
|||||||
@@ -78,6 +78,7 @@ var DebugRoute = function(app) {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user