Comparing version
@@ -40,4 +40,13 @@ 'use strict'; | ||
var cursor = _ref.cursor; | ||
var nodeOrNull = void 0; | ||
try { | ||
nodeOrNull = new _Node2.default(conn, type, node); | ||
} catch (err) { | ||
nodeOrNull = null; | ||
} | ||
return { | ||
node: new _Node2.default(conn, type, node), | ||
node: nodeOrNull, | ||
cursor: cursor | ||
@@ -106,2 +115,2 @@ }; | ||
exports.default = Connection; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9Db25uZWN0aW9uLmpzIl0sIm5hbWVzIjpbIkNvbm5lY3Rpb24iLCJjb25uIiwidHlwZSIsImRhdGEiLCJUeXBlRXJyb3IiLCJwYWdlSW5mbyIsInRvdGFsQ291bnQiLCJlZGdlcyIsIm1hcCIsIm5vZGUiLCJjdXJzb3IiLCJmbiIsImV2ZXJ5Iiwic29tZSIsImluaXRpYWxWYWx1ZSIsInJlZHVjZSIsImZvckVhY2giXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7Ozs7Ozs7O0lBRXFCQSxVO0FBQ25CLHNCQUFZQyxJQUFaLEVBQWtCQyxJQUFsQixFQUF3QkMsSUFBeEIsRUFBOEI7QUFBQTs7QUFDNUIsUUFBSSxDQUFDRixJQUFMLEVBQVc7QUFDVCxZQUFNLElBQUlHLFNBQUosQ0FBYywwREFBZCxDQUFOO0FBQ0Q7O0FBRUQsUUFBSSxDQUFDRixJQUFMLEVBQVc7QUFDVCxZQUFNLElBQUlFLFNBQUosQ0FBYywwREFBZCxDQUFOO0FBQ0Q7O0FBRUQsUUFBSSxDQUFDRCxJQUFMLEVBQVc7QUFDVCxZQUFNLElBQUlDLFNBQUosQ0FBYywwREFBZCxDQUFOO0FBQ0Q7O0FBRUQsU0FBS0YsSUFBTCxHQUFZQSxJQUFaO0FBQ0EsU0FBS0csUUFBTCxHQUFnQkYsS0FBS0UsUUFBckI7QUFDQSxTQUFLQyxVQUFMLEdBQWtCSCxLQUFLRyxVQUF2Qjs7QUFFQSxTQUFLQyxLQUFMLEdBQWFKLEtBQUtJLEtBQUwsQ0FBV0MsR0FBWCxDQUFlO0FBQUEsVUFBR0MsSUFBSCxRQUFHQSxJQUFIO0FBQUEsVUFBU0MsTUFBVCxRQUFTQSxNQUFUO0FBQUEsYUFBdUI7QUFDakRELGNBQU0sbUJBQVNSLElBQVQsRUFBZUMsSUFBZixFQUFxQk8sSUFBckIsQ0FEMkM7QUFFakRDO0FBRmlELE9BQXZCO0FBQUEsS0FBZixDQUFiO0FBSUQ7Ozs7NEJBRU87QUFDTixhQUFPLEtBQUtILEtBQUwsSUFBYyxLQUFLQSxLQUFMLENBQVcsQ0FBWCxDQUFkLElBQStCLEtBQUtBLEtBQUwsQ0FBVyxDQUFYLEVBQWNFLElBQTdDLElBQXFELElBQTVEO0FBQ0Q7Ozt3QkFFR0UsRSxFQUFJO0FBQ04sYUFBTyxLQUFLSixLQUFMLENBQVdDLEdBQVgsQ0FBZTtBQUFBLFlBQUdDLElBQUgsU0FBR0EsSUFBSDtBQUFBLFlBQVNDLE1BQVQsU0FBU0EsTUFBVDtBQUFBLGVBQXNCQyxHQUFHRixJQUFILEVBQVNDLE1BQVQsQ0FBdEI7QUFBQSxPQUFmLENBQVA7QUFDRDs7OzBCQUVLQyxFLEVBQUk7QUFDUixhQUFPLEtBQUtKLEtBQUwsQ0FBV0ssS0FBWCxDQUFpQjtBQUFBLFlBQUdILElBQUgsU0FBR0EsSUFBSDtBQUFBLFlBQVNDLE1BQVQsU0FBU0EsTUFBVDtBQUFBLGVBQXNCQyxHQUFHRixJQUFILEVBQVNDLE1BQVQsQ0FBdEI7QUFBQSxPQUFqQixDQUFQO0FBQ0Q7Ozt5QkFFSUMsRSxFQUFJO0FBQ1AsYUFBTyxLQUFLSixLQUFMLENBQVdNLElBQVgsQ0FBZ0I7QUFBQSxZQUFHSixJQUFILFNBQUdBLElBQUg7QUFBQSxZQUFTQyxNQUFULFNBQVNBLE1BQVQ7QUFBQSxlQUFzQkMsR0FBR0YsSUFBSCxFQUFTQyxNQUFULENBQXRCO0FBQUEsT0FBaEIsQ0FBUDtBQUNEOzs7MkJBRU1DLEUsRUFBdUI7QUFBQSxVQUFuQkcsWUFBbUIsdUVBQUosRUFBSTs7QUFDNUIsYUFBTyxLQUFLUCxLQUFMLENBQVdRLE1BQVgsQ0FBa0I7QUFBQSxZQUFHTixJQUFILFNBQUdBLElBQUg7QUFBQSxZQUFTQyxNQUFULFNBQVNBLE1BQVQ7QUFBQSxlQUFzQkMsR0FBR0YsSUFBSCxFQUFTQyxNQUFULENBQXRCO0FBQUEsT0FBbEIsRUFBMERJLFlBQTFELENBQVA7QUFDRDs7OzRCQUVPSCxFLEVBQUk7QUFDVixXQUFLSixLQUFMLENBQVdTLE9BQVgsQ0FBbUI7QUFBQSxZQUFHUCxJQUFILFNBQUdBLElBQUg7QUFBQSxZQUFTQyxNQUFULFNBQVNBLE1BQVQ7QUFBQSxlQUFzQkMsR0FBR0YsSUFBSCxFQUFTQyxNQUFULENBQXRCO0FBQUEsT0FBbkI7QUFDRDs7Ozs7O2tCQTlDa0JWLFUiLCJmaWxlIjoiQ29ubmVjdGlvbi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBOb2RlIGZyb20gJy4vTm9kZSc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbm5lY3Rpb24ge1xuICBjb25zdHJ1Y3Rvcihjb25uLCB0eXBlLCBkYXRhKSB7XG4gICAgaWYgKCFjb25uKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdBcmd1bWVudCBcImNvbm5cIiBpcyByZXF1aXJlZCB0byBpbnN0YW50aWF0ZSBhIENvbm5lY3Rpb24uJyk7XG4gICAgfVxuXG4gICAgaWYgKCF0eXBlKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdBcmd1bWVudCBcInR5cGVcIiBpcyByZXF1aXJlZCB0byBpbnN0YW50aWF0ZSBhIENvbm5lY3Rpb24uJyk7XG4gICAgfVxuXG4gICAgaWYgKCFkYXRhKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdBcmd1bWVudCBcImRhdGFcIiBpcyByZXF1aXJlZCB0byBpbnN0YW50aWF0ZSBhIENvbm5lY3Rpb24uJyk7XG4gICAgfVxuXG4gICAgdGhpcy50eXBlID0gdHlwZTtcbiAgICB0aGlzLnBhZ2VJbmZvID0gZGF0YS5wYWdlSW5mbztcbiAgICB0aGlzLnRvdGFsQ291bnQgPSBkYXRhLnRvdGFsQ291bnQ7XG5cbiAgICB0aGlzLmVkZ2VzID0gZGF0YS5lZGdlcy5tYXAoKHsgbm9kZSwgY3Vyc29yIH0pID0+ICh7XG4gICAgICBub2RlOiBuZXcgTm9kZShjb25uLCB0eXBlLCBub2RlKSxcbiAgICAgIGN1cnNvcixcbiAgICB9KSk7XG4gIH1cblxuICBmaXJzdCgpIHtcbiAgICByZXR1cm4gdGhpcy5lZGdlcyAmJiB0aGlzLmVkZ2VzWzBdICYmIHRoaXMuZWRnZXNbMF0ubm9kZSB8fCBudWxsO1xuICB9XG5cbiAgbWFwKGZuKSB7XG4gICAgcmV0dXJuIHRoaXMuZWRnZXMubWFwKCh7IG5vZGUsIGN1cnNvciB9KSA9PiBmbihub2RlLCBjdXJzb3IpKTtcbiAgfVxuXG4gIGV2ZXJ5KGZuKSB7XG4gICAgcmV0dXJuIHRoaXMuZWRnZXMuZXZlcnkoKHsgbm9kZSwgY3Vyc29yIH0pID0+IGZuKG5vZGUsIGN1cnNvcikpO1xuICB9XG5cbiAgc29tZShmbikge1xuICAgIHJldHVybiB0aGlzLmVkZ2VzLnNvbWUoKHsgbm9kZSwgY3Vyc29yIH0pID0+IGZuKG5vZGUsIGN1cnNvcikpO1xuICB9XG5cbiAgcmVkdWNlKGZuLCBpbml0aWFsVmFsdWUgPSBbXSkge1xuICAgIHJldHVybiB0aGlzLmVkZ2VzLnJlZHVjZSgoeyBub2RlLCBjdXJzb3IgfSkgPT4gZm4obm9kZSwgY3Vyc29yKSwgaW5pdGlhbFZhbHVlKTtcbiAgfVxuXG4gIGZvckVhY2goZm4pIHtcbiAgICB0aGlzLmVkZ2VzLmZvckVhY2goKHsgbm9kZSwgY3Vyc29yIH0pID0+IGZuKG5vZGUsIGN1cnNvcikpO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9Db25uZWN0aW9uLmpzIl0sIm5hbWVzIjpbIkNvbm5lY3Rpb24iLCJjb25uIiwidHlwZSIsImRhdGEiLCJUeXBlRXJyb3IiLCJwYWdlSW5mbyIsInRvdGFsQ291bnQiLCJlZGdlcyIsIm1hcCIsIm5vZGUiLCJjdXJzb3IiLCJub2RlT3JOdWxsIiwiZXJyIiwiZm4iLCJldmVyeSIsInNvbWUiLCJpbml0aWFsVmFsdWUiLCJyZWR1Y2UiLCJmb3JFYWNoIl0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBOzs7Ozs7OztJQUVxQkEsVTtBQUNuQixzQkFBWUMsSUFBWixFQUFrQkMsSUFBbEIsRUFBd0JDLElBQXhCLEVBQThCO0FBQUE7O0FBQzVCLFFBQUksQ0FBQ0YsSUFBTCxFQUFXO0FBQ1QsWUFBTSxJQUFJRyxTQUFKLENBQWMsMERBQWQsQ0FBTjtBQUNEOztBQUVELFFBQUksQ0FBQ0YsSUFBTCxFQUFXO0FBQ1QsWUFBTSxJQUFJRSxTQUFKLENBQWMsMERBQWQsQ0FBTjtBQUNEOztBQUVELFFBQUksQ0FBQ0QsSUFBTCxFQUFXO0FBQ1QsWUFBTSxJQUFJQyxTQUFKLENBQWMsMERBQWQsQ0FBTjtBQUNEOztBQUVELFNBQUtGLElBQUwsR0FBWUEsSUFBWjtBQUNBLFNBQUtHLFFBQUwsR0FBZ0JGLEtBQUtFLFFBQXJCO0FBQ0EsU0FBS0MsVUFBTCxHQUFrQkgsS0FBS0csVUFBdkI7O0FBRUEsU0FBS0MsS0FBTCxHQUFhSixLQUFLSSxLQUFMLENBQVdDLEdBQVgsQ0FBZSxnQkFBc0I7QUFBQSxVQUFuQkMsSUFBbUIsUUFBbkJBLElBQW1CO0FBQUEsVUFBYkMsTUFBYSxRQUFiQSxNQUFhOztBQUNoRCxVQUFJQyxtQkFBSjs7QUFFQSxVQUFJO0FBQ0ZBLHFCQUFhLG1CQUFTVixJQUFULEVBQWVDLElBQWYsRUFBcUJPLElBQXJCLENBQWI7QUFDRCxPQUZELENBRUUsT0FBT0csR0FBUCxFQUFZO0FBQ1pELHFCQUFhLElBQWI7QUFDRDs7QUFFRCxhQUFPO0FBQ0xGLGNBQU1FLFVBREQ7QUFFTEQ7QUFGSyxPQUFQO0FBSUQsS0FiWSxDQUFiO0FBY0Q7Ozs7NEJBRU87QUFDTixhQUFPLEtBQUtILEtBQUwsSUFBYyxLQUFLQSxLQUFMLENBQVcsQ0FBWCxDQUFkLElBQStCLEtBQUtBLEtBQUwsQ0FBVyxDQUFYLEVBQWNFLElBQTdDLElBQXFELElBQTVEO0FBQ0Q7Ozt3QkFFR0ksRSxFQUFJO0FBQ04sYUFBTyxLQUFLTixLQUFMLENBQVdDLEdBQVgsQ0FBZTtBQUFBLFlBQUdDLElBQUgsU0FBR0EsSUFBSDtBQUFBLFlBQVNDLE1BQVQsU0FBU0EsTUFBVDtBQUFBLGVBQXNCRyxHQUFHSixJQUFILEVBQVNDLE1BQVQsQ0FBdEI7QUFBQSxPQUFmLENBQVA7QUFDRDs7OzBCQUVLRyxFLEVBQUk7QUFDUixhQUFPLEtBQUtOLEtBQUwsQ0FBV08sS0FBWCxDQUFpQjtBQUFBLFlBQUdMLElBQUgsU0FBR0EsSUFBSDtBQUFBLFlBQVNDLE1BQVQsU0FBU0EsTUFBVDtBQUFBLGVBQXNCRyxHQUFHSixJQUFILEVBQVNDLE1BQVQsQ0FBdEI7QUFBQSxPQUFqQixDQUFQO0FBQ0Q7Ozt5QkFFSUcsRSxFQUFJO0FBQ1AsYUFBTyxLQUFLTixLQUFMLENBQVdRLElBQVgsQ0FBZ0I7QUFBQSxZQUFHTixJQUFILFNBQUdBLElBQUg7QUFBQSxZQUFTQyxNQUFULFNBQVNBLE1BQVQ7QUFBQSxlQUFzQkcsR0FBR0osSUFBSCxFQUFTQyxNQUFULENBQXRCO0FBQUEsT0FBaEIsQ0FBUDtBQUNEOzs7MkJBRU1HLEUsRUFBdUI7QUFBQSxVQUFuQkcsWUFBbUIsdUVBQUosRUFBSTs7QUFDNUIsYUFBTyxLQUFLVCxLQUFMLENBQVdVLE1BQVgsQ0FBa0I7QUFBQSxZQUFHUixJQUFILFNBQUdBLElBQUg7QUFBQSxZQUFTQyxNQUFULFNBQVNBLE1BQVQ7QUFBQSxlQUFzQkcsR0FBR0osSUFBSCxFQUFTQyxNQUFULENBQXRCO0FBQUEsT0FBbEIsRUFBMERNLFlBQTFELENBQVA7QUFDRDs7OzRCQUVPSCxFLEVBQUk7QUFDVixXQUFLTixLQUFMLENBQVdXLE9BQVgsQ0FBbUI7QUFBQSxZQUFHVCxJQUFILFNBQUdBLElBQUg7QUFBQSxZQUFTQyxNQUFULFNBQVNBLE1BQVQ7QUFBQSxlQUFzQkcsR0FBR0osSUFBSCxFQUFTQyxNQUFULENBQXRCO0FBQUEsT0FBbkI7QUFDRDs7Ozs7O2tCQXhEa0JWLFUiLCJmaWxlIjoiQ29ubmVjdGlvbi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBOb2RlIGZyb20gJy4vTm9kZSc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbm5lY3Rpb24ge1xuICBjb25zdHJ1Y3Rvcihjb25uLCB0eXBlLCBkYXRhKSB7XG4gICAgaWYgKCFjb25uKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdBcmd1bWVudCBcImNvbm5cIiBpcyByZXF1aXJlZCB0byBpbnN0YW50aWF0ZSBhIENvbm5lY3Rpb24uJyk7XG4gICAgfVxuXG4gICAgaWYgKCF0eXBlKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdBcmd1bWVudCBcInR5cGVcIiBpcyByZXF1aXJlZCB0byBpbnN0YW50aWF0ZSBhIENvbm5lY3Rpb24uJyk7XG4gICAgfVxuXG4gICAgaWYgKCFkYXRhKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdBcmd1bWVudCBcImRhdGFcIiBpcyByZXF1aXJlZCB0byBpbnN0YW50aWF0ZSBhIENvbm5lY3Rpb24uJyk7XG4gICAgfVxuXG4gICAgdGhpcy50eXBlID0gdHlwZTtcbiAgICB0aGlzLnBhZ2VJbmZvID0gZGF0YS5wYWdlSW5mbztcbiAgICB0aGlzLnRvdGFsQ291bnQgPSBkYXRhLnRvdGFsQ291bnQ7XG5cbiAgICB0aGlzLmVkZ2VzID0gZGF0YS5lZGdlcy5tYXAoKHsgbm9kZSwgY3Vyc29yIH0pID0+IHtcbiAgICAgIGxldCBub2RlT3JOdWxsO1xuXG4gICAgICB0cnkge1xuICAgICAgICBub2RlT3JOdWxsID0gbmV3IE5vZGUoY29ubiwgdHlwZSwgbm9kZSk7XG4gICAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbm9kZU9yTnVsbCA9IG51bGw7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIG5vZGU6IG5vZGVPck51bGwsXG4gICAgICAgIGN1cnNvcixcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cblxuICBmaXJzdCgpIHtcbiAgICByZXR1cm4gdGhpcy5lZGdlcyAmJiB0aGlzLmVkZ2VzWzBdICYmIHRoaXMuZWRnZXNbMF0ubm9kZSB8fCBudWxsO1xuICB9XG5cbiAgbWFwKGZuKSB7XG4gICAgcmV0dXJuIHRoaXMuZWRnZXMubWFwKCh7IG5vZGUsIGN1cnNvciB9KSA9PiBmbihub2RlLCBjdXJzb3IpKTtcbiAgfVxuXG4gIGV2ZXJ5KGZuKSB7XG4gICAgcmV0dXJuIHRoaXMuZWRnZXMuZXZlcnkoKHsgbm9kZSwgY3Vyc29yIH0pID0+IGZuKG5vZGUsIGN1cnNvcikpO1xuICB9XG5cbiAgc29tZShmbikge1xuICAgIHJldHVybiB0aGlzLmVkZ2VzLnNvbWUoKHsgbm9kZSwgY3Vyc29yIH0pID0+IGZuKG5vZGUsIGN1cnNvcikpO1xuICB9XG5cbiAgcmVkdWNlKGZuLCBpbml0aWFsVmFsdWUgPSBbXSkge1xuICAgIHJldHVybiB0aGlzLmVkZ2VzLnJlZHVjZSgoeyBub2RlLCBjdXJzb3IgfSkgPT4gZm4obm9kZSwgY3Vyc29yKSwgaW5pdGlhbFZhbHVlKTtcbiAgfVxuXG4gIGZvckVhY2goZm4pIHtcbiAgICB0aGlzLmVkZ2VzLmZvckVhY2goKHsgbm9kZSwgY3Vyc29yIH0pID0+IGZuKG5vZGUsIGN1cnNvcikpO1xuICB9XG59XG4iXX0= |
@@ -235,2 +235,4 @@ 'use strict'; | ||
return new _Node2.default(conn, relatedSchema, data); | ||
}).catch(function () { | ||
return null; | ||
}); | ||
@@ -269,2 +271,4 @@ } | ||
return new _Node2.default(conn, type, data); | ||
}).catch(function () { | ||
return null; | ||
}); | ||
@@ -351,2 +355,2 @@ } | ||
exports.default = Model; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/Model.js"],"names":["Model","conn","type","TypeError","options","connection","table","name","run","then","data","find","first","index","value","getAll","findByIndex","id","relationship","parentName","relationships","relatedName","relatedSchema","relation","inverse","query","field","args","get","record","checkComplianceAndNormalizeRecord","compliant","Error","createRecord","normalizedRecord","createdNode","insert","keys","generated_keys","fetch","node","syncRelationshipsArray","do"],"mappings":"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","file":"Model.js","sourcesContent":["import r from 'rethinkdb';\nimport Connection from './Connection';\nimport Node from './Node';\nimport isCreateCompliant from './constraints/create';\n\nimport {\n  applyOptions,\n  createConnection,\n  mergeRelationships,\n  normalizeRecord,\n  requiresIndex,\n  syncRelationships,\n} from './utils';\n\nexport default class Model {\n  /**\n   * Instantiates a Model.\n   *\n   * @class Model\n   * @param {Object} conn\n   * @param {String} type\n   */\n  constructor(conn, type) {\n    if (!conn) {\n      throw new TypeError('Argument \"conn\" is required to instantiate a Model.');\n    }\n\n    if (!type) {\n      throw new TypeError('Argument \"type\" is required to instantiate a Model.');\n    }\n\n    this.conn = conn;\n    this.type = type;\n  }\n\n  /**\n   * Creates a connection whose edges match the criteria in `options`.\n   *\n   * ```\n   * model('user').find({\n   *   filter: { name: 'Dylan' },\n   *   without: { password: true },\n   *   include: {\n   *     pets: {\n   *       filter: (pet) => pet('age').gt(6),\n   *       pluck: {\n   *         favoriteTreat: true,\n   *         color: true,\n   *       },\n   *     },\n   *     company: true,\n   *   },\n   * }).then(users => {\n   *   // Connection\n   * });\n   * ```\n   *\n   * @async\n   * @method find\n   * @param {Object} [options={}]\n   * @return {Promise<Connection>}\n   *\n   * @todo Write more docs on `options`\n   */\n  find(options = {}) {\n    const { conn, type } = this;\n    const connection = createConnection(type, r.table(type.name), options);\n\n    return connection.run(conn).then(data => new Connection(conn, type, data));\n  }\n\n  /**\n   * Finds the first node that matches the criteria in `options.`\n   *\n   * @async\n   * @method findOne\n   * @param {Object} [options={}]\n   * @return {Promise<Node>}\n   */\n  findOne(options = {}) {\n    return this.find(options).then(connection => connection.first());\n  }\n\n  /**\n   * Creates a connection using the index named `index`.\n   *\n   * ```\n   * model('user').findByIndex('email', 'dylanslack@gmail.com').then(users => {\n   *   // Connection\n   * });\n   * ```\n   *\n   * @async\n   * @method findByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [options={}]\n   * @return {Promise<Connection>}\n   *\n   * @todo Add test.\n   */\n  findByIndex(index, value, options = {}) {\n    const { conn, type } = this;\n\n    const connection = createConnection(\n      type,\n      r.table(type.name).getAll(value, { index }),\n      options\n    );\n\n    return connection.run(conn).then(data => new Connection(conn, type, data));\n  }\n\n  /**\n   * Finds a single node from `index` that matches `value` and that matches the criteria in\n   * `options`.\n   *\n   * @async\n   * @method findOneByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [options={}] - Critera before merging relationships.\n   * @return {Promise<Node>}\n   */\n  findOneByIndex(index, value, options = {}) {\n    return this.findByIndex(index, value, options).then(connection => connection.first());\n  }\n\n  /**\n   * Retrieves the resource(s) related to a particular resource identified by `id` according to\n   * `relationship`. A relationship with a relation of `hasMany` returns a `Connection`, and a\n   * relationship with a relation of `hasOne` or `belongsTo` returns a `Node`.\n   *\n   * ```js\n   * // pretend user `1` has a ton of pets\n   * model('user').findRelated('1', 'pets', {\n   *   filter: { species: 'hamster' },\n   * }).then(pets => {\n   *   // Connection\n   * });\n   *\n   * // pretend user `1` has a company\n   * model('user').findRelated('1', 'company').then(company => {\n   *   // Node\n   * });\n   * ```\n   *\n   * @async\n   * @method findRelated\n   * @param {String} id - The id of the parent resource.\n   * @param {String} relationship - The relationship to the parent.\n   * @param {Object} [options={}]\n   * @returns {Promise<Connection|Node>}\n   */\n  findRelated(id, relationship, options = {}) {\n    const { conn, type, type: { name: parentName } } = this;\n\n    const {\n      name: relatedName,\n      type: relatedSchema,\n      relation,\n      inverse,\n    } = type.relationships[relationship];\n\n    let query = r.table(relatedName);\n\n    if (relation === 'hasMany') {\n      if (requiresIndex(relation, inverse.relation)) {\n        query = query.getAll(id, { index: inverse.field });\n      } else {\n        query = query.getAll(\n          r.args(r.table(parentName).get(id)(relationship)('id'))\n        );\n      }\n\n      return createConnection(relatedSchema, query, options).run(conn)\n        .then(data => new Connection(conn, relatedSchema, data));\n    }\n\n    query = query.get(r.table(parentName).get(id)(relationship)('id'));\n    query = mergeRelationships(query, relatedSchema, options);\n    query = applyOptions(query, options);\n\n    return query.run(conn)\n      .then(data => new Node(conn, relatedSchema, data));\n  }\n\n  /**\n   * Fetches the node with `id`.\n   *\n   * ```js\n   * model('user').fetch('1').then(user => {\n   *   // Node\n   * });\n   * ```\n   *\n   * @async\n   * @method fetch\n   * @param {String} id - The ID of the resource to retrieve.\n   * @param {Object} [options={}] - Critera before merging relationships.\n   * @returns {Promise<Node>}\n   */\n  fetch(id, options = {}) {\n    const { conn, type } = this;\n\n    let query = r.table(type.name).get(id);\n    query = mergeRelationships(query, type, options);\n    query = applyOptions(query, options);\n\n    return query.run(conn)\n      .then(data => new Node(conn, type, data));\n  }\n\n  /**\n   * Persists a record in the database and creates a resource. The 'record' object must be a\n   * flattenen JSON with attributes and relationships. All relationships in `record` must be\n   * represented by either a string for a `hasOne` or `belongsTo` relation, or an array of strings\n   * for a `hasMany` relation.\n   *\n   * ```js\n   * model('user').create({\n   *   name: 'Dylan',\n   *   email: 'dylanslack@gmail.com',\n   *   password: 'hashedpassword',\n   *   pets: [ '1', '2', '3' ],\n   *   company: '1',\n   * }).then(user => {\n   *   // Node\n   * });\n   * ```\n   *\n   * @async\n   * @method create\n   * @param {Object} record\n   * @param {Object} [options={}] - Critera before merging relationships.\n   * @returns {Promise<Node>}\n   */\n  create(record, options = {}) {\n    const { conn, type } = this;\n    const { name } = type;\n\n    const checkComplianceAndNormalizeRecord = (compliant) => {\n      if (!compliant) {\n        throw new Error(\n          'Tried to create a record, but \\'record\\' had some invalid relationships.'\n        );\n      }\n\n      return normalizeRecord(record, type);\n    };\n\n    const createRecord = (normalizedRecord) => {\n      let createdNode;\n\n      return r.table(name).insert(normalizedRecord).run(conn)\n\n        // retrieve the record that was just created\n        .then(({ generated_keys: keys }) => this.fetch(keys[0], options))\n\n        // create the node and sync its relationships\n        .then(node => {\n          createdNode = node;\n\n          const syncRelationshipsArray = syncRelationships(record, type, node.id);\n          return r.do(syncRelationshipsArray).run(conn);\n        })\n\n        // return the node\n        .then(() => createdNode);\n    };\n\n    // check record and its relationships for Redink constraints\n    return isCreateCompliant(record, type, conn)\n      .then(checkComplianceAndNormalizeRecord)\n      .then(createRecord);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/Model.js"],"names":["Model","conn","type","TypeError","options","connection","table","name","run","then","data","find","first","index","value","getAll","findByIndex","id","relationship","parentName","relationships","relatedName","relatedSchema","relation","inverse","query","field","args","get","catch","record","checkComplianceAndNormalizeRecord","compliant","Error","createRecord","normalizedRecord","createdNode","insert","keys","generated_keys","fetch","node","syncRelationshipsArray","do"],"mappings":"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","file":"Model.js","sourcesContent":["import r from 'rethinkdb';\nimport Connection from './Connection';\nimport Node from './Node';\nimport isCreateCompliant from './constraints/create';\n\nimport {\n  applyOptions,\n  createConnection,\n  mergeRelationships,\n  normalizeRecord,\n  requiresIndex,\n  syncRelationships,\n} from './utils';\n\nexport default class Model {\n  /**\n   * Instantiates a Model.\n   *\n   * @class Model\n   * @param {Object} conn\n   * @param {String} type\n   */\n  constructor(conn, type) {\n    if (!conn) {\n      throw new TypeError('Argument \"conn\" is required to instantiate a Model.');\n    }\n\n    if (!type) {\n      throw new TypeError('Argument \"type\" is required to instantiate a Model.');\n    }\n\n    this.conn = conn;\n    this.type = type;\n  }\n\n  /**\n   * Creates a connection whose edges match the criteria in `options`.\n   *\n   * ```\n   * model('user').find({\n   *   filter: { name: 'Dylan' },\n   *   without: { password: true },\n   *   include: {\n   *     pets: {\n   *       filter: (pet) => pet('age').gt(6),\n   *       pluck: {\n   *         favoriteTreat: true,\n   *         color: true,\n   *       },\n   *     },\n   *     company: true,\n   *   },\n   * }).then(users => {\n   *   // Connection\n   * });\n   * ```\n   *\n   * @async\n   * @method find\n   * @param {Object} [options={}]\n   * @return {Promise<Connection>}\n   *\n   * @todo Write more docs on `options`\n   */\n  find(options = {}) {\n    const { conn, type } = this;\n    const connection = createConnection(type, r.table(type.name), options);\n\n    return connection.run(conn).then(data => new Connection(conn, type, data));\n  }\n\n  /**\n   * Finds the first node that matches the criteria in `options.`\n   *\n   * @async\n   * @method findOne\n   * @param {Object} [options={}]\n   * @return {Promise<Node>}\n   */\n  findOne(options = {}) {\n    return this.find(options).then(connection => connection.first());\n  }\n\n  /**\n   * Creates a connection using the index named `index`.\n   *\n   * ```\n   * model('user').findByIndex('email', 'dylanslack@gmail.com').then(users => {\n   *   // Connection\n   * });\n   * ```\n   *\n   * @async\n   * @method findByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [options={}]\n   * @return {Promise<Connection>}\n   *\n   * @todo Add test.\n   */\n  findByIndex(index, value, options = {}) {\n    const { conn, type } = this;\n\n    const connection = createConnection(\n      type,\n      r.table(type.name).getAll(value, { index }),\n      options\n    );\n\n    return connection.run(conn).then(data => new Connection(conn, type, data));\n  }\n\n  /**\n   * Finds a single node from `index` that matches `value` and that matches the criteria in\n   * `options`.\n   *\n   * @async\n   * @method findOneByIndex\n   * @param {String} index - The index name.\n   * @param {*} value\n   * @param {Object} [options={}] - Critera before merging relationships.\n   * @return {Promise<Node>}\n   */\n  findOneByIndex(index, value, options = {}) {\n    return this.findByIndex(index, value, options).then(connection => connection.first());\n  }\n\n  /**\n   * Retrieves the resource(s) related to a particular resource identified by `id` according to\n   * `relationship`. A relationship with a relation of `hasMany` returns a `Connection`, and a\n   * relationship with a relation of `hasOne` or `belongsTo` returns a `Node`.\n   *\n   * ```js\n   * // pretend user `1` has a ton of pets\n   * model('user').findRelated('1', 'pets', {\n   *   filter: { species: 'hamster' },\n   * }).then(pets => {\n   *   // Connection\n   * });\n   *\n   * // pretend user `1` has a company\n   * model('user').findRelated('1', 'company').then(company => {\n   *   // Node\n   * });\n   * ```\n   *\n   * @async\n   * @method findRelated\n   * @param {String} id - The id of the parent resource.\n   * @param {String} relationship - The relationship to the parent.\n   * @param {Object} [options={}]\n   * @returns {Promise<Connection|Node>}\n   */\n  findRelated(id, relationship, options = {}) {\n    const { conn, type, type: { name: parentName } } = this;\n\n    const {\n      name: relatedName,\n      type: relatedSchema,\n      relation,\n      inverse,\n    } = type.relationships[relationship];\n\n    let query = r.table(relatedName);\n\n    if (relation === 'hasMany') {\n      if (requiresIndex(relation, inverse.relation)) {\n        query = query.getAll(id, { index: inverse.field });\n      } else {\n        query = query.getAll(\n          r.args(r.table(parentName).get(id)(relationship)('id'))\n        );\n      }\n\n      return createConnection(relatedSchema, query, options).run(conn)\n        .then(data => new Connection(conn, relatedSchema, data));\n    }\n\n    query = query.get(r.table(parentName).get(id)(relationship)('id'));\n    query = mergeRelationships(query, relatedSchema, options);\n    query = applyOptions(query, options);\n\n    return query.run(conn)\n      .then(data => new Node(conn, relatedSchema, data))\n      .catch(() => null);\n  }\n\n  /**\n   * Fetches the node with `id`.\n   *\n   * ```js\n   * model('user').fetch('1').then(user => {\n   *   // Node\n   * });\n   * ```\n   *\n   * @async\n   * @method fetch\n   * @param {String} id - The ID of the resource to retrieve.\n   * @param {Object} [options={}] - Critera before merging relationships.\n   * @returns {Promise<Node>}\n   */\n  fetch(id, options = {}) {\n    const { conn, type } = this;\n\n    let query = r.table(type.name).get(id);\n    query = mergeRelationships(query, type, options);\n    query = applyOptions(query, options);\n\n    return query.run(conn)\n      .then(data => new Node(conn, type, data))\n      .catch(() => null);\n  }\n\n  /**\n   * Persists a record in the database and creates a resource. The 'record' object must be a\n   * flattenen JSON with attributes and relationships. All relationships in `record` must be\n   * represented by either a string for a `hasOne` or `belongsTo` relation, or an array of strings\n   * for a `hasMany` relation.\n   *\n   * ```js\n   * model('user').create({\n   *   name: 'Dylan',\n   *   email: 'dylanslack@gmail.com',\n   *   password: 'hashedpassword',\n   *   pets: [ '1', '2', '3' ],\n   *   company: '1',\n   * }).then(user => {\n   *   // Node\n   * });\n   * ```\n   *\n   * @async\n   * @method create\n   * @param {Object} record\n   * @param {Object} [options={}] - Critera before merging relationships.\n   * @returns {Promise<Node>}\n   */\n  create(record, options = {}) {\n    const { conn, type } = this;\n    const { name } = type;\n\n    const checkComplianceAndNormalizeRecord = (compliant) => {\n      if (!compliant) {\n        throw new Error(\n          'Tried to create a record, but \\'record\\' had some invalid relationships.'\n        );\n      }\n\n      return normalizeRecord(record, type);\n    };\n\n    const createRecord = (normalizedRecord) => {\n      let createdNode;\n\n      return r.table(name).insert(normalizedRecord).run(conn)\n\n        // retrieve the record that was just created\n        .then(({ generated_keys: keys }) => this.fetch(keys[0], options))\n\n        // create the node and sync its relationships\n        .then(node => {\n          createdNode = node;\n\n          const syncRelationshipsArray = syncRelationships(record, type, node.id);\n          return r.do(syncRelationshipsArray).run(conn);\n        })\n\n        // return the node\n        .then(() => createdNode);\n    };\n\n    // check record and its relationships for Redink constraints\n    return isCreateCompliant(record, type, conn)\n      .then(checkComplianceAndNormalizeRecord)\n      .then(createRecord);\n  }\n}\n"]} |
@@ -58,7 +58,11 @@ 'use strict'; | ||
} else { | ||
if (data) { | ||
this.data = new _Node2.default(conn, type, data); | ||
} else { | ||
this.data = null; | ||
var node = void 0; | ||
try { | ||
node = new _Node2.default(conn, type, data); | ||
} catch (err) { | ||
node = null; | ||
} | ||
this.data = node; | ||
} | ||
@@ -88,2 +92,2 @@ } | ||
exports.default = Relationship; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9SZWxhdGlvbnNoaXAuanMiXSwibmFtZXMiOlsiaXNIYXNNYW55UmVsYXRpb25zaGlwSHlkcmF0ZWQiLCJkYXRhIiwiT2JqZWN0Iiwia2V5cyIsImluY2x1ZGVzIiwiUmVsYXRpb25zaGlwIiwiY29ubiIsInBhcmVudFR5cGUiLCJmaWVsZCIsInJlbGF0aW9uc2hpcHMiLCJ0eXBlIiwicmVsYXRpb24iLCJpbnZlcnNlIiwiX2FyY2hpdmVkIiwiX3JlbGF0ZWQiLCJpc0h5ZHJhdGVkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUE7Ozs7QUFDQTs7OztBQUNBOzs7Ozs7QUFFQSxJQUFNQSxnQ0FBZ0MsU0FBaENBLDZCQUFnQyxDQUFDQyxJQUFEO0FBQUEsU0FDcENBLFFBQ0EsUUFBT0EsSUFBUCx5Q0FBT0EsSUFBUCxPQUFnQixRQURoQixJQUVBQyxPQUFPQyxJQUFQLENBQVlGLElBQVosRUFBa0JHLFFBQWxCLENBQTJCLE9BQTNCLENBSG9DO0FBQUEsQ0FBdEM7O0lBTXFCQyxZO0FBQ25CLHdCQUFZQyxJQUFaLEVBQWtCQyxVQUFsQixFQUE4QkMsS0FBOUIsRUFBa0Q7QUFBQSxRQUFiUCxJQUFhLHVFQUFOLElBQU07O0FBQUE7O0FBQUEsZ0NBQ1pNLFdBQVdFLGFBQVgsQ0FBeUJELEtBQXpCLENBRFk7QUFBQSxRQUN4Q0UsSUFEd0MseUJBQ3hDQSxJQUR3QztBQUFBLFFBQ2xDQyxRQURrQyx5QkFDbENBLFFBRGtDO0FBQUEsUUFDeEJDLE9BRHdCLHlCQUN4QkEsT0FEd0I7OztBQUdoRCxTQUFLRixJQUFMLEdBQVlBLElBQVo7QUFDQSxTQUFLRixLQUFMLEdBQWFBLEtBQWI7QUFDQSxTQUFLRyxRQUFMLEdBQWdCQSxRQUFoQjtBQUNBLFNBQUtDLE9BQUwsR0FBZUEsT0FBZjs7QUFFQSxRQUFJLDJCQUFlWCxJQUFmLEVBQXFCLFdBQXJCLENBQUosRUFBdUMsS0FBS1ksU0FBTCxHQUFpQlosS0FBS1ksU0FBdEI7QUFDdkMsUUFBSSwyQkFBZVosSUFBZixFQUFxQixVQUFyQixDQUFKLEVBQXNDLEtBQUthLFFBQUwsR0FBZ0JiLEtBQUthLFFBQXJCOztBQUV0QyxRQUFJSCxhQUFhLFNBQWpCLEVBQTRCO0FBQzFCLFVBQUlYLDhCQUE4QkMsSUFBOUIsQ0FBSixFQUF5QztBQUN2QyxhQUFLQSxJQUFMLEdBQVkseUJBQWVLLElBQWYsRUFBcUJJLElBQXJCLEVBQTJCVCxJQUEzQixDQUFaO0FBQ0EsYUFBS2MsVUFBTCxHQUFrQixJQUFsQjtBQUNELE9BSEQsTUFHTztBQUNMLGFBQUtkLElBQUwsR0FBWUEsSUFBWjtBQUNBLGFBQUtjLFVBQUwsR0FBa0IsS0FBbEI7QUFDRDtBQUNGLEtBUkQsTUFRTztBQUNMLFVBQUlkLElBQUosRUFBVTtBQUNSLGFBQUtBLElBQUwsR0FBWSxtQkFBU0ssSUFBVCxFQUFlSSxJQUFmLEVBQXFCVCxJQUFyQixDQUFaO0FBQ0QsT0FGRCxNQUVPO0FBQ0wsYUFBS0EsSUFBTCxHQUFZLElBQVo7QUFDRDtBQUNGO0FBQ0Y7Ozs7b0NBRWU7QUFDZCxhQUFPLEtBQUtVLFFBQUwsS0FBa0IsU0FBbEIsS0FDTCxLQUFLQyxPQUFMLENBQWFELFFBQWIsS0FBMEIsV0FBMUIsSUFDQSxLQUFLQyxPQUFMLENBQWFELFFBQWIsS0FBMEIsUUFGckIsQ0FBUDtBQUlEOzs7aUNBRVk7QUFDWCxhQUFPLEtBQUtFLFNBQVo7QUFDRDs7O2dDQUVXO0FBQ1YsYUFBTyxLQUFLQyxRQUFaO0FBQ0Q7Ozs7OztrQkExQ2tCVCxZIiwiZmlsZSI6IlJlbGF0aW9uc2hpcC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDb25uZWN0aW9uIGZyb20gJy4vQ29ubmVjdGlvbic7XG5pbXBvcnQgTm9kZSBmcm9tICcuL05vZGUnO1xuaW1wb3J0IHsgaGFzT3duUHJvcGVydHkgfSBmcm9tICcuL3V0aWxzJztcblxuY29uc3QgaXNIYXNNYW55UmVsYXRpb25zaGlwSHlkcmF0ZWQgPSAoZGF0YSkgPT4gKFxuICBkYXRhICYmXG4gIHR5cGVvZiBkYXRhID09PSAnb2JqZWN0JyAmJlxuICBPYmplY3Qua2V5cyhkYXRhKS5pbmNsdWRlcygnZWRnZXMnKVxuKTtcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgUmVsYXRpb25zaGlwIHtcbiAgY29uc3RydWN0b3IoY29ubiwgcGFyZW50VHlwZSwgZmllbGQsIGRhdGEgPSBudWxsKSB7XG4gICAgY29uc3QgeyB0eXBlLCByZWxhdGlvbiwgaW52ZXJzZSB9ID0gcGFyZW50VHlwZS5yZWxhdGlvbnNoaXBzW2ZpZWxkXTtcblxuICAgIHRoaXMudHlwZSA9IHR5cGU7XG4gICAgdGhpcy5maWVsZCA9IGZpZWxkO1xuICAgIHRoaXMucmVsYXRpb24gPSByZWxhdGlvbjtcbiAgICB0aGlzLmludmVyc2UgPSBpbnZlcnNlO1xuXG4gICAgaWYgKGhhc093blByb3BlcnR5KGRhdGEsICdfYXJjaGl2ZWQnKSkgdGhpcy5fYXJjaGl2ZWQgPSBkYXRhLl9hcmNoaXZlZDtcbiAgICBpZiAoaGFzT3duUHJvcGVydHkoZGF0YSwgJ19yZWxhdGVkJykpIHRoaXMuX3JlbGF0ZWQgPSBkYXRhLl9yZWxhdGVkO1xuXG4gICAgaWYgKHJlbGF0aW9uID09PSAnaGFzTWFueScpIHtcbiAgICAgIGlmIChpc0hhc01hbnlSZWxhdGlvbnNoaXBIeWRyYXRlZChkYXRhKSkge1xuICAgICAgICB0aGlzLmRhdGEgPSBuZXcgQ29ubmVjdGlvbihjb25uLCB0eXBlLCBkYXRhKTtcbiAgICAgICAgdGhpcy5pc0h5ZHJhdGVkID0gdHJ1ZTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuZGF0YSA9IGRhdGE7XG4gICAgICAgIHRoaXMuaXNIeWRyYXRlZCA9IGZhbHNlO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoZGF0YSkge1xuICAgICAgICB0aGlzLmRhdGEgPSBuZXcgTm9kZShjb25uLCB0eXBlLCBkYXRhKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuZGF0YSA9IG51bGw7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmVxdWlyZXNJbmRleCgpIHtcbiAgICByZXR1cm4gdGhpcy5yZWxhdGlvbiA9PT0gJ2hhc01hbnknICYmIChcbiAgICAgIHRoaXMuaW52ZXJzZS5yZWxhdGlvbiA9PT0gJ2JlbG9uZ3NUbycgfHxcbiAgICAgIHRoaXMuaW52ZXJzZS5yZWxhdGlvbiA9PT0gJ2hhc09uZSdcbiAgICApO1xuICB9XG5cbiAgaXNBcmNoaXZlZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fYXJjaGl2ZWQ7XG4gIH1cblxuICBpc1JlbGF0ZWQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3JlbGF0ZWQ7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9SZWxhdGlvbnNoaXAuanMiXSwibmFtZXMiOlsiaXNIYXNNYW55UmVsYXRpb25zaGlwSHlkcmF0ZWQiLCJkYXRhIiwiT2JqZWN0Iiwia2V5cyIsImluY2x1ZGVzIiwiUmVsYXRpb25zaGlwIiwiY29ubiIsInBhcmVudFR5cGUiLCJmaWVsZCIsInJlbGF0aW9uc2hpcHMiLCJ0eXBlIiwicmVsYXRpb24iLCJpbnZlcnNlIiwiX2FyY2hpdmVkIiwiX3JlbGF0ZWQiLCJpc0h5ZHJhdGVkIiwibm9kZSIsImVyciJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBOzs7O0FBQ0E7Ozs7QUFDQTs7Ozs7O0FBRUEsSUFBTUEsZ0NBQWdDLFNBQWhDQSw2QkFBZ0MsQ0FBQ0MsSUFBRDtBQUFBLFNBQ3BDQSxRQUNBLFFBQU9BLElBQVAseUNBQU9BLElBQVAsT0FBZ0IsUUFEaEIsSUFFQUMsT0FBT0MsSUFBUCxDQUFZRixJQUFaLEVBQWtCRyxRQUFsQixDQUEyQixPQUEzQixDQUhvQztBQUFBLENBQXRDOztJQU1xQkMsWTtBQUNuQix3QkFBWUMsSUFBWixFQUFrQkMsVUFBbEIsRUFBOEJDLEtBQTlCLEVBQWtEO0FBQUEsUUFBYlAsSUFBYSx1RUFBTixJQUFNOztBQUFBOztBQUFBLGdDQUNaTSxXQUFXRSxhQUFYLENBQXlCRCxLQUF6QixDQURZO0FBQUEsUUFDeENFLElBRHdDLHlCQUN4Q0EsSUFEd0M7QUFBQSxRQUNsQ0MsUUFEa0MseUJBQ2xDQSxRQURrQztBQUFBLFFBQ3hCQyxPQUR3Qix5QkFDeEJBLE9BRHdCOzs7QUFHaEQsU0FBS0YsSUFBTCxHQUFZQSxJQUFaO0FBQ0EsU0FBS0YsS0FBTCxHQUFhQSxLQUFiO0FBQ0EsU0FBS0csUUFBTCxHQUFnQkEsUUFBaEI7QUFDQSxTQUFLQyxPQUFMLEdBQWVBLE9BQWY7O0FBRUEsUUFBSSwyQkFBZVgsSUFBZixFQUFxQixXQUFyQixDQUFKLEVBQXVDLEtBQUtZLFNBQUwsR0FBaUJaLEtBQUtZLFNBQXRCO0FBQ3ZDLFFBQUksMkJBQWVaLElBQWYsRUFBcUIsVUFBckIsQ0FBSixFQUFzQyxLQUFLYSxRQUFMLEdBQWdCYixLQUFLYSxRQUFyQjs7QUFFdEMsUUFBSUgsYUFBYSxTQUFqQixFQUE0QjtBQUMxQixVQUFJWCw4QkFBOEJDLElBQTlCLENBQUosRUFBeUM7QUFDdkMsYUFBS0EsSUFBTCxHQUFZLHlCQUFlSyxJQUFmLEVBQXFCSSxJQUFyQixFQUEyQlQsSUFBM0IsQ0FBWjtBQUNBLGFBQUtjLFVBQUwsR0FBa0IsSUFBbEI7QUFDRCxPQUhELE1BR087QUFDTCxhQUFLZCxJQUFMLEdBQVlBLElBQVo7QUFDQSxhQUFLYyxVQUFMLEdBQWtCLEtBQWxCO0FBQ0Q7QUFDRixLQVJELE1BUU87QUFDTCxVQUFJQyxhQUFKOztBQUVBLFVBQUk7QUFDRkEsZUFBTyxtQkFBU1YsSUFBVCxFQUFlSSxJQUFmLEVBQXFCVCxJQUFyQixDQUFQO0FBQ0QsT0FGRCxDQUVFLE9BQU9nQixHQUFQLEVBQVk7QUFDWkQsZUFBTyxJQUFQO0FBQ0Q7O0FBRUQsV0FBS2YsSUFBTCxHQUFZZSxJQUFaO0FBQ0Q7QUFDRjs7OztvQ0FFZTtBQUNkLGFBQU8sS0FBS0wsUUFBTCxLQUFrQixTQUFsQixLQUNMLEtBQUtDLE9BQUwsQ0FBYUQsUUFBYixLQUEwQixXQUExQixJQUNBLEtBQUtDLE9BQUwsQ0FBYUQsUUFBYixLQUEwQixRQUZyQixDQUFQO0FBSUQ7OztpQ0FFWTtBQUNYLGFBQU8sS0FBS0UsU0FBWjtBQUNEOzs7Z0NBRVc7QUFDVixhQUFPLEtBQUtDLFFBQVo7QUFDRDs7Ozs7O2tCQTlDa0JULFkiLCJmaWxlIjoiUmVsYXRpb25zaGlwLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IENvbm5lY3Rpb24gZnJvbSAnLi9Db25uZWN0aW9uJztcbmltcG9ydCBOb2RlIGZyb20gJy4vTm9kZSc7XG5pbXBvcnQgeyBoYXNPd25Qcm9wZXJ0eSB9IGZyb20gJy4vdXRpbHMnO1xuXG5jb25zdCBpc0hhc01hbnlSZWxhdGlvbnNoaXBIeWRyYXRlZCA9IChkYXRhKSA9PiAoXG4gIGRhdGEgJiZcbiAgdHlwZW9mIGRhdGEgPT09ICdvYmplY3QnICYmXG4gIE9iamVjdC5rZXlzKGRhdGEpLmluY2x1ZGVzKCdlZGdlcycpXG4pO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBSZWxhdGlvbnNoaXAge1xuICBjb25zdHJ1Y3Rvcihjb25uLCBwYXJlbnRUeXBlLCBmaWVsZCwgZGF0YSA9IG51bGwpIHtcbiAgICBjb25zdCB7IHR5cGUsIHJlbGF0aW9uLCBpbnZlcnNlIH0gPSBwYXJlbnRUeXBlLnJlbGF0aW9uc2hpcHNbZmllbGRdO1xuXG4gICAgdGhpcy50eXBlID0gdHlwZTtcbiAgICB0aGlzLmZpZWxkID0gZmllbGQ7XG4gICAgdGhpcy5yZWxhdGlvbiA9IHJlbGF0aW9uO1xuICAgIHRoaXMuaW52ZXJzZSA9IGludmVyc2U7XG5cbiAgICBpZiAoaGFzT3duUHJvcGVydHkoZGF0YSwgJ19hcmNoaXZlZCcpKSB0aGlzLl9hcmNoaXZlZCA9IGRhdGEuX2FyY2hpdmVkO1xuICAgIGlmIChoYXNPd25Qcm9wZXJ0eShkYXRhLCAnX3JlbGF0ZWQnKSkgdGhpcy5fcmVsYXRlZCA9IGRhdGEuX3JlbGF0ZWQ7XG5cbiAgICBpZiAocmVsYXRpb24gPT09ICdoYXNNYW55Jykge1xuICAgICAgaWYgKGlzSGFzTWFueVJlbGF0aW9uc2hpcEh5ZHJhdGVkKGRhdGEpKSB7XG4gICAgICAgIHRoaXMuZGF0YSA9IG5ldyBDb25uZWN0aW9uKGNvbm4sIHR5cGUsIGRhdGEpO1xuICAgICAgICB0aGlzLmlzSHlkcmF0ZWQgPSB0cnVlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5kYXRhID0gZGF0YTtcbiAgICAgICAgdGhpcy5pc0h5ZHJhdGVkID0gZmFsc2U7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBub2RlO1xuXG4gICAgICB0cnkge1xuICAgICAgICBub2RlID0gbmV3IE5vZGUoY29ubiwgdHlwZSwgZGF0YSk7XG4gICAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbm9kZSA9IG51bGw7XG4gICAgICB9XG5cbiAgICAgIHRoaXMuZGF0YSA9IG5vZGU7XG4gICAgfVxuICB9XG5cbiAgcmVxdWlyZXNJbmRleCgpIHtcbiAgICByZXR1cm4gdGhpcy5yZWxhdGlvbiA9PT0gJ2hhc01hbnknICYmIChcbiAgICAgIHRoaXMuaW52ZXJzZS5yZWxhdGlvbiA9PT0gJ2JlbG9uZ3NUbycgfHxcbiAgICAgIHRoaXMuaW52ZXJzZS5yZWxhdGlvbiA9PT0gJ2hhc09uZSdcbiAgICApO1xuICB9XG5cbiAgaXNBcmNoaXZlZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fYXJjaGl2ZWQ7XG4gIH1cblxuICBpc1JlbGF0ZWQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3JlbGF0ZWQ7XG4gIH1cbn1cbiJdfQ== |
{ | ||
"name": "redink", | ||
"version": "3.0.0-alpha.3", | ||
"version": "3.0.0-alpha.4", | ||
"description": "RethinkDB model layer", | ||
@@ -5,0 +5,0 @@ "main": "dist/index.js", |
Sorry, the diff of this file is too big to display
327874
0.38%3015
0.53%