Use Long for int64
This commit is contained in:
parent
ae1ddbe266
commit
6cdf9a64a6
|
@ -22,9 +22,12 @@
|
|||
},
|
||||
"homepage": "https://github.com/nicdex/eventstore-node#readme",
|
||||
"dependencies": {
|
||||
"long": "^3.0.3",
|
||||
"protobufjs": "^5.0.1",
|
||||
"uuid": "^2.0.1"
|
||||
},
|
||||
"engines": { "node": ">=0.12" },
|
||||
"engines": {
|
||||
"node": ">=0.12"
|
||||
},
|
||||
"engineStrict": true
|
||||
}
|
||||
|
|
|
@ -56,7 +56,7 @@ StartTransactionOperation.prototype._inspectResponse = function(response) {
|
|||
};
|
||||
|
||||
StartTransactionOperation.prototype._transformResponse = function(response) {
|
||||
return new EventStoreTransaction(results.toNumber(response.transaction_id), this.userCredentials, this._parentConnection);
|
||||
return new EventStoreTransaction(response.transaction_id, this.userCredentials, this._parentConnection);
|
||||
};
|
||||
|
||||
StartTransactionOperation.prototype.toString = function() {
|
||||
|
|
|
@ -12,12 +12,13 @@ function EventStoreTransaction(transactionId, userCredentials, connection) {
|
|||
|
||||
this._isCommitted = false;
|
||||
this._isRolledBack = false;
|
||||
}
|
||||
Object.defineProperty(EventStoreTransaction.prototype, 'transactionId', {
|
||||
get: function() {
|
||||
return this._transactionId;
|
||||
|
||||
Object.defineProperties(this, {
|
||||
transactionId: {
|
||||
enumerable: true, get: function() { return this._transactionId; }
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Commit (async)
|
||||
|
|
|
@ -1,45 +1,41 @@
|
|||
var util = require('util');
|
||||
var uuid = require('uuid');
|
||||
var Long = require('long');
|
||||
var ensure = require('./common/utils/ensure');
|
||||
|
||||
function toNumber(obj) {
|
||||
if (typeof obj === 'number')
|
||||
return obj;
|
||||
if (typeof obj !== 'object')
|
||||
throw new TypeError(util.format("'%s' is not a number.", obj));
|
||||
if (!obj.hasOwnProperty('low') || !obj.hasOwnProperty('high') || !obj.hasOwnProperty('unsigned'))
|
||||
throw new Error("Invalid number.");
|
||||
return (obj.low + (obj.high * 0xffffffff));
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {!number} commitPosition
|
||||
* @param {!number} preparePosition
|
||||
* @param {!number|!Long} commitPosition
|
||||
* @param {!number|!Long} preparePosition
|
||||
* @constructor
|
||||
* @property {!number} commitPosition
|
||||
* @property {!number} preparePosition
|
||||
* @property {!Long} commitPosition
|
||||
* @property {!Long} preparePosition
|
||||
*/
|
||||
function Position(commitPosition, preparePosition) {
|
||||
ensure.notNull(commitPosition, "commitPosition");
|
||||
ensure.notNull(preparePosition, "preparePosition");
|
||||
commitPosition = Long.fromValue(commitPosition);
|
||||
preparePosition = Long.fromValue(preparePosition);
|
||||
|
||||
Object.defineProperties(this, {
|
||||
commitPosition: {
|
||||
enumerable: true, value: toNumber(commitPosition)
|
||||
enumerable: true, value: commitPosition
|
||||
},
|
||||
preparePosition: {
|
||||
enumerable: true, value: toNumber(preparePosition)
|
||||
enumerable: true, value: preparePosition
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
Position.prototype.compareTo = function(other) {
|
||||
if (this.commitPosition < other.commitPosition || (this.commitPosition === other.commitPosition && this.preparePosition < other.preparePosition))
|
||||
if (this.commitPosition.lt(other.commitPosition) || (this.commitPosition.eq(other.commitPosition)&& this.preparePosition.lt(other.preparePosition)))
|
||||
return -1;
|
||||
if (this.commitPosition > other.commitPosition || (this.commitPosition === other.commitPosition && this.preparePosition > other.preparePosition))
|
||||
if (this.commitPosition.gt(other.commitPosition) || (this.commitPosition.eq(other.commitPosition) && this.preparePosition.gt(other.preparePosition)))
|
||||
return 1;
|
||||
return 0;
|
||||
};
|
||||
|
||||
Position.prototype.toString = function() {
|
||||
return util.format("%d/%d", this.commitPosition, this.preparePosition);
|
||||
return [this.commitPosition.toString(), this.preparePosition.toString()].join("/");
|
||||
};
|
||||
|
||||
|
||||
|
@ -69,8 +65,8 @@ function RecordedEvent(ev) {
|
|||
eventNumber: {enumerable: true, value: ev.event_number},
|
||||
eventType: {enumerable: true, value: ev.event_type},
|
||||
//Javascript doesn't have .Net precision for time, so we use created_epoch for created
|
||||
created: {enumerable: true, value: new Date(ev.created_epoch || 0)},
|
||||
createdEpoch: {enumerable: true, value: ev.created_epoch ? toNumber(ev.created_epoch) : 0},
|
||||
created: {enumerable: true, value: new Date(ev.created_epoch ? ev.created_epoch.toInt() : 0)},
|
||||
createdEpoch: {enumerable: true, value: ev.created_epoch ? ev.created_epoch.toInt() : 0},
|
||||
data: {enumerable: true, value: ev.data ? ev.data.toBuffer() : new Buffer(0)},
|
||||
metadata: {enumerable: true, value: ev.metadata ? ev.metadata.toBuffer() : new Buffer(0)},
|
||||
isJson: {enumerable: true, value: ev.data_content_type == 1}
|
||||
|
@ -338,7 +334,6 @@ function PersistentSubscriptionDeleteResult(status) {
|
|||
|
||||
// Exports Constructors
|
||||
module.exports.Position = Position;
|
||||
module.exports.toNumber = toNumber;
|
||||
module.exports.ResolvedEvent = ResolvedEvent;
|
||||
module.exports.EventReadStatus = EventReadStatus;
|
||||
module.exports.EventReadResult = EventReadResult;
|
||||
|
|
Loading…
Reference in New Issue
Block a user