@cardano-sdk/input-selection 0.6.0-nightly.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/LICENSE +201 -0
  2. package/NOTICE +5 -0
  3. package/README.md +50 -0
  4. package/dist/cjs/InputSelectionError.d.ts +12 -0
  5. package/dist/cjs/InputSelectionError.d.ts.map +1 -0
  6. package/dist/cjs/InputSelectionError.js +19 -0
  7. package/dist/cjs/InputSelectionError.js.map +1 -0
  8. package/dist/cjs/RoundRobinRandomImprove/change.d.ts +23 -0
  9. package/dist/cjs/RoundRobinRandomImprove/change.d.ts.map +1 -0
  10. package/dist/cjs/RoundRobinRandomImprove/change.js +227 -0
  11. package/dist/cjs/RoundRobinRandomImprove/change.js.map +1 -0
  12. package/dist/cjs/RoundRobinRandomImprove/index.d.ts +7 -0
  13. package/dist/cjs/RoundRobinRandomImprove/index.d.ts.map +1 -0
  14. package/dist/cjs/RoundRobinRandomImprove/index.js +52 -0
  15. package/dist/cjs/RoundRobinRandomImprove/index.js.map +1 -0
  16. package/dist/cjs/RoundRobinRandomImprove/roundRobin.d.ts +3 -0
  17. package/dist/cjs/RoundRobinRandomImprove/roundRobin.d.ts.map +1 -0
  18. package/dist/cjs/RoundRobinRandomImprove/roundRobin.js +65 -0
  19. package/dist/cjs/RoundRobinRandomImprove/roundRobin.js.map +1 -0
  20. package/dist/cjs/RoundRobinRandomImprove/util.d.ts +34 -0
  21. package/dist/cjs/RoundRobinRandomImprove/util.d.ts.map +1 -0
  22. package/dist/cjs/RoundRobinRandomImprove/util.js +76 -0
  23. package/dist/cjs/RoundRobinRandomImprove/util.js.map +1 -0
  24. package/dist/cjs/index.d.ts +5 -0
  25. package/dist/cjs/index.d.ts.map +1 -0
  26. package/dist/cjs/index.js +21 -0
  27. package/dist/cjs/index.js.map +1 -0
  28. package/dist/cjs/package.json +3 -0
  29. package/dist/cjs/selectionConstraints.d.ts +14 -0
  30. package/dist/cjs/selectionConstraints.d.ts.map +1 -0
  31. package/dist/cjs/selectionConstraints.js +43 -0
  32. package/dist/cjs/selectionConstraints.js.map +1 -0
  33. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  34. package/dist/cjs/types.d.ts +40 -0
  35. package/dist/cjs/types.d.ts.map +1 -0
  36. package/dist/cjs/types.js +3 -0
  37. package/dist/cjs/types.js.map +1 -0
  38. package/dist/esm/InputSelectionError.d.ts +12 -0
  39. package/dist/esm/InputSelectionError.d.ts.map +1 -0
  40. package/dist/esm/InputSelectionError.js +15 -0
  41. package/dist/esm/InputSelectionError.js.map +1 -0
  42. package/dist/esm/RoundRobinRandomImprove/change.d.ts +23 -0
  43. package/dist/esm/RoundRobinRandomImprove/change.d.ts.map +1 -0
  44. package/dist/esm/RoundRobinRandomImprove/change.js +220 -0
  45. package/dist/esm/RoundRobinRandomImprove/change.js.map +1 -0
  46. package/dist/esm/RoundRobinRandomImprove/index.d.ts +7 -0
  47. package/dist/esm/RoundRobinRandomImprove/index.d.ts.map +1 -0
  48. package/dist/esm/RoundRobinRandomImprove/index.js +48 -0
  49. package/dist/esm/RoundRobinRandomImprove/index.js.map +1 -0
  50. package/dist/esm/RoundRobinRandomImprove/roundRobin.d.ts +3 -0
  51. package/dist/esm/RoundRobinRandomImprove/roundRobin.d.ts.map +1 -0
  52. package/dist/esm/RoundRobinRandomImprove/roundRobin.js +61 -0
  53. package/dist/esm/RoundRobinRandomImprove/roundRobin.js.map +1 -0
  54. package/dist/esm/RoundRobinRandomImprove/util.d.ts +34 -0
  55. package/dist/esm/RoundRobinRandomImprove/util.d.ts.map +1 -0
  56. package/dist/esm/RoundRobinRandomImprove/util.js +63 -0
  57. package/dist/esm/RoundRobinRandomImprove/util.js.map +1 -0
  58. package/dist/esm/index.d.ts +5 -0
  59. package/dist/esm/index.d.ts.map +1 -0
  60. package/dist/esm/index.js +5 -0
  61. package/dist/esm/index.js.map +1 -0
  62. package/dist/esm/package.json +3 -0
  63. package/dist/esm/selectionConstraints.d.ts +14 -0
  64. package/dist/esm/selectionConstraints.d.ts.map +1 -0
  65. package/dist/esm/selectionConstraints.js +35 -0
  66. package/dist/esm/selectionConstraints.js.map +1 -0
  67. package/dist/esm/tsconfig.tsbuildinfo +1 -0
  68. package/dist/esm/types.d.ts +40 -0
  69. package/dist/esm/types.d.ts.map +1 -0
  70. package/dist/esm/types.js +2 -0
  71. package/dist/esm/types.js.map +1 -0
  72. package/package.json +78 -0
@@ -0,0 +1,3 @@
1
+ import { RoundRobinRandomImproveArgs, UtxoSelection } from './util';
2
+ export declare const roundRobinSelection: ({ utxo: utxosWithValue, outputs: outputsWithValue, uniqueTxAssetIDs, random, implicitValue }: RoundRobinRandomImproveArgs) => UtxoSelection;
3
+ //# sourceMappingURL=roundRobin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"roundRobin.d.ts","sourceRoot":"","sources":["../../../src/RoundRobinRandomImprove/roundRobin.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,2BAA2B,EAC3B,aAAa,EAId,MAAM,QAAQ,CAAC;AAiEhB,eAAO,MAAM,mBAAmB,iGAM7B,2BAA2B,KAAG,aA2ChC,CAAC"}
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.roundRobinSelection = void 0;
4
+ const util_1 = require("@cardano-sdk/util");
5
+ const util_2 = require("./util");
6
+ const improvesSelection = (utxoAlreadySelected, input, minimumTarget, getQuantity) => {
7
+ const oldQuantity = getQuantity(utxoAlreadySelected);
8
+ if (oldQuantity < minimumTarget)
9
+ return true;
10
+ const newQuantity = oldQuantity + getQuantity([input]);
11
+ const idealTarget = 2n * minimumTarget;
12
+ const newDistance = util_1.BigIntMath.abs(idealTarget - newQuantity);
13
+ const oldDistance = util_1.BigIntMath.abs(idealTarget - oldQuantity);
14
+ if (newDistance < oldDistance)
15
+ return true;
16
+ return false;
17
+ };
18
+ const listTokensWithin = (uniqueOutputAssetIDs, outputs, { implicitCoin, implicitTokens }) => [
19
+ ...uniqueOutputAssetIDs.map((id) => {
20
+ const getQuantity = (0, util_2.assetQuantitySelector)(id);
21
+ const implicitInput = implicitTokens.input(id);
22
+ const implicitSpend = implicitTokens.spend(id);
23
+ return {
24
+ filterUtxo: (utxo) => utxo.filter(([_, { value: { assets } }]) => assets?.get(id)),
25
+ getTotalSelectedQuantity: (utxo) => getQuantity((0, util_2.toValues)(utxo)) + implicitInput,
26
+ minimumTarget: getQuantity((0, util_2.toValues)(outputs)) + implicitSpend
27
+ };
28
+ }),
29
+ {
30
+ filterUtxo: (utxo) => utxo,
31
+ getTotalSelectedQuantity: (utxo) => (0, util_2.getCoinQuantity)((0, util_2.toValues)(utxo)) + implicitCoin.input,
32
+ minimumTarget: (0, util_2.getCoinQuantity)((0, util_2.toValues)(outputs)) + implicitCoin.deposit
33
+ }
34
+ ];
35
+ const roundRobinSelection = ({ utxo: utxosWithValue, outputs: outputsWithValue, uniqueTxAssetIDs, random, implicitValue }) => {
36
+ const utxoSelected = [];
37
+ const utxoRemaining = [...utxosWithValue];
38
+ const tokensRemaining = listTokensWithin(uniqueTxAssetIDs, outputsWithValue, implicitValue);
39
+ while (tokensRemaining.length > 0) {
40
+ for (const [tokenIdx, { filterUtxo, minimumTarget, getTotalSelectedQuantity }] of tokensRemaining.entries()) {
41
+ const utxo = filterUtxo(utxoRemaining);
42
+ if (utxo.length > 0) {
43
+ const inputIdx = Math.floor(random() * utxo.length);
44
+ const input = utxo[inputIdx];
45
+ if (improvesSelection(utxoSelected, input, minimumTarget, getTotalSelectedQuantity)) {
46
+ utxoSelected.push(input);
47
+ utxoRemaining.splice(utxoRemaining.indexOf(input), 1);
48
+ }
49
+ else {
50
+ tokensRemaining.splice(tokenIdx, 1);
51
+ }
52
+ }
53
+ else {
54
+ tokensRemaining.splice(tokenIdx, 1);
55
+ }
56
+ }
57
+ }
58
+ if (utxoSelected.length === 0) {
59
+ utxoSelected.push(utxoRemaining[0]);
60
+ utxoRemaining.splice(0, 1);
61
+ }
62
+ return { utxoRemaining, utxoSelected };
63
+ };
64
+ exports.roundRobinSelection = roundRobinSelection;
65
+ //# sourceMappingURL=roundRobin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"roundRobin.js","sourceRoot":"","sources":["../../../src/RoundRobinRandomImprove/roundRobin.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ import { Cardano } from '@cardano-sdk/core';
2
+ import { ImplicitValue } from '../types';
3
+ export interface ImplicitTokens {
4
+ spend(assetId: Cardano.AssetId): bigint;
5
+ input(assetId: Cardano.AssetId): bigint;
6
+ }
7
+ export interface RequiredImplicitValue {
8
+ implicitCoin: Required<Cardano.util.ImplicitCoin>;
9
+ implicitTokens: ImplicitTokens;
10
+ }
11
+ export interface RoundRobinRandomImproveArgs {
12
+ utxo: Cardano.Utxo[];
13
+ outputs: Cardano.TxOut[];
14
+ uniqueTxAssetIDs: Cardano.AssetId[];
15
+ implicitValue: RequiredImplicitValue;
16
+ random: typeof Math.random;
17
+ }
18
+ export declare type PreProcessedArgs = Omit<RoundRobinRandomImproveArgs, 'random'>;
19
+ export interface UtxoSelection {
20
+ utxoSelected: Cardano.Utxo[];
21
+ utxoRemaining: Cardano.Utxo[];
22
+ }
23
+ export declare const mintToImplicitTokens: (mintMap?: Cardano.TokenMap) => {
24
+ implicitTokensInput: Map<Cardano.AssetId, bigint>;
25
+ implicitTokensSpend: Map<Cardano.AssetId, bigint>;
26
+ };
27
+ export declare const preProcessArgs: (availableUtxo: Set<Cardano.Utxo>, outputSet: Set<Cardano.TxOut>, partialImplicitValue?: ImplicitValue) => PreProcessedArgs;
28
+ export declare function toValues(outputs: Cardano.TxOut[]): Cardano.Value[];
29
+ export declare function toValues(utxo: Cardano.Utxo[]): Cardano.Value[];
30
+ export declare const assetQuantitySelector: (id: Cardano.AssetId) => (quantities: Cardano.Value[]) => bigint;
31
+ export declare const getCoinQuantity: (quantities: Cardano.Value[]) => bigint;
32
+ export declare const assertIsCoinBalanceSufficient: (utxoValues: Cardano.Value[], outputValues: Cardano.Value[], implicitCoin: Required<Cardano.util.ImplicitCoin>) => void;
33
+ export declare const assertIsBalanceSufficient: (uniqueTxAssetIDs: Cardano.AssetId[], utxo: Cardano.Utxo[], outputs: Cardano.TxOut[], { implicitCoin, implicitTokens }: RequiredImplicitValue) => void;
34
+ //# sourceMappingURL=util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/RoundRobinRandomImprove/util.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAIzC,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAAC;IACxC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAAC;CACzC;AAED,MAAM,WAAW,qBAAqB;IACpC,YAAY,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClD,cAAc,EAAE,cAAc,CAAC;CAChC;AAED,MAAM,WAAW,2BAA2B;IAC1C,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC;IACzB,gBAAgB,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;IACpC,aAAa,EAAE,qBAAqB,CAAC;IACrC,MAAM,EAAE,OAAO,IAAI,CAAC,MAAM,CAAC;CAC5B;AAED,oBAAY,gBAAgB,GAAG,IAAI,CAAC,2BAA2B,EAAE,QAAQ,CAAC,CAAC;AAE3E,MAAM,WAAW,aAAa;IAC5B,YAAY,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAC7B,aAAa,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;CAC/B;AAED,eAAO,MAAM,oBAAoB;;;CAOhC,CAAC;AAEF,eAAO,MAAM,cAAc,kBACV,IAAI,QAAQ,IAAI,CAAC,aACrB,IAAI,QAAQ,KAAK,CAAC,yBACN,aAAa,KACnC,gBAoBF,CAAC;AAKF,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,EAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;AACpE,wBAAgB,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;AAWhE,eAAO,MAAM,qBAAqB,wCAEnB,QAAQ,KAAK,EAAE,KAAG,MACwC,CAAC;AAE1E,eAAO,MAAM,eAAe,eAAgB,QAAQ,KAAK,EAAE,KAAG,MACR,CAAC;AAEvD,eAAO,MAAM,6BAA6B,eAC5B,QAAQ,KAAK,EAAE,gBACb,QAAQ,KAAK,EAAE,gBACf,SAAS,QAAQ,IAAI,CAAC,YAAY,CAAC,SAOlD,CAAC;AAQF,eAAO,MAAM,yBAAyB,qBAClB,QAAQ,OAAO,EAAE,QAC7B,QAAQ,IAAI,EAAE,WACX,QAAQ,KAAK,EAAE,oCACU,qBAAqB,KACtD,IAeF,CAAC"}
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.assertIsBalanceSufficient = exports.assertIsCoinBalanceSufficient = exports.getCoinQuantity = exports.assetQuantitySelector = exports.toValues = exports.preProcessArgs = exports.mintToImplicitTokens = void 0;
7
+ const util_1 = require("@cardano-sdk/util");
8
+ const InputSelectionError_1 = require("../InputSelectionError");
9
+ const uniq_1 = __importDefault(require("lodash/uniq"));
10
+ const mintToImplicitTokens = (mintMap = new Map()) => {
11
+ const mint = [...mintMap.entries()];
12
+ const implicitTokensInput = new Map(mint.filter(([_, quantity]) => quantity > 0));
13
+ const implicitTokensSpend = new Map(mint.filter(([_, quantity]) => quantity < 0).map(([assetId, quantity]) => [assetId, -quantity]));
14
+ return { implicitTokensInput, implicitTokensSpend };
15
+ };
16
+ exports.mintToImplicitTokens = mintToImplicitTokens;
17
+ const preProcessArgs = (availableUtxo, outputSet, partialImplicitValue) => {
18
+ const outputs = [...outputSet];
19
+ const implicitCoin = {
20
+ deposit: partialImplicitValue?.coin?.deposit || 0n,
21
+ input: partialImplicitValue?.coin?.input || 0n
22
+ };
23
+ const mintMap = partialImplicitValue?.mint || new Map();
24
+ const { implicitTokensInput, implicitTokensSpend } = (0, exports.mintToImplicitTokens)(mintMap);
25
+ const implicitTokens = {
26
+ input: (assetId) => implicitTokensInput.get(assetId) || 0n,
27
+ spend: (assetId) => implicitTokensSpend.get(assetId) || 0n
28
+ };
29
+ const uniqueOutputAssetIDs = (0, uniq_1.default)(outputs.flatMap(({ value: { assets } }) => [...(assets?.keys() || [])]));
30
+ const uniqueTxAssetIDs = (0, uniq_1.default)([...uniqueOutputAssetIDs, ...mintMap.keys()]);
31
+ return {
32
+ implicitValue: { implicitCoin, implicitTokens },
33
+ outputs,
34
+ uniqueTxAssetIDs,
35
+ utxo: [...availableUtxo]
36
+ };
37
+ };
38
+ exports.preProcessArgs = preProcessArgs;
39
+ const isUtxoArray = (outputsOrUtxo) => outputsOrUtxo.length > 0 && Array.isArray(outputsOrUtxo[0]);
40
+ function toValues(outputsOrUtxo) {
41
+ if (isUtxoArray(outputsOrUtxo)) {
42
+ return outputsOrUtxo.map(([_, { value }]) => value);
43
+ }
44
+ return outputsOrUtxo.map(({ value }) => value);
45
+ }
46
+ exports.toValues = toValues;
47
+ const assetQuantitySelector = (id) => (quantities) => util_1.BigIntMath.sum(quantities.map(({ assets }) => assets?.get(id) || 0n));
48
+ exports.assetQuantitySelector = assetQuantitySelector;
49
+ const getCoinQuantity = (quantities) => util_1.BigIntMath.sum(quantities.map(({ coins }) => coins));
50
+ exports.getCoinQuantity = getCoinQuantity;
51
+ const assertIsCoinBalanceSufficient = (utxoValues, outputValues, implicitCoin) => {
52
+ const utxoCoinTotal = (0, exports.getCoinQuantity)(utxoValues);
53
+ const outputsCoinTotal = (0, exports.getCoinQuantity)(outputValues);
54
+ if (outputsCoinTotal + implicitCoin.deposit > utxoCoinTotal + implicitCoin.input) {
55
+ throw new InputSelectionError_1.InputSelectionError(InputSelectionError_1.InputSelectionFailure.UtxoBalanceInsufficient);
56
+ }
57
+ };
58
+ exports.assertIsCoinBalanceSufficient = assertIsCoinBalanceSufficient;
59
+ const assertIsBalanceSufficient = (uniqueTxAssetIDs, utxo, outputs, { implicitCoin, implicitTokens }) => {
60
+ if (utxo.length === 0) {
61
+ throw new InputSelectionError_1.InputSelectionError(InputSelectionError_1.InputSelectionFailure.UtxoBalanceInsufficient);
62
+ }
63
+ const utxoValues = toValues(utxo);
64
+ const outputsValues = toValues(outputs);
65
+ for (const assetId of uniqueTxAssetIDs) {
66
+ const getAssetQuantity = (0, exports.assetQuantitySelector)(assetId);
67
+ const utxoTotal = getAssetQuantity(utxoValues);
68
+ const outputsTotal = getAssetQuantity(outputsValues);
69
+ if (outputsTotal + implicitTokens.spend(assetId) > utxoTotal + implicitTokens.input(assetId)) {
70
+ throw new InputSelectionError_1.InputSelectionError(InputSelectionError_1.InputSelectionFailure.UtxoBalanceInsufficient);
71
+ }
72
+ }
73
+ (0, exports.assertIsCoinBalanceSufficient)(utxoValues, outputsValues, implicitCoin);
74
+ };
75
+ exports.assertIsBalanceSufficient = assertIsBalanceSufficient;
76
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/RoundRobinRandomImprove/util.ts"],"names":[],"mappings":";;;;;;AACA,4CAA+C;AAG/C,gEAAoF;AACpF,uDAA+B;AA2BxB,MAAM,oBAAoB,GAAG,CAAC,UAA4B,IAAI,GAAG,EAAE,EAAE,EAAE;IAC5E,MAAM,IAAI,GAAG,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IACpC,MAAM,mBAAmB,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC;IAClF,MAAM,mBAAmB,GAAG,IAAI,GAAG,CACjC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC,CAChG,CAAC;IACF,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,CAAC;AACtD,CAAC,CAAC;AAPW,QAAA,oBAAoB,wBAO/B;AAEK,MAAM,cAAc,GAAG,CAC5B,aAAgC,EAChC,SAA6B,EAC7B,oBAAoC,EAClB,EAAE;IACpB,MAAM,OAAO,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC;IAC/B,MAAM,YAAY,GAAwC;QACxD,OAAO,EAAE,oBAAoB,EAAE,IAAI,EAAE,OAAO,IAAI,EAAE;QAClD,KAAK,EAAE,oBAAoB,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE;KAC/C,CAAC;IACF,MAAM,OAAO,GAAqB,oBAAoB,EAAE,IAAI,IAAI,IAAI,GAAG,EAAE,CAAC;IAC1E,MAAM,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,GAAG,IAAA,4BAAoB,EAAC,OAAO,CAAC,CAAC;IACnF,MAAM,cAAc,GAAmB;QACrC,KAAK,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE;QAC1D,KAAK,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE;KAC3D,CAAC;IACF,MAAM,oBAAoB,GAAG,IAAA,cAAI,EAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3G,MAAM,gBAAgB,GAAG,IAAA,cAAI,EAAC,CAAC,GAAG,oBAAoB,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC5E,OAAO;QACL,aAAa,EAAE,EAAE,YAAY,EAAE,cAAc,EAAE;QAC/C,OAAO;QACP,gBAAgB;QAChB,IAAI,EAAE,CAAC,GAAG,aAAa,CAAC;KACzB,CAAC;AACJ,CAAC,CAAC;AAxBW,QAAA,cAAc,kBAwBzB;AAEF,MAAM,WAAW,GAAG,CAAC,aAA+C,EAAmC,EAAE,CACvG,aAAa,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;AAO9D,SAAgB,QAAQ,CAAC,aAA+C;IACtE,IAAI,WAAW,CAAC,aAAa,CAAC,EAAE;QAC9B,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;KACrD;IACD,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;AACjD,CAAC;AALD,4BAKC;AAEM,MAAM,qBAAqB,GAChC,CAAC,EAAmB,EAAE,EAAE,CACxB,CAAC,UAA2B,EAAU,EAAE,CACtC,iBAAU,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;AAH7D,QAAA,qBAAqB,yBAGwC;AAEnE,MAAM,eAAe,GAAG,CAAC,UAA2B,EAAU,EAAE,CACrE,iBAAU,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;AAD1C,QAAA,eAAe,mBAC2B;AAEhD,MAAM,6BAA6B,GAAG,CAC3C,UAA2B,EAC3B,YAA6B,EAC7B,YAAiD,EACjD,EAAE;IACF,MAAM,aAAa,GAAG,IAAA,uBAAe,EAAC,UAAU,CAAC,CAAC;IAClD,MAAM,gBAAgB,GAAG,IAAA,uBAAe,EAAC,YAAY,CAAC,CAAC;IACvD,IAAI,gBAAgB,GAAG,YAAY,CAAC,OAAO,GAAG,aAAa,GAAG,YAAY,CAAC,KAAK,EAAE;QAChF,MAAM,IAAI,yCAAmB,CAAC,2CAAqB,CAAC,uBAAuB,CAAC,CAAC;KAC9E;AACH,CAAC,CAAC;AAVW,QAAA,6BAA6B,iCAUxC;AAQK,MAAM,yBAAyB,GAAG,CACvC,gBAAmC,EACnC,IAAoB,EACpB,OAAwB,EACxB,EAAE,YAAY,EAAE,cAAc,EAAyB,EACjD,EAAE;IACR,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;QACrB,MAAM,IAAI,yCAAmB,CAAC,2CAAqB,CAAC,uBAAuB,CAAC,CAAC;KAC9E;IACD,MAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAClC,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;IACxC,KAAK,MAAM,OAAO,IAAI,gBAAgB,EAAE;QACtC,MAAM,gBAAgB,GAAG,IAAA,6BAAqB,EAAC,OAAO,CAAC,CAAC;QACxD,MAAM,SAAS,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;QACrD,IAAI,YAAY,GAAG,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE;YAC5F,MAAM,IAAI,yCAAmB,CAAC,2CAAqB,CAAC,uBAAuB,CAAC,CAAC;SAC9E;KACF;IACD,IAAA,qCAA6B,EAAC,UAAU,EAAE,aAAa,EAAE,YAAY,CAAC,CAAC;AACzE,CAAC,CAAC;AApBW,QAAA,yBAAyB,6BAoBpC"}
@@ -0,0 +1,5 @@
1
+ export * from './RoundRobinRandomImprove';
2
+ export * from './selectionConstraints';
3
+ export * from './types';
4
+ export * from './InputSelectionError';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAC;AAC1C,cAAc,wBAAwB,CAAC;AACvC,cAAc,SAAS,CAAC;AACxB,cAAc,uBAAuB,CAAC"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./RoundRobinRandomImprove"), exports);
18
+ __exportStar(require("./selectionConstraints"), exports);
19
+ __exportStar(require("./types"), exports);
20
+ __exportStar(require("./InputSelectionError"), exports);
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,yDAAuC;AACvC,0CAAwB;AACxB,wDAAsC"}
@@ -0,0 +1,3 @@
1
+ {
2
+ "type": "commonjs"
3
+ }
@@ -0,0 +1,14 @@
1
+ import { CSL } from '@cardano-sdk/core';
2
+ import { ComputeMinimumCoinQuantity, ComputeSelectionLimit, EstimateTxFee, ProtocolParametersForInputSelection, SelectionConstraints, SelectionSkeleton, TokenBundleSizeExceedsLimit } from './types';
3
+ import { ProtocolParametersRequiredByInputSelection } from '.';
4
+ export declare type BuildTx = (selection: SelectionSkeleton) => Promise<CSL.Transaction>;
5
+ export interface DefaultSelectionConstraintsProps {
6
+ protocolParameters: ProtocolParametersForInputSelection;
7
+ buildTx: BuildTx;
8
+ }
9
+ export declare const computeMinimumCost: ({ minFeeCoefficient, minFeeConstant }: Pick<ProtocolParametersRequiredByInputSelection, 'minFeeCoefficient' | 'minFeeConstant'>, buildTx: BuildTx) => EstimateTxFee;
10
+ export declare const computeMinimumCoinQuantity: (coinsPerUtxoByte: ProtocolParametersRequiredByInputSelection['coinsPerUtxoByte']) => ComputeMinimumCoinQuantity;
11
+ export declare const tokenBundleSizeExceedsLimit: (maxValueSize: ProtocolParametersRequiredByInputSelection['maxValueSize']) => TokenBundleSizeExceedsLimit;
12
+ export declare const computeSelectionLimit: (maxTxSize: ProtocolParametersRequiredByInputSelection['maxTxSize'], buildTx: BuildTx) => ComputeSelectionLimit;
13
+ export declare const defaultSelectionConstraints: ({ protocolParameters: { coinsPerUtxoByte, maxTxSize, maxValueSize, minFeeCoefficient, minFeeConstant }, buildTx }: DefaultSelectionConstraintsProps) => SelectionConstraints;
14
+ //# sourceMappingURL=selectionConstraints.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"selectionConstraints.d.ts","sourceRoot":"","sources":["../../src/selectionConstraints.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAsD,MAAM,mBAAmB,CAAC;AAC5F,OAAO,EACL,0BAA0B,EAC1B,qBAAqB,EACrB,aAAa,EACb,mCAAmC,EACnC,oBAAoB,EACpB,iBAAiB,EACjB,2BAA2B,EAC5B,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,0CAA0C,EAAE,MAAM,GAAG,CAAC;AAE/D,oBAAY,OAAO,GAAG,CAAC,SAAS,EAAE,iBAAiB,KAAK,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;AAEjF,MAAM,WAAW,gCAAgC;IAC/C,kBAAkB,EAAE,mCAAmC,CAAC;IACxD,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,eAAO,MAAM,kBAAkB,0CAKxB,KAAK,0CAA0C,EAAE,mBAAmB,GAAG,gBAAgB,CAAC,WAClF,OAAO,KACf,aAYF,CAAC;AAEJ,eAAO,MAAM,0BAA0B,qBAClB,0CAA0C,CAAC,kBAAkB,CAAC,KAAG,0BAOjF,CAAC;AAEN,eAAO,MAAM,2BAA2B,iBACvB,0CAA0C,CAAC,cAAc,CAAC,KAAG,2BAQ3E,CAAC;AAWJ,eAAO,MAAM,qBAAqB,cACpB,0CAA0C,CAAC,WAAW,CAAC,WAAW,OAAO,KAAG,qBAQvF,CAAC;AAEJ,eAAO,MAAM,2BAA2B,sHAGrC,gCAAgC,KAAG,oBAYrC,CAAC"}
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.defaultSelectionConstraints = exports.computeSelectionLimit = exports.tokenBundleSizeExceedsLimit = exports.computeMinimumCoinQuantity = exports.computeMinimumCost = void 0;
4
+ const core_1 = require("@cardano-sdk/core");
5
+ const computeMinimumCost = ({ minFeeCoefficient, minFeeConstant }, buildTx) => async (selection) => {
6
+ const tx = await buildTx(selection);
7
+ return BigInt(core_1.CSL.min_fee(tx, core_1.CSL.LinearFee.new(core_1.CSL.BigNum.from_str(minFeeCoefficient.toString()), core_1.CSL.BigNum.from_str(minFeeConstant.toString()))).to_str());
8
+ };
9
+ exports.computeMinimumCost = computeMinimumCost;
10
+ const computeMinimumCoinQuantity = (coinsPerUtxoByte) => (output) => BigInt(core_1.CSL.min_ada_for_output(core_1.coreToCsl.txOut(output), core_1.CSL.DataCost.new_coins_per_byte(core_1.CSL.BigNum.from_str(coinsPerUtxoByte.toString()))).to_str());
11
+ exports.computeMinimumCoinQuantity = computeMinimumCoinQuantity;
12
+ const tokenBundleSizeExceedsLimit = (maxValueSize) => (tokenBundle) => {
13
+ if (!tokenBundle) {
14
+ return false;
15
+ }
16
+ const value = core_1.CSL.Value.new(core_1.cslUtil.maxBigNum);
17
+ value.set_multiasset(core_1.coreToCsl.tokenMap(tokenBundle));
18
+ return value.to_bytes().length > maxValueSize;
19
+ };
20
+ exports.tokenBundleSizeExceedsLimit = tokenBundleSizeExceedsLimit;
21
+ const getTxSize = (tx) => tx.to_bytes().length;
22
+ const computeSelectionLimit = (maxTxSize, buildTx) => async (selectionSkeleton) => {
23
+ const tx = await buildTx(selectionSkeleton);
24
+ const txSize = getTxSize(tx);
25
+ if (txSize <= maxTxSize) {
26
+ return selectionSkeleton.inputs.size;
27
+ }
28
+ return selectionSkeleton.inputs.size - 1;
29
+ };
30
+ exports.computeSelectionLimit = computeSelectionLimit;
31
+ const defaultSelectionConstraints = ({ protocolParameters: { coinsPerUtxoByte, maxTxSize, maxValueSize, minFeeCoefficient, minFeeConstant }, buildTx }) => {
32
+ if (!coinsPerUtxoByte || !maxTxSize || !maxValueSize || !minFeeCoefficient || !minFeeConstant) {
33
+ throw new core_1.InvalidProtocolParametersError('Missing one of: coinsPerUtxoByte, maxTxSize, maxValueSize, minFeeCoefficient, minFeeConstant');
34
+ }
35
+ return {
36
+ computeMinimumCoinQuantity: (0, exports.computeMinimumCoinQuantity)(coinsPerUtxoByte),
37
+ computeMinimumCost: (0, exports.computeMinimumCost)({ minFeeCoefficient, minFeeConstant }, buildTx),
38
+ computeSelectionLimit: (0, exports.computeSelectionLimit)(maxTxSize, buildTx),
39
+ tokenBundleSizeExceedsLimit: (0, exports.tokenBundleSizeExceedsLimit)(maxValueSize)
40
+ };
41
+ };
42
+ exports.defaultSelectionConstraints = defaultSelectionConstraints;
43
+ //# sourceMappingURL=selectionConstraints.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"selectionConstraints.js","sourceRoot":"","sources":["../../src/selectionConstraints.ts"],"names":[],"mappings":"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"}