meteor-nem-library
Version:
Meteor NIS1 Library
89 lines • 4.34 kB
JavaScript
;
/*
* The MIT License (MIT)
*
* Copyright (c) 2017 NEM
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const AccountHttp_1 = require("../../infrastructure/AccountHttp");
const ConfirmedTransactionListener_1 = require("../../infrastructure/ConfirmedTransactionListener");
const UnconfirmedTransactionListener_1 = require("../../infrastructure/UnconfirmedTransactionListener");
const Address_1 = require("../../models/account/Address");
const TransactionUtilities_1 = require("../utilities/TransactionUtilities");
const bMosaic_1 = require("./bMosaic");
class BAddress extends Address_1.Address {
constructor(address) {
super(address);
/**
* Get mosaics for given address
* @returns {Promise<Array<MosaicTransferable>>}
*/
this.mosaics = () => {
return new Promise((resolve, reject) => {
try {
new AccountHttp_1.AccountHttp().getMosaicOwnedByAddress(this).subscribe((mosaics) => __awaiter(this, void 0, void 0, function* () {
resolve(yield Promise.all(mosaics.map((mosaic) => __awaiter(this, void 0, void 0, function* () {
const bMosaic = new bMosaic_1.BMosaic(mosaic.mosaicId, mosaic.quantity);
return yield bMosaic.getMosaicDetails();
}))));
}), err => {
reject(err);
});
}
catch (err) {
reject(err);
}
});
};
/**
* Start listening new confirmed transactions
* @returns {Observable<Array<TransferTransaction>>}
*/
this.confirmedTxObserver = () => {
return new ConfirmedTransactionListener_1.ConfirmedTransactionListener().given(this).filter(TransactionUtilities_1.transferFilter).map(TransactionUtilities_1.mapTransfer);
};
/**
* Start listening new unconfirmed transactions
* @returns {Observable<Array<TransferTransaction>>}
*/
this.unconfirmedTxObserver = () => {
return new UnconfirmedTransactionListener_1.UnconfirmedTransactionListener().given(this).filter(TransactionUtilities_1.transferFilter).map(TransactionUtilities_1.mapTransfer);
};
}
}
/**
* Create a Address from object
* @param addressValue - Address object from outside source
* @returns {Address}
*/
BAddress.castToAddress = (addressValue) => {
return new Address_1.Address(addressValue.value);
};
exports.BAddress = BAddress;
//# sourceMappingURL=bAddress.js.map