UNPKG

@protokol/nft-base-api

Version:

REST API For Base NFT Functionality

142 lines 6.87 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.AssetsController = void 0; const core_kernel_1 = require("@arkecosystem/core-kernel"); const crypto_1 = require("@arkecosystem/crypto"); const boom_1 = __importDefault(require("@hapi/boom")); const nft_base_crypto_1 = require("@protokol/nft-base-crypto"); const nft_base_transactions_1 = require("@protokol/nft-base-transactions"); const assets_1 = require("../resources/assets"); const wallets_1 = require("../resources/wallets"); const base_controller_1 = require("./base-controller"); const pluginName = require("../../package.json").name; let AssetsController = class AssetsController extends base_controller_1.BaseController { constructor() { super(...arguments); Object.defineProperty(this, "walletRepository", { enumerable: true, configurable: true, writable: true, value: void 0 }); Object.defineProperty(this, "configuration", { enumerable: true, configurable: true, writable: true, value: void 0 }); } async index(request) { const criteria = { ...request.query, typeGroup: nft_base_crypto_1.Enums.NFTBaseTransactionGroup, type: nft_base_crypto_1.Enums.NFTBaseTransactionTypes.NFTCreate, }; return this.paginateWithBlock(criteria, this.getListingOrder(request), this.getListingPage(request), request.query.transform, assets_1.AssetResource); } async showAssetWallet(request) { let wallet; try { wallet = this.walletRepository.findByIndex(nft_base_transactions_1.Indexers.NFTIndexers.NFTTokenIndexer, request.params.id); } catch (e) { return boom_1.default.notFound("Asset not found or it was burned"); } return this.respondWithResource(wallet, wallets_1.WalletsResource); } async show(request) { const transaction = await this.transactionHistoryService.findOneByCriteria({ ...request.query, typeGroup: nft_base_crypto_1.Enums.NFTBaseTransactionGroup, type: nft_base_crypto_1.Enums.NFTBaseTransactionTypes.NFTCreate, id: request.params.id, }); if (!transaction) { return boom_1.default.notFound("Asset not found"); } return this.respondWithBlockResource(transaction, request.query.transform, assets_1.AssetResource); } async showWalletAssets(request) { let wallet; try { wallet = this.walletRepository.findByPublicKey(request.params.id); } catch (e) { return boom_1.default.notFound("Wallet not found"); } const tokenIds = Object.keys(wallet.getAttribute("nft.base.tokenIds", {})); const criteria = tokenIds.map((tokenId) => ({ typeGroup: nft_base_crypto_1.Enums.NFTBaseTransactionGroup, type: nft_base_crypto_1.Enums.NFTBaseTransactionTypes.NFTCreate, id: tokenId, })); return this.paginateWithBlock(criteria, this.getListingOrder(request), this.getListingPage(request), request.query.transform, assets_1.AssetResource); } async showByAsset(request) { const criteria = { ...request.query, typeGroup: nft_base_crypto_1.Enums.NFTBaseTransactionGroup, type: nft_base_crypto_1.Enums.NFTBaseTransactionTypes.NFTCreate, asset: { nftToken: { attributes: request.payload } }, }; return this.paginateWithBlock(criteria, this.getListingOrder(request), this.getListingPage(request), request.query.transform, assets_1.AssetResource); } async claimAsset(request) { const passphrase = this.configuration.get("mintPassphrase"); if (!passphrase) { return boom_1.default.notImplemented(); } const { collectionId, recipientId } = request.payload; if (!crypto_1.Identities.Address.validate(recipientId)) { return boom_1.default.badData("Address not found"); } let genesisWalletCollection; try { const genesisWallet = this.walletRepository.findByIndex(nft_base_transactions_1.Indexers.NFTIndexers.CollectionIndexer, collectionId); genesisWalletCollection = genesisWallet.getAttribute("nft.base.collections"); } catch (e) { return boom_1.default.badData("Collection not found"); } const attributes = genesisWalletCollection[collectionId].nftCollectionAsset.metadata; if (!attributes) { return boom_1.default.badData("This collection does not support claiming assets"); } const wallet = this.walletRepository.findByAddress(crypto_1.Identities.Address.fromPassphrase(passphrase)); const nonce = core_kernel_1.Utils.BigNumber.make(wallet.getNonce()).plus(1).toFixed(); const createAssetTx = new nft_base_crypto_1.Builders.NFTCreateBuilder() .NFTCreateToken({ collectionId, attributes, recipientId }) .nonce(nonce) .sign(passphrase) .build() .toJson(); return createAssetTx; } }; __decorate([ core_kernel_1.Container.inject(core_kernel_1.Container.Identifiers.WalletRepository), core_kernel_1.Container.tagged("state", "blockchain"), __metadata("design:type", Object) ], AssetsController.prototype, "walletRepository", void 0); __decorate([ core_kernel_1.Container.inject(core_kernel_1.Container.Identifiers.PluginConfiguration), core_kernel_1.Container.tagged("plugin", pluginName), __metadata("design:type", core_kernel_1.Providers.PluginConfiguration) ], AssetsController.prototype, "configuration", void 0); AssetsController = __decorate([ core_kernel_1.Container.injectable() ], AssetsController); exports.AssetsController = AssetsController; //# sourceMappingURL=assets.js.map