2018-06-13 15:39:39 -04:00
|
|
|
'use strict';
|
2018-10-14 19:05:38 -04:00
|
|
|
var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
|
if (mod && mod.__esModule) return mod;
|
|
|
|
var result = {};
|
|
|
|
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
|
|
result["default"] = mod;
|
|
|
|
return result;
|
|
|
|
};
|
2018-06-13 15:39:39 -04:00
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
2018-10-14 19:05:38 -04:00
|
|
|
var errors = __importStar(require("../errors"));
|
2018-06-13 15:39:39 -04:00
|
|
|
function defineReadOnly(object, name, value) {
|
|
|
|
Object.defineProperty(object, name, {
|
|
|
|
enumerable: true,
|
|
|
|
value: value,
|
|
|
|
writable: false,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
exports.defineReadOnly = defineReadOnly;
|
2018-07-25 21:20:21 -04:00
|
|
|
// There are some issues with instanceof with npm link, so we use this
|
|
|
|
// to ensure types are what we expect.
|
|
|
|
function setType(object, type) {
|
|
|
|
Object.defineProperty(object, '_ethersType', { configurable: false, value: type, writable: false });
|
|
|
|
}
|
|
|
|
exports.setType = setType;
|
|
|
|
function isType(object, type) {
|
2018-08-13 17:01:44 +01:00
|
|
|
return (object && object._ethersType === type);
|
2018-07-25 21:20:21 -04:00
|
|
|
}
|
|
|
|
exports.isType = isType;
|
2018-06-13 15:39:39 -04:00
|
|
|
function resolveProperties(object) {
|
|
|
|
var result = {};
|
|
|
|
var promises = [];
|
|
|
|
Object.keys(object).forEach(function (key) {
|
|
|
|
var value = object[key];
|
|
|
|
if (value instanceof Promise) {
|
2018-06-23 01:33:51 -04:00
|
|
|
promises.push(value.then(function (value) {
|
|
|
|
result[key] = value;
|
2018-07-03 16:44:05 -04:00
|
|
|
return null;
|
2018-06-23 01:33:51 -04:00
|
|
|
}));
|
2018-06-13 15:39:39 -04:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
result[key] = value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return Promise.all(promises).then(function () {
|
2018-06-21 20:41:09 -04:00
|
|
|
return result;
|
2018-06-13 15:39:39 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
exports.resolveProperties = resolveProperties;
|
2018-10-14 19:05:38 -04:00
|
|
|
function checkProperties(object, properties) {
|
|
|
|
if (!object || typeof (object) !== 'object') {
|
|
|
|
errors.throwError('invalid object', errors.INVALID_ARGUMENT, {
|
|
|
|
argument: 'object',
|
|
|
|
value: object
|
|
|
|
});
|
|
|
|
}
|
|
|
|
Object.keys(object).forEach(function (key) {
|
|
|
|
if (!properties[key]) {
|
|
|
|
errors.throwError('invalid object key - ' + key, errors.INVALID_ARGUMENT, {
|
|
|
|
argument: 'transaction',
|
|
|
|
value: object,
|
|
|
|
key: key
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
exports.checkProperties = checkProperties;
|
2018-06-15 04:18:17 -04:00
|
|
|
function shallowCopy(object) {
|
|
|
|
var result = {};
|
|
|
|
for (var key in object) {
|
|
|
|
result[key] = object[key];
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
exports.shallowCopy = shallowCopy;
|
2018-08-21 13:13:52 +02:00
|
|
|
var opaque = { boolean: true, number: true, string: true };
|
|
|
|
function deepCopy(object, frozen) {
|
2018-10-01 17:34:44 -04:00
|
|
|
// Opaque objects are not mutable, so safe to copy by assignment
|
2018-08-21 13:13:52 +02:00
|
|
|
if (object === undefined || object === null || opaque[typeof (object)]) {
|
|
|
|
return object;
|
|
|
|
}
|
2018-10-01 17:34:44 -04:00
|
|
|
// Arrays are mutable, so we need to create a copy
|
2018-08-21 13:13:52 +02:00
|
|
|
if (Array.isArray(object)) {
|
2018-10-01 17:34:44 -04:00
|
|
|
var result = object.map(function (item) { return deepCopy(item, frozen); });
|
2018-08-21 13:13:52 +02:00
|
|
|
if (frozen) {
|
2018-10-01 17:34:44 -04:00
|
|
|
Object.freeze(result);
|
2018-08-21 13:13:52 +02:00
|
|
|
}
|
2018-10-01 17:34:44 -04:00
|
|
|
return result;
|
2018-08-21 13:13:52 +02:00
|
|
|
}
|
|
|
|
if (typeof (object) === 'object') {
|
|
|
|
// Some internal objects, which are already immutable
|
|
|
|
if (isType(object, 'BigNumber')) {
|
|
|
|
return object;
|
|
|
|
}
|
|
|
|
if (isType(object, 'Description')) {
|
|
|
|
return object;
|
|
|
|
}
|
|
|
|
if (isType(object, 'Indexed')) {
|
|
|
|
return object;
|
|
|
|
}
|
|
|
|
var result = {};
|
|
|
|
for (var key in object) {
|
|
|
|
var value = object[key];
|
|
|
|
if (value === undefined) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
defineReadOnly(result, key, deepCopy(value, frozen));
|
|
|
|
}
|
|
|
|
if (frozen) {
|
|
|
|
Object.freeze(result);
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2018-10-01 17:34:44 -04:00
|
|
|
// The function type is also immutable, so safe to copy by assignment
|
|
|
|
if (typeof (object) === 'function') {
|
|
|
|
return object;
|
|
|
|
}
|
2018-08-21 13:13:52 +02:00
|
|
|
throw new Error('Cannot deepCopy ' + typeof (object));
|
2018-06-15 04:18:17 -04:00
|
|
|
}
|
2018-08-21 13:13:52 +02:00
|
|
|
exports.deepCopy = deepCopy;
|
2018-07-30 18:59:52 -04:00
|
|
|
// See: https://github.com/isaacs/inherits/blob/master/inherits_browser.js
|
|
|
|
function inherits(ctor, superCtor) {
|
|
|
|
ctor.super_ = superCtor;
|
|
|
|
ctor.prototype = Object.create(superCtor.prototype, {
|
|
|
|
constructor: {
|
|
|
|
value: ctor,
|
|
|
|
enumerable: false,
|
|
|
|
writable: true,
|
|
|
|
configurable: true
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
function inheritable(parent) {
|
|
|
|
return function (child) {
|
|
|
|
inherits(child, parent);
|
|
|
|
defineReadOnly(child, 'inherits', inheritable(child));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
exports.inheritable = inheritable;
|