More than a year has passed, but it may be useful for others, so here is my answer:
I tried to perform the same task in order to resolve the grace period after deleting the record so that the user could subsequently cancel the operation.
, TTL .
, expireAfterSeconds :
db.yourCollection.createIndex({ "expireAt": 1 }, { expireAfterSeconds: 0 });
- , expireAfterSeconds :
db.log_events.insert( {
"expireAt": new Date('July 22, 2013 14:00:00'),
"logEvent": 2,
"logMessage": "Success!"
} )
Model
var BeerSchema = new Schema({
name: {
type: String,
unique: true,
required: true
},
description: String,
alcohol: Number,
price: Number,
createdAt: { type: Date, default: Date.now }
expireAt: { type: Date, default: undefined }
});
BeerSchema.index({ "expireAt": 1 }, { expireAfterSeconds: 0 });
moment
exports.deleteBeer = function(id) {
var deferred = q.defer();
Beer.update(id, { expireAt: moment().add(10, 'seconds') }, function(err, data) {
if(err) {
deferred.reject(err);
} else {
deferred.resolve(data);
}
});
return deferred.promise;
};
moment
exports.undeleteBeer = function(id) {
var deferred = q.defer();
Beer.update(id, { $unset: { expireAt: 1 }}, function(err, data) {
if(err) {
deferred.reject(err);
} else {
deferred.resolve(data);
}
});
return deferred.promise;
};