UNPKG

aerospike

Version:
135 lines (120 loc) 4.36 kB
// ***************************************************************************** // Copyright 2013-2024 Aerospike, Inc. // // Licensed under the Apache License, Version 2.0 (the "License") // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // ***************************************************************************** 'use strict' const BasePolicy = require('./base_policy') /** * A policy affecting the behavior of operate operations. * * @extends BasePolicy * @since v3.0.0 */ class OperatePolicy extends BasePolicy { /** * Initializes a new OperatePolicy from the provided policy values. * * @param {Object} [props] - Policy values */ constructor (props) { props = props || {} super(props) /** * Specifies the behavior for the key. * * @type number * @see {@link module:aerospike/policy.key} for supported policy values. */ this.key = props.key /** * Specifies the behavior for the generation value. * * @type number * @see {@link module:aerospike/policy.gen} for supported policy values. */ this.gen = props.gen /** * Specifies the behavior for the existence of the record. * * @type number * @see {@link module:aerospike/policy.exists} for supported policy values. */ this.exists = props.exists /** * Specifies the replica to be consulted for the read operation. * * @type number * @see {@link module:aerospike/policy.replica} for supported policy values. */ this.replica = props.replica /** * Specifies the number of replicas required to be committed successfully * when writing before returning transaction succeeded. * * @type number * @see {@link module:aerospike/policy.commitLevel} for supported policy values. */ this.commitLevel = props.commitLevel /** * Should CDT data types (Lists / Maps) be deserialized to JS data types * (Arrays / Objects) or returned as raw bytes (Buffer). * * @type boolean * @default <code>true</code> * @since v3.7.0 */ this.deserialize = props.deserialize /** * Specifies whether a {@link * http://www.aerospike.com/docs/guide/durable_deletes.html|tombstone} * should be written in place of a record that gets deleted as a result of * this operation. * * @type boolean * @default <code>false</code> (do not tombstone deleted records) */ this.durableDelete = props.durableDelete /** * Read policy for AP (availability) namespaces. * * @type number * @default Aerospike.policy.readModeAP.ONE * @see {@link module:aerospike/policy.readModeAP} for supported policy values. */ this.readModeAP = props.readModeAP /** * Read policy for SC (strong consistency) namespaces. * * @type number * @default Aerospike.policy.readModeSC.SESSION * @see {@link module:aerospike/policy.readModeSC} for supported policy values. */ this.readModeSC = props.readModeSC /** * Determine how record TTL (time to live) is affected on reads. When enabled, the server can * efficiently operate as a read-based LRU cache where the least recently used records are expired. * The value is expressed as a percentage of the TTL sent on the most recent write such that a read * within this interval of the record’s end of life will generate a touch. * * For example, if the most recent write had a TTL of 10 hours and read_touch_ttl_percent is set to * 80, the next read within 8 hours of the record's end of life (equivalent to 2 hours after the most * recent write) will result in a touch, resetting the TTL to another 10 hours. * * * @type number * @default 0 */ this.readTouchTtlPercent = props.readTouchTtlPercent } } module.exports = OperatePolicy