loopback-datasource-juggler/lib/kvao/ttl.js

40 lines
1.2 KiB
JavaScript
Raw Normal View History

// Copyright IBM Corp. 2016,2019. All Rights Reserved.
2019-05-08 15:45:37 +00:00
// Node module: loopback-datasource-juggler
// This file is licensed under the MIT License.
// License text available at https://opensource.org/licenses/MIT
2016-08-10 06:21:51 +00:00
'use strict';
2018-12-07 14:54:29 +00:00
const assert = require('assert');
const utils = require('../utils');
2016-08-10 06:21:51 +00:00
/**
2016-09-17 00:03:33 +00:00
* Return the TTL (time to live) for a given key. TTL is the remaining time
* before a key-value pair is discarded from the database.
2016-08-10 06:21:51 +00:00
*
2016-09-17 00:03:33 +00:00
* @param {String} key Key to use when searching the database.
* @options {Object} options
* @callback {Function} callback
2016-08-10 06:21:51 +00:00
* @param {Error} error
2016-09-17 00:03:33 +00:00
* @param {Number} ttl Expiration time for the key-value pair. `undefined` if
* TTL was not initially set.
* @promise
2016-08-10 06:21:51 +00:00
*
* @header KVAO.ttl(key, cb)
*/
module.exports = function keyValueTtl(key, options, callback) {
if (callback == undefined && typeof options === 'function') {
callback = options;
options = {};
} else if (!options) {
options = {};
}
assert(typeof key === 'string' && key, 'key must be a non-empty string');
assert(typeof options === 'object', 'options must be an object');
callback = callback || utils.createPromiseCallback();
this.getConnector().ttl(this.modelName, key, options, callback);
return callback.promise;
};