You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
4.0 KiB
JavaScript
136 lines
4.0 KiB
JavaScript
2 years ago
|
/*
|
||
|
* Copyright DataStax, 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 util = require('util');
|
||
|
const utils = require('../utils');
|
||
|
const inspectMethod = util.inspect.custom || 'inspect';
|
||
|
|
||
|
/**
|
||
|
* Represents the result of an execution as an iterable of objects in the Mapper.
|
||
|
* @alias module:mapping~Result
|
||
|
*/
|
||
|
class Result {
|
||
|
/**
|
||
|
* Creates a new instance of Result.
|
||
|
* @param {ResultSet} rs
|
||
|
* @param {ModelMappingInfo} info
|
||
|
* @param {Function} rowAdapter
|
||
|
*/
|
||
|
constructor(rs, info, rowAdapter) {
|
||
|
this._rs = rs;
|
||
|
this._info = info;
|
||
|
this._rowAdapter = rowAdapter;
|
||
|
|
||
|
/**
|
||
|
* When there is a single cell containing the result of the a LWT operation, hide the result from the user.
|
||
|
* @private
|
||
|
*/
|
||
|
this._isEmptyLwt = (rs.columns !== null
|
||
|
&& rs.columns.length === 1 && this._rs.rowLength === 1 && rs.columns[0].name === '[applied]');
|
||
|
|
||
|
/**
|
||
|
* Gets the amount of the documents contained in this Result instance.
|
||
|
* <p>
|
||
|
* When the results are paged, it returns the length of the current paged results not the total amount of
|
||
|
* rows in the table matching the query.
|
||
|
* </p>
|
||
|
* @type {Number}
|
||
|
*/
|
||
|
this.length = this._isEmptyLwt ? 0 : (rs.rowLength || 0);
|
||
|
|
||
|
/**
|
||
|
* A string token representing the current page state of query.
|
||
|
* <p>
|
||
|
* When provided, it can be used in the following executions to continue paging and retrieve the remained of the
|
||
|
* result for the query.
|
||
|
* </p>
|
||
|
* @type {String}
|
||
|
* @default null
|
||
|
*/
|
||
|
this.pageState = rs.pageState;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* When this instance is the result of a conditional update query, it returns whether it was successful.
|
||
|
* Otherwise, it returns <code>true</code>.
|
||
|
* <p>
|
||
|
* For consistency, this method always returns <code>true</code> for non-conditional queries (although there is
|
||
|
* no reason to call the method in that case). This is also the case for conditional DDL statements
|
||
|
* (CREATE KEYSPACE... IF NOT EXISTS, CREATE TABLE... IF NOT EXISTS), for which the server doesn't return
|
||
|
* information whether it was applied or not.
|
||
|
* </p>
|
||
|
*/
|
||
|
wasApplied() {
|
||
|
return this._rs.wasApplied();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets the first document in this result or null when the result is empty.
|
||
|
*/
|
||
|
first() {
|
||
|
if (!this._rs.rowLength || this._isEmptyLwt) {
|
||
|
return null;
|
||
|
}
|
||
|
return this._rowAdapter(this._rs.rows[0], this._info);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a new Iterator object that contains the document values.
|
||
|
*/
|
||
|
*[Symbol.iterator]() {
|
||
|
if (this._isEmptyLwt) {
|
||
|
// Empty iterator
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
for (let i = 0; i < this._rs.rows.length; i++) {
|
||
|
yield this._rowAdapter(this._rs.rows[i], this._info);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Converts the current instance to an Array of documents.
|
||
|
* @return {Array<Object>}
|
||
|
*/
|
||
|
toArray() {
|
||
|
if (this._isEmptyLwt || !this._rs.rows) {
|
||
|
return utils.emptyArray;
|
||
|
}
|
||
|
|
||
|
return this._rs.rows.map(row => this._rowAdapter(row, this._info));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Executes a provided function once per result element.
|
||
|
* @param {Function} callback Function to execute for each element, taking two arguments: currentValue and index.
|
||
|
* @param {Object} [thisArg] Value to use as <code>this</code> when executing callback.
|
||
|
*/
|
||
|
forEach(callback, thisArg) {
|
||
|
let index = 0;
|
||
|
thisArg = thisArg || this;
|
||
|
for (const doc of this) {
|
||
|
callback.call(thisArg, doc, index++);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[inspectMethod]() {
|
||
|
return this.toArray();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
module.exports = Result;
|