mirror of
https://kevinblog.sytes.net/Code/Jibo-Revival-Group/RoboCommander.git
synced 2026-06-16 19:16:12 +00:00
Initial commit
This commit is contained in:
201
node_modules/neo4j-driver/lib/v1/internal/stream-observer.js
generated
vendored
Normal file
201
node_modules/neo4j-driver/lib/v1/internal/stream-observer.js
generated
vendored
Normal file
@@ -0,0 +1,201 @@
|
||||
'use strict';
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
|
||||
var _assign = require('babel-runtime/core-js/object/assign');
|
||||
|
||||
var _assign2 = _interopRequireDefault(_assign);
|
||||
|
||||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
|
||||
|
||||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
||||
|
||||
var _createClass2 = require('babel-runtime/helpers/createClass');
|
||||
|
||||
var _createClass3 = _interopRequireDefault(_createClass2);
|
||||
|
||||
var _record = require('../record');
|
||||
|
||||
var _record2 = _interopRequireDefault(_record);
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
|
||||
/**
|
||||
* Handles a RUN/PULL_ALL, or RUN/DISCARD_ALL requests, maps the responses
|
||||
* in a way that a user-provided observer can see these as a clean Stream
|
||||
* of records.
|
||||
* This class will queue up incoming messages until a user-provided observer
|
||||
* for the incoming stream is registered. Thus, we keep fields around
|
||||
* for tracking head/records/tail. These are only used if there is no
|
||||
* observer registered.
|
||||
* @access private
|
||||
*/
|
||||
var StreamObserver = function () {
|
||||
/**
|
||||
* @constructor
|
||||
* @param errorTransformer optional callback to be used for adding additional logic on error
|
||||
*/
|
||||
function StreamObserver() {
|
||||
var errorTransformer = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : function (err) {
|
||||
return err;
|
||||
};
|
||||
(0, _classCallCheck3.default)(this, StreamObserver);
|
||||
|
||||
this._fieldKeys = null;
|
||||
this._fieldLookup = null;
|
||||
this._queuedRecords = [];
|
||||
this._tail = null;
|
||||
this._error = null;
|
||||
this._hasFailed = false;
|
||||
this._errorTransformer = errorTransformer;
|
||||
this._observer = null;
|
||||
this._conn = null;
|
||||
this._meta = {};
|
||||
}
|
||||
|
||||
/**
|
||||
* Will be called on every record that comes in and transform a raw record
|
||||
* to a Object. If user-provided observer is present, pass transformed record
|
||||
* to it's onNext method, otherwise, push to record que.
|
||||
* @param {Array} rawRecord - An array with the raw record
|
||||
*/
|
||||
|
||||
|
||||
(0, _createClass3.default)(StreamObserver, [{
|
||||
key: 'onNext',
|
||||
value: function onNext(rawRecord) {
|
||||
var record = new _record2.default(this._fieldKeys, rawRecord, this._fieldLookup);
|
||||
if (this._observer) {
|
||||
this._observer.onNext(record);
|
||||
} else {
|
||||
this._queuedRecords.push(record);
|
||||
}
|
||||
}
|
||||
}, {
|
||||
key: 'onCompleted',
|
||||
value: function onCompleted(meta) {
|
||||
if (this._fieldKeys === null) {
|
||||
// Stream header, build a name->index field lookup table
|
||||
// to be used by records. This is an optimization to make it
|
||||
// faster to look up fields in a record by name, rather than by index.
|
||||
// Since the records we get back via Bolt are just arrays of values.
|
||||
this._fieldKeys = [];
|
||||
this._fieldLookup = {};
|
||||
if (meta.fields && meta.fields.length > 0) {
|
||||
this._fieldKeys = meta.fields;
|
||||
for (var i = 0; i < meta.fields.length; i++) {
|
||||
this._fieldLookup[meta.fields[i]] = i;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// End of stream
|
||||
if (this._observer) {
|
||||
this._observer.onCompleted(meta);
|
||||
} else {
|
||||
this._tail = meta;
|
||||
}
|
||||
}
|
||||
this._copyMetadataOnCompletion(meta);
|
||||
}
|
||||
}, {
|
||||
key: '_copyMetadataOnCompletion',
|
||||
value: function _copyMetadataOnCompletion(meta) {
|
||||
for (var key in meta) {
|
||||
if (meta.hasOwnProperty(key)) {
|
||||
this._meta[key] = meta[key];
|
||||
}
|
||||
}
|
||||
}
|
||||
}, {
|
||||
key: 'serverMetadata',
|
||||
value: function serverMetadata() {
|
||||
var serverMeta = { server: this._conn.server };
|
||||
return (0, _assign2.default)({}, this._meta, serverMeta);
|
||||
}
|
||||
}, {
|
||||
key: 'resolveConnection',
|
||||
value: function resolveConnection(conn) {
|
||||
this._conn = conn;
|
||||
}
|
||||
|
||||
/**
|
||||
* Will be called on errors.
|
||||
* If user-provided observer is present, pass the error
|
||||
* to it's onError method, otherwise set instance variable _error.
|
||||
* @param {Object} error - An error object
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'onError',
|
||||
value: function onError(error) {
|
||||
var transformedError = this._errorTransformer(error, this._conn);
|
||||
if (this._hasFailed) {
|
||||
return;
|
||||
}
|
||||
this._hasFailed = true;
|
||||
if (this._observer) {
|
||||
if (this._observer.onError) {
|
||||
this._observer.onError(transformedError);
|
||||
} else {
|
||||
console.log(transformedError);
|
||||
}
|
||||
} else {
|
||||
this._error = transformedError;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Subscribe to events with provided observer.
|
||||
* @param {Object} observer - Observer object
|
||||
* @param {function(record: Object)} observer.onNext - Handle records, one by one.
|
||||
* @param {function(metadata: Object)} observer.onComplete - Handle stream tail, the metadata.
|
||||
* @param {function(error: Object)} observer.onError - Handle errors.
|
||||
*/
|
||||
|
||||
}, {
|
||||
key: 'subscribe',
|
||||
value: function subscribe(observer) {
|
||||
if (this._error) {
|
||||
observer.onError(this._error);
|
||||
return;
|
||||
}
|
||||
if (this._queuedRecords.length > 0) {
|
||||
for (var i = 0; i < this._queuedRecords.length; i++) {
|
||||
observer.onNext(this._queuedRecords[i]);
|
||||
}
|
||||
}
|
||||
if (this._tail) {
|
||||
observer.onCompleted(this._tail);
|
||||
}
|
||||
this._observer = observer;
|
||||
}
|
||||
}, {
|
||||
key: 'hasFailed',
|
||||
value: function hasFailed() {
|
||||
return this._hasFailed;
|
||||
}
|
||||
}]);
|
||||
return StreamObserver;
|
||||
}(); /**
|
||||
* Copyright (c) 2002-2018 "Neo4j,"
|
||||
* Neo4j Sweden AB [http://neo4j.com]
|
||||
*
|
||||
* This file is part of Neo4j.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
|
||||
exports.default = StreamObserver;
|
||||
Reference in New Issue
Block a user