UNPKG

@harmoniclabs/blockfrost-pluts

Version:

@blockfrost/blockfrost-js extension based on plu-ts types

83 lines (82 loc) 3.35 kB
"use strict"; var __values = (this && this.__values) || function(o) { var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; if (m) return m.call(o); if (o && typeof o.length === "number") return { next: function () { if (o && i >= o.length) o = void 0; return { value: o && o[i++], done: !o }; } }; throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); }; var __read = (this && this.__read) || function (o, n) { var m = typeof Symbol === "function" && o[Symbol.iterator]; if (!m) return o; var i = m.call(o), r, ar = [], e; try { while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); } catch (error) { e = { error: error }; } finally { try { if (r && !r.done && (m = i["return"])) m.call(i); } finally { if (e) throw e.error; } } return ar; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.getRealTxRedeemers = void 0; var cardano_ledger_ts_1 = require("@harmoniclabs/cardano-ledger-ts"); var obj_utils_1 = require("@harmoniclabs/obj-utils"); function isOgmios5EvalTxResponse(stuff) { return (0, obj_utils_1.isObject)(stuff) && (stuff.type === "jsonwsp/response" && stuff.version === "1.0" && stuff.servicename === "ogmios"); } function adaptOgmiosTag(tag) { switch (tag) { case "spend": return cardano_ledger_ts_1.TxRedeemerTag.Spend; case "mint": return cardano_ledger_ts_1.TxRedeemerTag.Mint; case "certificate": return cardano_ledger_ts_1.TxRedeemerTag.Cert; case "withdrawal": return cardano_ledger_ts_1.TxRedeemerTag.Withdraw; } } function ogmiosEvalTxResultToPartialTxRdmrs(result) { var e_1, _a; if (typeof result !== "object" || result === null) throw new Error("invalid ogmios result"); var keys = Object.keys(result); var rdmrs = []; try { for (var keys_1 = __values(keys), keys_1_1 = keys_1.next(); !keys_1_1.done; keys_1_1 = keys_1.next()) { var k = keys_1_1.value; var _b = __read(k.split(":"), 2), tagStr = _b[0], idxStr = _b[1]; rdmrs.push({ tag: adaptOgmiosTag(tagStr), index: parseInt(idxStr), exunits: { mem: result[k].memory, cpu: result[k].steps } }); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (keys_1_1 && !keys_1_1.done && (_a = keys_1.return)) _a.call(keys_1); } finally { if (e_1) throw e_1.error; } } return rdmrs; } function getRealTxRedeemers(tx, response) { var _a, _b, _c, _d; // if( !isOgmios5EvalTxResponse( response ) ) throw new Error("unexpected response; expected ogmios 5.6 EvalTx response"); if (!response.result) throw new Error("Missing Ogmios result: " + ((_b = (_a = response.fault) === null || _a === void 0 ? void 0 : _a.string) !== null && _b !== void 0 ? _b : "")); return ogmiosEvalTxResultToPartialTxRdmrs((_d = (_c = response.result) === null || _c === void 0 ? void 0 : _c.EvaluationResult) !== null && _d !== void 0 ? _d : response.result); } exports.getRealTxRedeemers = getRealTxRedeemers;