@xyo-network/payment-payload-plugins 3.0.25 → 3.0.27

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.
@@ -0,0 +1,6 @@
1
+ import type { Hash } from '@xylabs/hex';
2
+ import { type HashLeaseEstimate } from '@xyo-network/diviner-hash-lease';
3
+ import type { Payload, WithMeta, WithSources } from '@xyo-network/payload-model';
4
+ import type { EscrowTerms } from '../../Terms/index.ts';
5
+ export declare const getAppraisalsByAsset: (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>) => Record<Hash, WithSources<HashLeaseEstimate>[]>;
6
+ //# sourceMappingURL=getAppraisalsByAsset.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getAppraisalsByAsset.d.ts","sourceRoot":"","sources":["../../../../../src/Escrow/util/appraisal/getAppraisalsByAsset.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,KAAK,iBAAiB,EAAkC,MAAM,iCAAiC,CAAA;AACxG,OAAO,KAAK,EACV,OAAO,EAAE,QAAQ,EAAE,WAAW,EAC/B,MAAM,4BAA4B,CAAA;AAEnC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAQvD,eAAO,MAAM,oBAAoB,UAAW,WAAW,cAAc,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAG,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,iBAAiB,CAAC,EAAE,CAkBnJ,CAAA"}
@@ -0,0 +1,6 @@
1
+ import type { Hash } from '@xylabs/hex';
2
+ import { type BoundWitness } from '@xyo-network/boundwitness-model';
3
+ import type { Payload, WithMeta } from '@xyo-network/payload-model';
4
+ import type { EscrowTerms } from '../../Terms/index.ts';
5
+ export declare const getSignaturesByAppraisal: (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>) => Record<Hash, WithMeta<BoundWitness>[]>;
6
+ //# sourceMappingURL=getSignaturesByAppraisal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSignaturesByAppraisal.d.ts","sourceRoot":"","sources":["../../../../../src/Escrow/util/appraisal/getSignaturesByAppraisal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,KAAK,YAAY,EAA0B,MAAM,iCAAiC,CAAA;AAC3F,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAEnE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AASvD,eAAO,MAAM,wBAAwB,UAC5B,WAAW,cACN,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,KAC1C,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,YAAY,CAAC,EAAE,CAsBvC,CAAA"}
@@ -0,0 +1,3 @@
1
+ export * from './getAppraisalsByAsset.ts';
2
+ export * from './getSignaturesByAppraisal.ts';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/Escrow/util/appraisal/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAA;AACzC,cAAc,+BAA+B,CAAA"}
@@ -1,2 +1,3 @@
1
+ export * from './appraisal/index.ts';
1
2
  export * from './secret/index.ts';
2
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/Escrow/util/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/Escrow/util/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAA;AACpC,cAAc,mBAAmB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"appraisal.d.ts","sourceRoot":"","sources":["../../../../../src/Escrow/validators/escrow/appraisal.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAKvC,OAAO,KAAK,EACV,OAAO,EAAE,6BAA6B,EAAE,QAAQ,EACjD,MAAM,4BAA4B,CAAA;AAEnC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AASvD,eAAO,MAAM,wBAAwB,EAAE,6BAA6B,CAAC,WAAW,CAQ/E,CAAA;AAOD,eAAO,MAAM,0CAA0C,eAAgB,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAG,6BAA6B,CAAC,WAAW,CA0BjJ,CAAA;AASD,eAAO,MAAM,2BAA2B,eAC1B,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,cAC/B,MAAM,KACjB,6BAA6B,CAAC,WAAW,CAiB3C,CAAA;AAOD,eAAO,MAAM,kCAAkC,eAAgB,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAG,6BAA6B,CAAC,WAAW,CAWzI,CAAA"}
1
+ {"version":3,"file":"appraisal.d.ts","sourceRoot":"","sources":["../../../../../src/Escrow/validators/escrow/appraisal.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAIvC,OAAO,KAAK,EACV,OAAO,EAAE,6BAA6B,EAAE,QAAQ,EACjD,MAAM,4BAA4B,CAAA;AAEnC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAUvD,eAAO,MAAM,wBAAwB,EAAE,6BAA6B,CAAC,WAAW,CAQ/E,CAAA;AAOD,eAAO,MAAM,0CAA0C,eAAgB,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAG,6BAA6B,CAAC,WAAW,CA0BjJ,CAAA;AASD,eAAO,MAAM,2BAA2B,eAC1B,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,cAC/B,MAAM,KACjB,6BAA6B,CAAC,WAAW,CAiB3C,CAAA;AAOD,eAAO,MAAM,kCAAkC,eAAgB,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAG,6BAA6B,CAAC,WAAW,CAWzI,CAAA"}
@@ -397,6 +397,48 @@ var isEscrowTerms = isPayloadOfSchemaType9(EscrowTermsSchema);
397
397
  var isEscrowTermsWithSources = isPayloadOfSchemaTypeWithSources9(EscrowTermsSchema);
398
398
  var isEscrowTermsWithMeta = isPayloadOfSchemaTypeWithMeta9(EscrowTermsSchema);
399
399
 
400
+ // src/Escrow/util/appraisal/getAppraisalsByAsset.ts
401
+ import { isHashLeaseEstimateWithSources } from "@xyo-network/diviner-hash-lease";
402
+ var getAppraisalsByAsset = (terms, dictionary) => {
403
+ const assets = terms.assets;
404
+ if (!assets || assets.length === 0) return {};
405
+ const appraisals = Object.values(dictionary).filter(isHashLeaseEstimateWithSources);
406
+ const appraisalsByAsset = {};
407
+ for (const estimate of appraisals) {
408
+ const { sources } = estimate;
409
+ if (sources === void 0 || sources.length === 0) {
410
+ continue;
411
+ }
412
+ for (const asset of assets) {
413
+ if (sources.includes(asset)) {
414
+ if (!appraisalsByAsset[asset]) appraisalsByAsset[asset] = [];
415
+ appraisalsByAsset[asset].push(estimate);
416
+ }
417
+ }
418
+ }
419
+ return appraisalsByAsset;
420
+ };
421
+
422
+ // src/Escrow/util/appraisal/getSignaturesByAppraisal.ts
423
+ import { isBoundWitnessWithMeta } from "@xyo-network/boundwitness-model";
424
+ var getSignaturesByAppraisal = (terms, dictionary) => {
425
+ const appraisals = terms.appraisals;
426
+ if (!appraisals || appraisals.length === 0) return {};
427
+ const appraisalAuthorities = terms.appraisalAuthorities;
428
+ if (!appraisalAuthorities || appraisalAuthorities.length === 0) return {};
429
+ const appraisalBWsValid = Object.fromEntries(
430
+ appraisals.map((hash) => [hash, []])
431
+ );
432
+ for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta)) {
433
+ for (const appraisal of appraisals) {
434
+ if (bw.payload_hashes.includes(appraisal) && bw.addresses.some((address) => appraisalAuthorities.includes(address))) {
435
+ appraisalBWsValid[appraisal].push(bw);
436
+ }
437
+ }
438
+ }
439
+ return appraisalBWsValid;
440
+ };
441
+
400
442
  // src/Escrow/util/secret/createEscrowIntent.ts
401
443
  import { BoundWitnessBuilder } from "@xyo-network/boundwitness-builder";
402
444
  var createEscrowIntentWithSecret = async (terms, secret, account) => {
@@ -405,7 +447,7 @@ var createEscrowIntentWithSecret = async (terms, secret, account) => {
405
447
  };
406
448
 
407
449
  // src/Escrow/util/secret/findEscrowPartySecretSignatures.ts
408
- import { isBoundWitnessWithMeta } from "@xyo-network/boundwitness-model";
450
+ import { isBoundWitnessWithMeta as isBoundWitnessWithMeta2 } from "@xyo-network/boundwitness-model";
409
451
  var getLogPrefix = (party) => {
410
452
  const partySecret = party === "seller" ? "sellerSecret" : "buyerSecret";
411
453
  return `EscrowTerms.${partySecret}`;
@@ -422,7 +464,7 @@ var findEscrowPartySecretSignatures = (terms, dictionary, party) => {
422
464
  console.log(`${getLogPrefix(party)}: No ${partySecret}: ${terms[partySecret]}`);
423
465
  return [];
424
466
  }
425
- const partySignedBWs = Object.values(dictionary).filter(isBoundWitnessWithMeta).filter((bw) => bw.payload_hashes.includes(secretHash)).filter((bw) => partyAddresses.every((address) => bw.addresses.includes(address)));
467
+ const partySignedBWs = Object.values(dictionary).filter(isBoundWitnessWithMeta2).filter((bw) => bw.payload_hashes.includes(secretHash)).filter((bw) => partyAddresses.every((address) => bw.addresses.includes(address)));
426
468
  return partySignedBWs;
427
469
  };
428
470
 
@@ -510,8 +552,7 @@ var getEscrowAgentAllowedValidator = (allowedEscrowAgent) => {
510
552
 
511
553
  // src/Escrow/validators/escrow/appraisal.ts
512
554
  import { assertEx } from "@xylabs/assert";
513
- import { isBoundWitnessWithMeta as isBoundWitnessWithMeta2 } from "@xyo-network/boundwitness-model";
514
- import { isHashLeaseEstimateWithSources } from "@xyo-network/diviner-hash-lease";
555
+ import { isBoundWitnessWithMeta as isBoundWitnessWithMeta3 } from "@xyo-network/boundwitness-model";
515
556
  var name2 = "EscrowTerms.appraisal";
516
557
  var appraisalsExistValidator = (terms) => {
517
558
  const appraisals = terms.appraisals;
@@ -528,7 +569,7 @@ var getAppraisalsFromValidAuthoritiesValidator = (dictionary) => {
528
569
  const appraisalBWsValid = Object.fromEntries(
529
570
  appraisals.map((hash) => [hash, []])
530
571
  );
531
- for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta2)) {
572
+ for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta3)) {
532
573
  for (const appraisal of appraisals) {
533
574
  if (bw.payload_hashes.includes(appraisal) && bw.addresses.some((address) => appraisalAuthorities.includes(address))) {
534
575
  appraisalBWsValid[appraisal].push(bw);
@@ -546,7 +587,7 @@ var getAppraisalsFromValidAuthoritiesValidator = (dictionary) => {
546
587
  };
547
588
  var getAppraisalsValidValidator = (dictionary, minimumExp) => {
548
589
  return (terms) => {
549
- const estimatesByAsset = getEstimatesByAsset(terms, dictionary);
590
+ const estimatesByAsset = getAppraisalsByAsset(terms, dictionary);
550
591
  const now = Date.now();
551
592
  const exp = now + minimumExp;
552
593
  for (const [asset, estimates] of Object.entries(estimatesByAsset)) {
@@ -562,8 +603,8 @@ var getAppraisalsValidValidator = (dictionary, minimumExp) => {
562
603
  };
563
604
  var getAppraisalsForAllAssetsValidator = (dictionary) => {
564
605
  return (terms) => {
565
- const estimatesByAsset = getEstimatesByAsset(terms, dictionary);
566
606
  const assets = assertEx(terms.assets, () => `${name2}: No assets: ${terms.assets}`);
607
+ const estimatesByAsset = getAppraisalsByAsset(terms, dictionary);
567
608
  if (Object.keys(estimatesByAsset).length !== assets.length) {
568
609
  console.log(`${name2}: Missing appraisals for all assets: ${assets}`);
569
610
  return false;
@@ -577,25 +618,6 @@ var validateEstimate = (estimate, exp) => {
577
618
  if (estimate.price < 0) return false;
578
619
  return true;
579
620
  };
580
- var getEstimatesByAsset = (terms, dictionary) => {
581
- const assets = assertEx(terms.assets, () => `${name2}: No assets: ${terms.assets}`);
582
- const estimates = Object.values(dictionary).filter(isHashLeaseEstimateWithSources);
583
- const estimatesByAsset = {};
584
- for (const estimate of estimates) {
585
- const { sources } = estimate;
586
- if (sources === void 0 || sources.length === 0) {
587
- console.log(`${name2}: No sources: ${estimate}`);
588
- continue;
589
- }
590
- for (const asset of assets) {
591
- if (sources.includes(asset)) {
592
- if (!estimatesByAsset[asset]) estimatesByAsset[asset] = [];
593
- estimatesByAsset[asset].push(estimate);
594
- }
595
- }
596
- }
597
- return estimatesByAsset;
598
- };
599
621
 
600
622
  // src/Escrow/validators/escrow/appraisalAuthorities.ts
601
623
  import { asAddress } from "@xylabs/hex";
@@ -883,6 +905,7 @@ export {
883
905
  createEscrowIntentWithSecret,
884
906
  findEscrowPartySecretSignatures,
885
907
  getAppraisalAuthoritiesAllowedValidator,
908
+ getAppraisalsByAsset,
886
909
  getAppraisalsForAllAssetsValidator,
887
910
  getAppraisalsFromValidAuthoritiesValidator,
888
911
  getAppraisalsValidValidator,
@@ -895,6 +918,7 @@ export {
895
918
  getPaymentAuthoritiesAllowedValidator,
896
919
  getSellerSecretSignedValidator,
897
920
  getSellerSecretSuppliedValidator,
921
+ getSignaturesByAppraisal,
898
922
  isAmount,
899
923
  isAmountWithMeta,
900
924
  isAmountWithSources,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Amount/Iso4217Currency.ts","../../src/Amount/Payload.ts","../../src/Billing/Address/Address.ts","../../src/Schema.ts","../../src/Billing/Schema.ts","../../src/Billing/Address/Schema.ts","../../src/Discount/Config.ts","../../src/Discount/Payload/Coupon/Conditions/AppraisalAmountCondition.ts","../../src/Discount/Payload/Coupon/Conditions/AssetQuantityCondition.ts","../../src/Discount/Payload/Coupon/Conditions/BuyerCondition.ts","../../src/Discount/Payload/Coupon/Coupons/FixedAmount.ts","../../src/Discount/Payload/Coupon/Schema.ts","../../src/Discount/Payload/Coupon/Coupons/FixedPercentage.ts","../../src/Discount/Payload/Coupon/Coupons/FixedPrice.ts","../../src/Discount/Payload/Coupon/Payload.ts","../../src/Discount/Payload/Coupon/types/Condition.ts","../../src/Discount/Payload/Coupon/types/isStackable.ts","../../src/Discount/Payload/Discount.ts","../../src/Discount/Payload/NoDiscount.ts","../../src/Escrow/Outcome.ts","../../src/Escrow/Schema.ts","../../src/Escrow/Terms/Terms.ts","../../src/Escrow/util/secret/createEscrowIntent.ts","../../src/Escrow/util/secret/findEscrowPartySecretSignatures.ts","../../src/Escrow/util/secret/getEscrowSecret.ts","../../src/Escrow/util/secret/updateEscrowTermsWithSecret.ts","../../src/Escrow/validators/common/ModuleInstanceValidators/moduleInstanceValidators.ts","../../src/Escrow/validators/common/SecretValidators/getPartySecretSignedValidator.ts","../../src/Escrow/validators/common/TemporalValidators/validateWithinWindow.ts","../../src/Escrow/validators/escrow/agent.ts","../../src/Escrow/validators/escrow/appraisal.ts","../../src/Escrow/validators/escrow/appraisalAuthorities.ts","../../src/Escrow/validators/escrow/assets.ts","../../src/Escrow/validators/escrow/buyer.ts","../../src/Escrow/validators/escrow/buyerSecret.ts","../../src/Escrow/validators/escrow/nbfExp.ts","../../src/Escrow/validators/escrow/paymentAuthorities.ts","../../src/Escrow/validators/escrow/seller.ts","../../src/Escrow/validators/escrow/sellerSecret.ts","../../src/Payment/Instrument/Card/Payload.ts","../../src/Payment/Schema.ts","../../src/Payment/Instrument/Schema.ts","../../src/Payment/Instrument/Card/Schema.ts","../../src/Payment/Payload.ts","../../src/Payment/Status/Payload.ts","../../src/Payment/Status/Schema.ts","../../src/Purchase/Payload.ts","../../src/Purchase/Schema.ts","../../src/Receipt/Payload.ts","../../src/Receipt/Schema.ts","../../src/Subtotal/Diviner/Config.ts","../../src/Subtotal/Diviner/Payload.ts","../../src/Total/Diviner/Config.ts","../../src/Total/Diviner/Payload.ts"],"sourcesContent":["/* eslint-disable max-lines */\n/**\n * ISO 4217 currency codes\n */\nexport type Iso4217AlphabeticalCode =\n 'AED' |\n 'AFN' |\n 'ALL' |\n 'AMD' |\n 'ANG' |\n 'AOA' |\n 'ARS' |\n 'AUD' |\n 'AWG' |\n 'AZN' |\n 'BAM' |\n 'BBD' |\n 'BDT' |\n 'BGN' |\n 'BHD' |\n 'BIF' |\n 'BMD' |\n 'BND' |\n 'BOB' |\n 'BOV' |\n 'BRL' |\n 'BSD' |\n 'BTN' |\n 'BWP' |\n 'BYN' |\n 'BZD' |\n 'CAD' |\n 'CDF' |\n 'CHE' |\n 'CHF' |\n 'CHW' |\n 'CLF' |\n 'CLP' |\n 'CNY' |\n 'COP' |\n 'COU' |\n 'CRC' |\n 'CUP' |\n 'CVE' |\n 'CZK' |\n 'DJF' |\n 'DKK' |\n 'DOP' |\n 'DZD' |\n 'EGP' |\n 'ERN' |\n 'ETB' |\n 'EUR' |\n 'FJD' |\n 'FKP' |\n 'GBP' |\n 'GEL' |\n 'GHS' |\n 'GIP' |\n 'GMD' |\n 'GNF' |\n 'GTQ' |\n 'GYD' |\n 'HKD' |\n 'HNL' |\n 'HTG' |\n 'HUF' |\n 'IDR' |\n 'ILS' |\n 'INR' |\n 'IQD' |\n 'IRR' |\n 'ISK' |\n 'JMD' |\n 'JOD' |\n 'JPY' |\n 'KES' |\n 'KGS' |\n 'KHR' |\n 'KMF' |\n 'KPW' |\n 'KRW' |\n 'KWD' |\n 'KYD' |\n 'KZT' |\n 'LAK' |\n 'LBP' |\n 'LKR' |\n 'LRD' |\n 'LSL' |\n 'LYD' |\n 'MAD' |\n 'MDL' |\n 'MGA' |\n 'MKD' |\n 'MMK' |\n 'MNT' |\n 'MOP' |\n 'MRU' |\n 'MUR' |\n 'MVR' |\n 'MWK' |\n 'MXN' |\n 'MXV' |\n 'MYR' |\n 'MZN' |\n 'NAD' |\n 'NGN' |\n 'NIO' |\n 'NOK' |\n 'NPR' |\n 'NZD' |\n 'OMR' |\n 'PAB' |\n 'PEN' |\n 'PGK' |\n 'PHP' |\n 'PKR' |\n 'PLN' |\n 'PYG' |\n 'QAR' |\n 'RON' |\n 'RSD' |\n 'RUB' |\n 'RWF' |\n 'SAR' |\n 'SBD' |\n 'SCR' |\n 'SDG' |\n 'SEK' |\n 'SGD' |\n 'SHP' |\n 'SLE' |\n 'SOS' |\n 'SRD' |\n 'SSP' |\n 'STN' |\n 'SVC' |\n 'SYP' |\n 'SZL' |\n 'THB' |\n 'TJS' |\n 'TMT' |\n 'TND' |\n 'TOP' |\n 'TRY' |\n 'TTD' |\n 'TWD' |\n 'TZS' |\n 'UAH' |\n 'UGX' |\n 'USD' |\n 'USN' |\n 'UYI' |\n 'UYU' |\n 'UYW' |\n 'UZS' |\n 'VED' |\n 'VES' |\n 'VND' |\n 'VUV' |\n 'WST' |\n 'XAF' |\n 'XAG' |\n 'XAU' |\n 'XBA' |\n 'XBB' |\n 'XBC' |\n 'XBD' |\n 'XCD' |\n 'XDR' |\n 'XOF' |\n 'XPD' |\n 'XPF' |\n 'XPT' |\n 'XSU' |\n 'XTS' |\n 'XUA' |\n 'XXX' |\n 'YER' |\n 'ZAR' |\n 'ZMW' |\n 'ZWG' |\n 'ZWL'\n\n// TODO: Technically, the values should be 3 digit numbers with leading\n// zeros, so we can padStart if we need to be strict\n/**\n * ISO 4217 numeric currency number codes\n */\nexport type Iso4217NumericCode =\n 784 |\n 971 |\n 8 |\n 51 |\n 532 |\n 973 |\n 32 |\n 36 |\n 533 |\n 944 |\n 977 |\n 52 |\n 50 |\n 975 |\n 48 |\n 108 |\n 60 |\n 96 |\n 68 |\n 984 |\n 986 |\n 44 |\n 64 |\n 72 |\n 933 |\n 84 |\n 124 |\n 976 |\n 947 |\n 756 |\n 948 |\n 990 |\n 152 |\n 156 |\n 170 |\n 970 |\n 188 |\n 192 |\n 132 |\n 203 |\n 262 |\n 208 |\n 214 |\n 12 |\n 818 |\n 232 |\n 230 |\n 978 |\n 242 |\n 238 |\n 826 |\n 981 |\n 936 |\n 292 |\n 270 |\n 324 |\n 320 |\n 328 |\n 344 |\n 340 |\n 332 |\n 348 |\n 360 |\n 376 |\n 356 |\n 368 |\n 364 |\n 352 |\n 388 |\n 400 |\n 392 |\n 404 |\n 417 |\n 116 |\n 174 |\n 408 |\n 410 |\n 414 |\n 136 |\n 398 |\n 418 |\n 422 |\n 144 |\n 430 |\n 426 |\n 434 |\n 504 |\n 498 |\n 969 |\n 807 |\n 104 |\n 496 |\n 446 |\n 929 |\n 480 |\n 462 |\n 454 |\n 484 |\n 979 |\n 458 |\n 943 |\n 516 |\n 566 |\n 558 |\n 578 |\n 524 |\n 554 |\n 512 |\n 590 |\n 604 |\n 598 |\n 608 |\n 586 |\n 985 |\n 600 |\n 634 |\n 946 |\n 941 |\n 643 |\n 646 |\n 682 |\n 90 |\n 690 |\n 938 |\n 752 |\n 702 |\n 654 |\n 925 |\n 706 |\n 968 |\n 728 |\n 930 |\n 222 |\n 760 |\n 748 |\n 764 |\n 972 |\n 934 |\n 788 |\n 776 |\n 949 |\n 780 |\n 901 |\n 834 |\n 980 |\n 800 |\n 840 |\n 997 |\n 940 |\n 858 |\n 927 |\n 860 |\n 926 |\n 928 |\n 704 |\n 548 |\n 882 |\n 950 |\n 961 |\n 959 |\n 955 |\n 956 |\n 957 |\n 958 |\n 951 |\n 960 |\n 952 |\n 964 |\n 953 |\n 962 |\n 994 |\n 963 |\n 965 |\n 999 |\n 886 |\n 710 |\n 967 |\n 924 |\n 932\n\n/**\n * Dictionary of ISO 4217 alphabetical currency codes to numeric currency number codes\n */\nexport const Iso4217CurrencyCodes: Record<Iso4217AlphabeticalCode, Iso4217NumericCode> = {\n AED: 784,\n AFN: 971,\n ALL: 8,\n AMD: 51,\n ANG: 532,\n AOA: 973,\n ARS: 32,\n AUD: 36,\n AWG: 533,\n AZN: 944,\n BAM: 977,\n BBD: 52,\n BDT: 50,\n BGN: 975,\n BHD: 48,\n BIF: 108,\n BMD: 60,\n BND: 96,\n BOB: 68,\n BOV: 984,\n BRL: 986,\n BSD: 44,\n BTN: 64,\n BWP: 72,\n BYN: 933,\n BZD: 84,\n CAD: 124,\n CDF: 976,\n CHE: 947,\n CHF: 756,\n CHW: 948,\n CLF: 990,\n CLP: 152,\n CNY: 156,\n COP: 170,\n COU: 970,\n CRC: 188,\n CUP: 192,\n CVE: 132,\n CZK: 203,\n DJF: 262,\n DKK: 208,\n DOP: 214,\n DZD: 12,\n EGP: 818,\n ERN: 232,\n ETB: 230,\n EUR: 978,\n FJD: 242,\n FKP: 238,\n GBP: 826,\n GEL: 981,\n GHS: 936,\n GIP: 292,\n GMD: 270,\n GNF: 324,\n GTQ: 320,\n GYD: 328,\n HKD: 344,\n HNL: 340,\n HTG: 332,\n HUF: 348,\n IDR: 360,\n ILS: 376,\n INR: 356,\n IQD: 368,\n IRR: 364,\n ISK: 352,\n JMD: 388,\n JOD: 400,\n JPY: 392,\n KES: 404,\n KGS: 417,\n KHR: 116,\n KMF: 174,\n KPW: 408,\n KRW: 410,\n KWD: 414,\n KYD: 136,\n KZT: 398,\n LAK: 418,\n LBP: 422,\n LKR: 144,\n LRD: 430,\n LSL: 426,\n LYD: 434,\n MAD: 504,\n MDL: 498,\n MGA: 969,\n MKD: 807,\n MMK: 104,\n MNT: 496,\n MOP: 446,\n MRU: 929,\n MUR: 480,\n MVR: 462,\n MWK: 454,\n MXN: 484,\n MXV: 979,\n MYR: 458,\n MZN: 943,\n NAD: 516,\n NGN: 566,\n NIO: 558,\n NOK: 578,\n NPR: 524,\n NZD: 554,\n OMR: 512,\n PAB: 590,\n PEN: 604,\n PGK: 598,\n PHP: 608,\n PKR: 586,\n PLN: 985,\n PYG: 600,\n QAR: 634,\n RON: 946,\n RSD: 941,\n RUB: 643,\n RWF: 646,\n SAR: 682,\n SBD: 90,\n SCR: 690,\n SDG: 938,\n SEK: 752,\n SGD: 702,\n SHP: 654,\n SLE: 925,\n SOS: 706,\n SRD: 968,\n SSP: 728,\n STN: 930,\n SVC: 222,\n SYP: 760,\n SZL: 748,\n THB: 764,\n TJS: 972,\n TMT: 934,\n TND: 788,\n TOP: 776,\n TRY: 949,\n TTD: 780,\n TWD: 901,\n TZS: 834,\n UAH: 980,\n UGX: 800,\n USD: 840,\n USN: 997,\n UYI: 940,\n UYU: 858,\n UYW: 927,\n UZS: 860,\n VED: 926,\n VES: 928,\n VND: 704,\n VUV: 548,\n WST: 882,\n XAF: 950,\n XAG: 961,\n XAU: 959,\n XBA: 955,\n XBB: 956,\n XBC: 957,\n XBD: 958,\n XCD: 951,\n XDR: 960,\n XOF: 952,\n XPD: 964,\n XPF: 953,\n XPT: 962,\n XSU: 994,\n XTS: 963,\n XUA: 965,\n XXX: 999,\n YER: 886,\n ZAR: 710,\n ZMW: 967,\n ZWG: 924,\n ZWL: 932,\n}\n\nexport const isIso4217CurrencyCode = (code: string): code is Iso4217AlphabeticalCode => Iso4217CurrencyCodes[code as Iso4217AlphabeticalCode] ? true : false\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { Iso4217AlphabeticalCode } from './Iso4217Currency.ts'\n\nexport const AmountSchema = 'network.xyo.payments.amount' as const\nexport type AmountSchema = typeof AmountSchema\n\nexport interface AmountFields {\n amount: number\n currency: Iso4217AlphabeticalCode\n}\n\n/**\n * The result of a amount\n */\nexport type Amount = PayloadWithSources<AmountFields, AmountSchema>\n\n/**\n * Identity function for determining if an object is an Amount\n */\nexport const isAmount = isPayloadOfSchemaType<Amount>(AmountSchema)\n\n/**\n * Identity function for determining if an object is an Amount with sources\n */\nexport const isAmountWithSources = isPayloadOfSchemaTypeWithSources<Amount>(AmountSchema)\n\n/**\n * Identity function for determining if an object is an Amount with meta\n */\nexport const isAmountWithMeta = isPayloadOfSchemaTypeWithMeta<Amount>(AmountSchema)\n","import type { Payload } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { BillingAddressSchema } from './Schema.ts'\n\n/**\n * The fields describing a billing address.\n */\nexport interface BillingAddressFields {\n /** Street address line 1. */\n address?: string\n /** Street address line 2. */\n address2?: string | null\n /** City of the billing address. */\n city?: string\n /** Country code of the billing address, ISO 3166-1 alpha-2 code. */\n country?: string\n /** First name */\n firstName: string\n /** Last name */\n lastName: string\n /** Organization or company name associated with the billing address. */\n organization?: string | null\n /** Postal or ZIP code of the billing address. */\n postalCode?: string\n /** State or region of the billing address. */\n region?: string\n}\n\n/**\n * A BillingAddress Payload\n */\nexport type BillingAddress = Payload<BillingAddressFields, BillingAddressSchema>\n\n/**\n * Identity function for determine if an object is a BillingAddress\n */\nexport const isBillingAddress = isPayloadOfSchemaType<BillingAddress>(BillingAddressSchema)\n\n/**\n * Identity function for determine if an object is a BillingAddress with sources\n */\nexport const isBillingAddressWithSources = isPayloadOfSchemaTypeWithSources<BillingAddress>(BillingAddressSchema)\n\n/**\n * Identity function for determine if an object is a BillingAddress with meta\n */\nexport const isBillingAddressWithMeta = isPayloadOfSchemaTypeWithMeta<BillingAddress>(BillingAddressSchema)\n","export const PaymentsSchema = 'network.xyo.payments'\nexport type PaymentsSchema = typeof PaymentsSchema\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const BillingSchema = `${PaymentsSchema}.billing`\nexport type BillingSchema = typeof BillingSchema\n","import { BillingSchema } from '../Schema.ts'\n\nexport const BillingAddressSchema = `${BillingSchema}.address`\nexport type BillingAddressSchema = typeof BillingAddressSchema\n","// import type { Hash } from '@xylabs/hex'\nimport type { Address } from '@xylabs/hex'\nimport type { DivinerConfig } from '@xyo-network/diviner-model'\nimport type { ModuleIdentifier } from '@xyo-network/module-model'\n\nexport const PaymentDiscountDivinerConfigSchema = 'network.xyo.diviner.payments.discount.config'\nexport type PaymentDiscountDivinerConfigSchema = typeof PaymentDiscountDivinerConfigSchema\n\n/**\n * The configuration for the Payment Discount Diviner\n */\nexport type PaymentDiscountDivinerConfig = DivinerConfig<\n {\n /**\n * The boundwitness diviner used to query for payloads\n */\n boundWitnessDiviner?: ModuleIdentifier\n /**\n * The list of coupon authorities that can be used to get a discount\n */\n couponAuthorities?: Address[]\n\n // /**\n // * The list of coupons that are supported by this diviner\n // */\n // supportedCoupons?: Hash[]\n\n /**\n * The Diviner that can be used to determine the subtotal to apply discounts to\n */\n paymentSubtotalDiviner?: ModuleIdentifier\n },\n PaymentDiscountDivinerConfigSchema\n>\n","/* eslint-disable unicorn/no-thenable */\nimport { SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type { Condition } from '../types/index.ts'\n\n/**\n * Creates a coupon condition that requires an appraisal amount below a certain value\n * @param maximumAppraisalAmount The maximum appraisal amount\n * @returns A condition that requires an appraisal amount below a certain value\n */\nexport const createConditionForMaximumAppraisalAmount = (maximumAppraisalAmount: number): Condition => {\n return {\n schema: SchemaSchema,\n definition: {\n allOf: [\n {\n type: 'array',\n contains: {\n type: 'object',\n properties: {\n schema: { type: 'string', const: 'network.xyo.escrow.terms' },\n appraisals: { type: 'array', minItems: 1 },\n },\n required: ['schema', 'appraisals'],\n },\n },\n {\n type: 'array',\n contains: {\n type: 'object',\n properties: { schema: { type: 'string', const: 'network.xyo.hash.lease.estimate' } },\n required: ['schema'],\n },\n items: {\n type: 'object',\n if: { properties: { schema: { type: 'string', const: 'network.xyo.hash.lease.estimate' } } },\n then: { properties: { price: { type: 'number', maximum: maximumAppraisalAmount } }, required: ['price'] },\n },\n },\n ],\n },\n }\n}\n","import { SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type { Condition } from '../types/index.ts'\n\n/**\n * Returns a coupon condition that requires a minimum quantity of assets\n * @param minimumAssetQuantity The minimum quantity of assets required\n * @returns A condition that requires a minimum quantity of assets\n */\nexport const createConditionForMinimumAssetQuantity = (minimumAssetQuantity: number): Condition => {\n return {\n schema: SchemaSchema,\n definition: {\n type: 'array',\n contains: {\n type: 'object',\n properties: {\n schema: { type: 'string', const: 'network.xyo.escrow.terms' },\n assets: { type: 'array', minItems: minimumAssetQuantity },\n },\n required: ['schema', 'assets'],\n },\n },\n }\n}\n","import type { Address } from '@xylabs/hex'\nimport { SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type { Condition } from '../types/index.ts'\n\nexport type BuyerCondition = Condition & {\n definition: {\n contains: {\n properties: {\n buyer: {\n items: {\n const: Address\n type: 'string'\n }\n minItems: 1\n type: 'array'\n }\n schema: { const: 'network.xyo.escrow.terms'; type: 'string' }\n }\n required: ['schema', 'buyer']\n type: 'object'\n }\n type: 'array'\n }\n schema: SchemaSchema\n}\n\n/**\n * Creates a coupon condition that requires a specific buyer\n * @param buyer The buyer's address\n * @returns A coupon condition that requires a specific buyer\n */\nexport const createConditionForRequiredBuyer = (buyer: Address): BuyerCondition => {\n return {\n schema: SchemaSchema,\n definition: {\n type: 'array',\n contains: {\n type: 'object',\n properties: {\n schema: { type: 'string', const: 'network.xyo.escrow.terms' },\n buyer: {\n type: 'array', items: { type: 'string', const: buyer }, minItems: 1,\n },\n },\n required: ['schema', 'buyer'],\n },\n },\n }\n}\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../../../Amount/index.ts'\nimport { CouponSchema } from '../Schema.ts'\nimport type { CouponFields } from '../types/index.ts'\n\nexport const FixedAmountCouponSchema = `${CouponSchema}.fixed.amount` as const\nexport type FixedAmountCouponSchema = typeof FixedAmountCouponSchema\n\nexport interface FixedAmountCouponFields extends CouponFields, AmountFields {}\n\n/**\n * A coupon that provides a fixed discount amount\n */\nexport type FixedAmountCoupon = PayloadWithSources<FixedAmountCouponFields, FixedAmountCouponSchema>\n\n/**\n * Identity function for determining if an object is an FixedAmountCoupon\n */\nexport const isFixedAmountCoupon = isPayloadOfSchemaType<FixedAmountCoupon>(FixedAmountCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedAmountCoupon with sources\n */\nexport const isFixedAmountCouponWithSources = isPayloadOfSchemaTypeWithSources<FixedAmountCoupon>(FixedAmountCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedAmountCoupon with meta\n */\nexport const isFixedAmountCouponWithMeta = isPayloadOfSchemaTypeWithMeta<FixedAmountCoupon>(FixedAmountCouponSchema)\n","export const CouponSchema = 'network.xyo.payments.coupon' as const\nexport type CouponSchema = typeof CouponSchema\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { CouponSchema } from '../Schema.ts'\nimport type { CouponFields } from '../types/index.ts'\n\nexport const FixedPercentageCouponSchema = `${CouponSchema}.fixed.percentage` as const\nexport type FixedPercentageCouponSchema = typeof FixedPercentageCouponSchema\n\nexport interface FixedPercentageCouponFields extends CouponFields {\n percentage: number\n}\n\n/**\n * A coupon that provides a fixed discount amount\n */\nexport type FixedPercentageCoupon = PayloadWithSources<FixedPercentageCouponFields, FixedPercentageCouponSchema>\n\n/**\n * Identity function for determining if an object is an FixedPercentageCoupon\n */\nexport const isFixedPercentageCoupon = isPayloadOfSchemaType<FixedPercentageCoupon>(FixedPercentageCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPercentageCoupon with sources\n */\nexport const isFixedPercentageCouponWithSources = isPayloadOfSchemaTypeWithSources<FixedPercentageCoupon>(FixedPercentageCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPercentageCoupon with meta\n */\nexport const isFixedPercentageCouponWithMeta = isPayloadOfSchemaTypeWithMeta<FixedPercentageCoupon>(FixedPercentageCouponSchema)\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../../../Amount/index.ts'\nimport { CouponSchema } from '../Schema.ts'\nimport type { CouponFields } from '../types/index.ts'\n\nexport const FixedPriceCouponSchema = `${CouponSchema}.fixed.price` as const\nexport type FixedPriceCouponSchema = typeof FixedPriceCouponSchema\n\nexport interface FixedPriceCouponFields extends CouponFields, AmountFields { }\n\n/**\n * A coupon that provides a fixed total price\n */\nexport type FixedPriceCoupon = PayloadWithSources<FixedPriceCouponFields, FixedPriceCouponSchema>\n\n/**\n * Identity function for determining if an object is an FixedPriceCoupon\n */\nexport const isFixedPriceCoupon = isPayloadOfSchemaType<FixedPriceCoupon>(FixedPriceCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPriceCoupon with sources\n */\nexport const isFixedPriceCouponWithSources = isPayloadOfSchemaTypeWithSources<FixedPriceCoupon>(FixedPriceCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPriceCoupon with meta\n */\nexport const isFixedPriceCouponWithMeta = isPayloadOfSchemaTypeWithMeta<FixedPriceCoupon>(FixedPriceCouponSchema)\n","import {\n type FixedAmountCoupon, type FixedPercentageCoupon, type FixedPriceCoupon,\n isFixedAmountCoupon, isFixedAmountCouponWithMeta, isFixedAmountCouponWithSources, isFixedPercentageCoupon,\n isFixedPercentageCouponWithMeta,\n isFixedPercentageCouponWithSources,\n isFixedPriceCoupon,\n isFixedPriceCouponWithSources,\n} from './Coupons/index.ts'\n\n/**\n * The type of coupons\n */\nexport type Coupon =\n FixedAmountCoupon\n | FixedPercentageCoupon\n | FixedPriceCoupon\n\n/**\n * Identity function for determining if an object is an Coupon\n */\nexport const isCoupon = (x?: unknown | null) =>\n isFixedAmountCoupon(x)\n || isFixedPercentageCoupon(x)\n || isFixedPriceCoupon(x)\n\n/**\n * Identity function for determining if an object is an Coupon with sources\n */\nexport const isCouponWithSources = (x?: unknown | null) =>\n isFixedAmountCouponWithSources(x)\n || isFixedPercentageCouponWithSources(x)\n || isFixedPriceCouponWithSources(x)\n\n/**\n * Identity function for determining if an object is an Coupon with meta\n */\nexport const isCouponWithMeta = (x?: unknown | null) =>\n isFixedAmountCouponWithMeta(x)\n || isFixedPercentageCouponWithMeta(x)\n","import {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources, type WithMeta, type WithOptionalMeta,\n} from '@xyo-network/payload-model'\nimport { type SchemaPayload, SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\n/**\n * The payloads that can be used as conditions for a coupon\n */\nexport type Condition = SchemaPayload | WithOptionalMeta<SchemaPayload> | WithMeta<SchemaPayload>\n\n/**\n * Identity function for determining if an object is a Condition payload\n */\nexport const isCondition = isPayloadOfSchemaType<Condition>(SchemaSchema)\n\n/**\n * Identity function for determining if an object is a Condition payload with sources\n */\nexport const isConditionWithSources = isPayloadOfSchemaTypeWithSources<Condition>(SchemaSchema)\n\n/**\n * Identity function for determining if an object is a Condition payload with meta\n */\nexport const isConditionWithMeta = isPayloadOfSchemaTypeWithMeta<Condition>(SchemaSchema)\n","import type { CouponFields } from './CouponFields.ts'\n\n/**\n * Identity function for determining if coupon is stackable\n */\nexport const isStackable = (x?: unknown | null) => (x as CouponFields ?? { stackable: false })?.stackable\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../Amount/index.ts'\n\nexport const DiscountSchema = 'network.xyo.payments.discount' as const\nexport type DiscountSchema = typeof DiscountSchema\n\nexport interface DiscountFields extends AmountFields { }\n\n/**\n * The result of a discount\n */\nexport type Discount = PayloadWithSources<DiscountFields, DiscountSchema>\n\n/**\n * Identity function for determining if an object is an Discount\n */\nexport const isDiscount = isPayloadOfSchemaType<Discount>(DiscountSchema)\n\n/**\n * Identity function for determining if an object is an Discount with sources\n */\nexport const isDiscountWithSources = isPayloadOfSchemaTypeWithSources<Discount>(DiscountSchema)\n\n/**\n * Identity function for determining if an object is an Discount with meta\n */\nexport const isDiscountWithMeta = isPayloadOfSchemaTypeWithMeta<Discount>(DiscountSchema)\n","import type { Discount } from './Discount.ts'\nimport { DiscountSchema } from './Discount.ts'\n\nexport const NO_DISCOUNT: Discount = {\n schema: DiscountSchema,\n amount: 0,\n currency: 'USD',\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { EscrowSchema } from './Schema.ts'\n\nexport const EscrowOutcomeSchema = `${EscrowSchema}.outcome` as const\nexport type EscrowOutcomeSchema = typeof EscrowOutcomeSchema\n\n/**\n * The possible outcomes for an escrow\n */\nexport type EscrowOutcomes = 'fulfilled' | 'expired' // TODO: More outcomes\n\nexport interface EscrowOutcomeFields {\n outcome: EscrowOutcomes\n terms: Hash\n}\n\n/**\n * The terms of an escrow\n */\nexport type EscrowOutcome = PayloadWithSources<EscrowOutcomeFields, EscrowOutcomeSchema>\n\n/**\n * Identity function for determining if an object is an EscrowOutcome\n */\nexport const isEscrowOutcome = isPayloadOfSchemaType<EscrowOutcome>(EscrowOutcomeSchema)\n\n/**\n * Identity function for determining if an object is an EscrowOutcome with sources\n */\nexport const isEscrowOutcomeWithSources = isPayloadOfSchemaTypeWithSources<EscrowOutcome>(EscrowOutcomeSchema)\n\n/**\n * Identity function for determining if an object is an EscrowOutcome with meta\n */\nexport const isEscrowOutcomeWithMeta = isPayloadOfSchemaTypeWithMeta<EscrowOutcome>(EscrowOutcomeSchema)\n","export const EscrowSchema = 'network.xyo.escrow'\nexport type EscrowSchema = typeof EscrowSchema\n","import type { Address, Hash } from '@xylabs/hex'\nimport type { Payload } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { EscrowSchema } from '../Schema.ts'\n\nexport const EscrowTermsSchema = `${EscrowSchema}.terms` as const\nexport type EscrowTermsSchema = typeof EscrowTermsSchema\n\n// TODO: Include escrow agent in escrow terms\nexport interface EscrowTermsFields {\n /**\n * The trusted estimators for the worth of the things being sold\n */\n appraisalAuthorities: Address[]\n /**\n * The estimated worths of the things being sold\n */\n appraisals: Hash[]\n /**\n * The things being sold\n */\n assets: Hash[]\n /**\n * The buyer\n */\n buyer: Address[]\n /**\n * The buyer\n */\n buyerSecret: Hash\n /**\n * Any discounts (coupons, vouchers, credits, etc.) to be applied to the escrow\n */\n discounts: Hash[]\n /**\n * The escrow agent responsible for the escrow\n */\n escrowAgent: Address\n /**\n * The time the escrow expires\n */\n exp: number\n /**\n * The time the escrow starts\n */\n nbf: number\n /**\n * The trusted payment authorities\n */\n paymentAuthorities: Address[]\n /**\n * The seller\n */\n seller: Address[]\n /**\n * The seller\n */\n sellerSecret: Hash\n}\n\n/**\n * The terms of an escrow\n */\nexport type EscrowTerms = Payload<Partial<EscrowTermsFields>, EscrowTermsSchema>\n\n/**\n * Identity function for determining if an object is an EscrowTerms\n */\nexport const isEscrowTerms = isPayloadOfSchemaType<EscrowTerms>(EscrowTermsSchema)\n\n/**\n * Identity function for determining if an object is an EscrowTerms with sources\n */\nexport const isEscrowTermsWithSources = isPayloadOfSchemaTypeWithSources<EscrowTerms>(EscrowTermsSchema)\n\n/**\n * Identity function for determining if an object is an EscrowTerms with meta\n */\nexport const isEscrowTermsWithMeta = isPayloadOfSchemaTypeWithMeta<EscrowTerms>(EscrowTermsSchema)\n","import type { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport type { IdPayload } from '@xyo-network/id-payload-plugin'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\n/**\n * Creates an escrow intent (for a buyer or seller) using the supplied secret\n * @param terms The payload describing the terms for the escrow\n * @param secret The secret for the escrow principal party to use for the escrow\n * @param account The account to create the escrow intent with\n * @returns The escrow intent\n */\nexport const createEscrowIntentWithSecret = async (terms: EscrowTerms, secret: IdPayload, account: AccountInstance) => {\n const result = await new BoundWitnessBuilder({ accounts: [account] }).payloads([terms, secret]).build()\n return result\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport type { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport type {\n EscrowParty, EscrowPartySecret, EscrowTerms,\n} from '../../Terms/index.ts'\n/**\n * Returns the log prefix for the party\n * @param party The party\n * @returns The log prefix for the party\n */\nconst getLogPrefix = (party: EscrowParty) => {\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n return `EscrowTerms.${partySecret}`\n}\n\n/**\n * Returns an array of BoundWitnesses containing the secret signed by all the parties\n * @param terms The escrow terms\n * @param dictionary A dictionary of all the payloads associated with the escrow\n * @param party The party to get the secret signatures for\n * @returns An array of BoundWitnesses containing the secret signed by all the parties\n */\nexport const findEscrowPartySecretSignatures = (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>, party: EscrowParty): BoundWitness[] => {\n const partyAddresses = terms[party]\n if (partyAddresses === undefined || partyAddresses.length === 0) {\n console.log(`${getLogPrefix(party)}: No ${party}: ${terms[party]}`)\n return []\n }\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n const secretHash = terms[partySecret]\n if (secretHash === undefined) {\n console.log(`${getLogPrefix(party)}: No ${partySecret}: ${terms[partySecret]}`)\n return []\n }\n // BWs containing the secret signed by all the parties\n const partySignedBWs = Object.values(dictionary)\n // Find all BoundWitnesses\n .filter(isBoundWitnessWithMeta)\n // That contain the seller secret\n .filter(bw => bw.payload_hashes.includes(secretHash))\n // That are signed by all the parties\n .filter(bw => partyAddresses.every(address => bw.addresses.includes(address)))\n return partySignedBWs\n}\n","import { Crypto } from '@xylabs/crypto'\nimport type { IdPayload } from '@xyo-network/id-payload-plugin'\nimport { IdSchema } from '@xyo-network/id-payload-plugin'\n\n/**\n * Returns a cryptographically random secret to use for escrow\n * @returns The escrow secret\n */\nexport const getEscrowSecret = (): IdPayload => {\n return { salt: Crypto.randomUUID(), schema: IdSchema }\n}\n","import type { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport type { IdPayload } from '@xyo-network/id-payload-plugin'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\n\nimport type {\n EscrowParty, EscrowPartySecret, EscrowTerms,\n} from '../../Terms/index.ts'\nimport { getEscrowSecret } from './getEscrowSecret.ts'\n\n/**\n * Creates an escrow intent (for a buyer or seller) using the supplied secret\n * @param terms The payload describing the terms for the escrow\n * @param escrowParty The party in the escrow transaction\n * @param account The account(s) to create the escrow intent with\n * @param secret The secret for the escrow principal party to use for the escrow. If\n * not provided, a cryptographically random secret will be generated.\n * @returns The escrow intent\n */\nexport const updateEscrowTermsWithSecret = async (\n terms: EscrowTerms,\n escrowParty: EscrowParty,\n account: AccountInstance | AccountInstance[],\n secret?: IdPayload,\n) => {\n if (!secret) secret = getEscrowSecret()\n const signers = Array.isArray(account) ? account : [account]\n // Add party addresses to escrow terms\n terms[escrowParty] = signers.map(signer => signer.address)\n // Add secret hash to terms\n const secretType: EscrowPartySecret = escrowParty === 'buyer' ? 'buyerSecret' : 'sellerSecret'\n const secretHash = await PayloadBuilder.dataHash(secret)\n terms[secretType] = secretHash\n // Have the parties sign the secret and terms\n const result = await new BoundWitnessBuilder().signers(signers).payloads([terms, secret]).build()\n return result\n}\n","import type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { PayloadValueExpression } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../../Terms/index.ts'\n\n/**\n * Checks if property value of the escrow terms contains one of the valid moduleIdentifiers\n * @param escrowTerms The escrow terms to validate\n * @param propertyExpression The selector to get the property containing the moduleIdentifier(s) from the escrow terms\n * @param moduleIdentifiers The list of allowed moduleIdentifiers\n * @param required Is the property required to be present\n * @returns True if the property value contains one of the valid moduleIdentifiers\n */\nexport const moduleIdentifiersContainsOneOf = (\n escrowTerms: EscrowTerms,\n propertyExpression: PayloadValueExpression<EscrowTerms, 'appraisalAuthorities' | 'buyer' | 'escrowAgent' | 'paymentAuthorities' | 'seller'>,\n moduleIdentifiers: ModuleIdentifier[],\n required: boolean = true,\n) => {\n const termsValue: string | string[] | undefined = propertyExpression(escrowTerms)\n if (termsValue === undefined) {\n return required ? false : true\n } else {\n return Array.isArray(termsValue) ? termsValue.some(address => moduleIdentifiers.includes(address)) : moduleIdentifiers.includes(termsValue)\n }\n}\n\n/**\n * Checks if property value of the escrow terms contains all of the valid moduleIdentifiers\n * @param escrowTerms The escrow terms to validate\n * @param selector The selector to get the property containing the moduleIdentifier(s) from the escrow terms\n * @param moduleIdentifiers The list of allowed moduleIdentifiers\n * @param required Is the property required to be present\n * @returns True if the property value contains all of the valid moduleIdentifiers\n */\nexport const moduleIdentifiersContainsAllOf = (\n escrowTerms: EscrowTerms,\n selector: PayloadValueExpression<EscrowTerms, 'appraisalAuthorities' | 'buyer' | 'escrowAgent' | 'paymentAuthorities' | 'seller'>,\n moduleIdentifiers: ModuleIdentifier[],\n required: boolean = true,\n) => {\n const termsValue: string | string[] | undefined = selector(escrowTerms)\n if (termsValue === undefined) {\n return required ? false : true\n } else {\n return Array.isArray(termsValue) ? termsValue.every(address => moduleIdentifiers.includes(address)) : moduleIdentifiers.includes(termsValue)\n }\n}\n","import type { Hash } from '@xylabs/hex'\nimport { BoundWitnessValidator } from '@xyo-network/boundwitness-validator'\nimport type {\n AsyncPayloadValidationFunction, Payload, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport type {\n EscrowParty, EscrowPartySecret, EscrowTerms,\n} from '../../../Terms/index.ts'\nimport { findEscrowPartySecretSignatures } from '../../../util/index.ts'\n\n/**\n * Returns the log prefix for the party\n * @param party The party\n * @returns The log prefix for the party\n */\nconst getLogPrefix = (party: EscrowParty) => {\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n return `EscrowTerms.${partySecret}`\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the party secret signed by the party\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the party secret signed by the party\n */\nexport const getPartySecretSignedValidator = (dictionary: Record<Hash, WithMeta<Payload>>, party: EscrowParty): AsyncPayloadValidationFunction<EscrowTerms> => {\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n return async (terms: EscrowTerms): Promise<boolean> => {\n // Party-signed party secret BWs\n const buyerSecretBWs = findEscrowPartySecretSignatures(terms, dictionary, party)\n\n // If there are no BWs, return false\n if (buyerSecretBWs.length === 0) {\n console.log(`${getLogPrefix(party)}: No BoundWitnesses supplied for ${partySecret}: ${terms[partySecret]}`)\n return false\n }\n\n // Ensure each BW supplied for the party secret is valid\n const errors = await Promise.all(buyerSecretBWs.map(bw => new BoundWitnessValidator(bw).validate()))\n const validBoundWitnesses = errors.every(errors => errors.length === 0)\n if (!validBoundWitnesses) {\n console.log(`${getLogPrefix(party)}: Invalid BoundWitnesses supplied for ${partySecret}: ${terms[partySecret]}`)\n return false\n }\n return true\n }\n}\n","export type Windowed = { exp?: number; nbf?: number }\n\nexport const validateWithinWindow = (value: Windowed, exp: number, nbf: number = Date.now()): boolean => {\n if (value.nbf === undefined || value.nbf > nbf) return false\n if (value.exp === undefined || value.exp < exp) return false\n return true\n}\n","import type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { moduleIdentifiersContainsOneOf } from '../common/index.ts'\n\nconst name = 'EscrowTerms.escrowAgent'\n\nexport const getEscrowAgentAllowedValidator = (allowedEscrowAgent: ModuleIdentifier): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const result = moduleIdentifiersContainsOneOf(terms, t => t.escrowAgent, [allowedEscrowAgent], true)\n if (!result) {\n console.log(`${name}: Escrow agent not allowed: ${terms.escrowAgent}`)\n }\n return result\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport type { HashLeaseEstimate } from '@xyo-network/diviner-hash-lease'\nimport { isHashLeaseEstimateWithSources } from '@xyo-network/diviner-hash-lease'\nimport type {\n Payload, SyncPayloadValidationFunction, WithMeta, WithSources,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { validateWithinWindow } from '../common/index.ts'\n\nconst name = 'EscrowTerms.appraisal'\n\n/**\n * A function that validates the escrow terms for tbe existence of appraisals\n * @returns True if the escrow terms contain appraisals, false otherwise\n */\nexport const appraisalsExistValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have appraisals\n const appraisals = terms.appraisals\n if (!appraisals || appraisals.length === 0) {\n console.log(`${name}: No appraisals: ${terms.appraisals}`)\n return false\n }\n return true\n}\n\n/**\n * Returns a function that validates the escrow terms for appraisals which are from valid authorities\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for appraisals which are from valid authorities\n */\nexport const getAppraisalsFromValidAuthoritiesValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const appraisals = assertEx(terms.appraisals, () => `${name}: No appraisals: ${terms.appraisals}`)\n const appraisalAuthorities = assertEx(terms.appraisalAuthorities, () => `${name}: No appraisalAuthorities: ${terms.appraisalAuthorities}`)\n\n // Validate the appraisals are signed by valid appraisal authorities. Validation criteria:\n // - We have a bw for each of the appraisal\n // - The bw is signed by an approved appraisal authority\n const appraisalBWsValid: Record<Hash, WithMeta<BoundWitness>[]> = Object.fromEntries(\n appraisals.map<[Hash, WithMeta<BoundWitness>[]]>(hash => [hash, []]),\n )\n for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta)) {\n for (const appraisal of appraisals) {\n if (bw.payload_hashes.includes(appraisal) && bw.addresses.some(address => appraisalAuthorities.includes(address))) {\n appraisalBWsValid[appraisal].push(bw)\n }\n }\n }\n for (const [appraisal, bws] of Object.entries(appraisalBWsValid)) {\n if (bws.length === 0) {\n console.log(`${name}: No valid appraisals for ${appraisal}`)\n return false\n }\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms for appraisals which are valid\n * @param dictionary Payload dictionary of the escrow terms\n * @param minimumExp The minium amount of time an estimate needs to be valid\n * for in the future (so as not to expire before the escrow is complete)\n * @returns A function that validates the escrow terms for appraisals which are valid\n */\nexport const getAppraisalsValidValidator = (\n dictionary: Record<Hash, WithMeta<Payload>>,\n minimumExp: number,\n): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n // Verify we have an estimate for each of the assets\n const estimatesByAsset = getEstimatesByAsset(terms, dictionary)\n // Validate each of the estimates are valid (time, price, etc)\n const now = Date.now()\n const exp = now + minimumExp\n for (const [asset, estimates] of Object.entries(estimatesByAsset)) {\n for (const estimate of estimates) {\n if (!validateEstimate(estimate, exp)) {\n console.log(`${name}: Invalid estimate for asset ${asset}: ${estimate}`)\n return false\n }\n }\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms to ensure that they contain an appraisal for each asset\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for appraisals\n */\nexport const getAppraisalsForAllAssetsValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n // Verify we have an estimate for each of the assets\n const estimatesByAsset = getEstimatesByAsset(terms, dictionary)\n const assets = assertEx(terms.assets, () => `${name}: No assets: ${terms.assets}`)\n if (Object.keys(estimatesByAsset).length !== assets.length) {\n console.log(`${name}: Missing appraisals for all assets: ${assets}`)\n return false\n }\n return true\n }\n}\n\nconst validateEstimate = (estimate: WithSources<HashLeaseEstimate>, exp: number): boolean => {\n if (!validateWithinWindow(estimate, exp)) return false\n if (estimate.currency !== 'USD') return false\n if (estimate.price < 0) return false\n return true\n}\n\nconst getEstimatesByAsset = (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>): Record<Hash, WithSources<HashLeaseEstimate>[]> => {\n const assets = assertEx(terms.assets, () => `${name}: No assets: ${terms.assets}`)\n const estimates = Object.values(dictionary).filter(isHashLeaseEstimateWithSources) as unknown as WithSources<HashLeaseEstimate>[]\n const estimatesByAsset: Record<Hash, WithSources<HashLeaseEstimate>[]> = {}\n for (const estimate of estimates) {\n const { sources } = estimate\n if (sources === undefined || sources.length === 0) {\n console.log(`${name}: No sources: ${estimate}`)\n continue\n }\n for (const asset of assets) {\n if (sources.includes(asset)) {\n if (!estimatesByAsset[asset]) estimatesByAsset[asset] = []\n estimatesByAsset[asset].push(estimate)\n }\n }\n }\n return estimatesByAsset\n}\n","import { asAddress } from '@xylabs/hex'\nimport type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { moduleIdentifiersContainsAllOf } from '../common/index.ts'\n\nconst name = 'EscrowTerms.appraisalAuthorities'\n\n/**\n * A function that validates the escrow terms for appraisalAuthorities\n * @returns True if the escrow terms contain appraisalAuthorities, false otherwise\n */\nexport const appraisalAuthoritiesExistValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have appraisalAuthorities\n const appraisalAuthorities = terms.appraisalAuthorities\n if (!appraisalAuthorities || appraisalAuthorities.length === 0) {\n console.log(`${name}: No appraisalAuthorities: ${terms.appraisalAuthorities}`)\n return false\n }\n // Validate the authorities are addresses\n if (appraisalAuthorities.map(x => asAddress(x)).length !== appraisalAuthorities.length) {\n console.log(`${name}: Invalid address: ${terms.appraisalAuthorities}`)\n return false\n }\n return true\n}\n\nexport const getAppraisalAuthoritiesAllowedValidator = (allowed: ModuleIdentifier[]): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const result = moduleIdentifiersContainsAllOf(terms, t => t.appraisalAuthorities, allowed, true)\n if (!result) {\n console.log(`${name}: Appraisal authority not allowed: ${terms.appraisalAuthorities}`)\n }\n return result\n }\n}\n","import type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nconst name = 'EscrowTerms.assets'\n\n/**\n * Returns a function that validates the escrow terms for assets\n * @returns A function that validates the escrow terms for assets\n */\nexport const assetsExistValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have assets\n const assets = terms.assets\n if (!assets || assets.length === 0) {\n console.log(`${name}: No assets: ${terms.assets}`)\n return false\n }\n return true\n}\n","import { asAddress } from '@xylabs/hex'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nconst name = 'EscrowTerms.buyer'\n\n/**\n * A function that validates the escrow terms for buyer\n * @returns True if the escrow terms contain buyer, false otherwise\n */\nexport const buyerExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have buyer\n const buyer = terms.buyer\n if (!buyer || buyer.length === 0) {\n console.log(`${name}: No buyer: ${terms.buyer}`)\n return false\n }\n // Validate the authorities are addresses\n if (buyer.map(x => asAddress(x)).length !== buyer.length) {\n console.log(`${name}: Invalid address: ${terms.buyer}`)\n return false\n }\n return true\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type {\n AsyncPayloadValidationFunction, Payload, SyncPayloadValidationFunction, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { getPartySecretSignedValidator } from '../common/index.ts'\n\nconst name = 'EscrowTerms.buyerSecret'\n\n/**\n * Returns a function that validates the escrow terms for buyerSecret\n * @returns A function that validates the escrow terms for buyerSecret\n */\nexport const buyerSecretExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have buyerSecret\n const buyerSecret = terms.buyerSecret\n if (!buyerSecret || buyerSecret.length === 0) {\n console.log(`${name}: No buyerSecret: ${terms.buyerSecret}`)\n return false\n }\n return true\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the buyerSecret in the dictionary\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the buyerSecret in the dictionary\n */\nexport const getBuyerSecretSuppliedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const buyerSecret = assertEx(terms.buyerSecret, () => `${name}: No buyerSecret: ${terms.buyerSecret}`)\n if (!dictionary[buyerSecret]) {\n console.log(`${name}: Payload not supplied for buyerSecret: ${buyerSecret}`)\n return false\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the buyerSecret signed by the buyer\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the buyerSecret signed by the buyer\n */\nexport const getBuyerSecretSignedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): AsyncPayloadValidationFunction<EscrowTerms> => {\n return getPartySecretSignedValidator(dictionary, 'buyer')\n}\n","import type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nexport const getNbfExpValidator = (now: number, minRequiredDuration: number): SyncPayloadValidationFunction<EscrowTerms> => {\n const minExp = now + minRequiredDuration\n return (terms: EscrowTerms) => {\n const { exp, nbf } = terms\n if (nbf === undefined || nbf < now) {\n console.log(`EscrowTerms.nbf: invalid nbf ${terms.nbf}`)\n return false\n }\n if (exp === undefined || exp < minExp || nbf > exp) {\n console.log(`EscrowTerms.exp: invalid exp ${terms.exp}`)\n return false\n }\n return true\n }\n}\n","import type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { moduleIdentifiersContainsAllOf } from '../common/index.ts'\n\nconst name = 'EscrowTerms.paymentAuthorities'\n\nexport const getPaymentAuthoritiesAllowedValidator = (allowed: ModuleIdentifier[]): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const result = moduleIdentifiersContainsAllOf(terms, t => t.paymentAuthorities, allowed, true)\n if (!result) {\n console.log(`${name}: Payment authority not allowed: ${terms.paymentAuthorities}`)\n }\n return result\n }\n}\n","import { asAddress } from '@xylabs/hex'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nconst name = 'EscrowTerms.seller'\n\n/**\n * A function that validates the escrow terms for seller\n * @returns True if the escrow terms contain seller, false otherwise\n */\nexport const sellerExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have seller\n const seller = terms.seller\n if (!seller || seller.length === 0) {\n console.log(`${name}: No seller: ${terms.seller}`)\n return false\n }\n // Validate the authorities are addresses\n if (seller.map(x => asAddress(x)).length !== seller.length) {\n console.log(`${name}: Invalid address: ${terms.seller}`)\n return false\n }\n return true\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type {\n AsyncPayloadValidationFunction, Payload, SyncPayloadValidationFunction, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { getPartySecretSignedValidator } from '../common/index.ts'\n\nconst name = 'EscrowTerms.sellerSecret'\n\n/**\n * Returns a function that validates the escrow terms for sellerSecret\n * @returns A function that validates the escrow terms for sellerSecret\n */\nexport const sellerSecretExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have sellerSecret\n const sellerSecret = terms.sellerSecret\n if (!sellerSecret || sellerSecret.length === 0) {\n console.log(`${name}: No sellerSecret: ${terms.sellerSecret}`)\n return false\n }\n return true\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the sellerSecret in the dictionary\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the sellerSecret in the dictionary\n */\nexport const getSellerSecretSuppliedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const sellerSecret = assertEx(terms.sellerSecret, () => `${name}: No sellerSecret: ${terms.sellerSecret}`)\n if (!dictionary[sellerSecret]) {\n console.log(`${name}: Payload not supplied for sellerSecret: ${sellerSecret}`)\n return false\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the sellerSecret signed by the seller\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the sellerSecret signed by the seller\n */\nexport const getSellerSecretSignedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): AsyncPayloadValidationFunction<EscrowTerms> => {\n return getPartySecretSignedValidator(dictionary, 'seller')\n}\n","import type { Payload } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { PaymentCardSchema } from './Schema.ts'\n\n/**\n * The fields describing a payment card.\n */\nexport interface PaymentCardFields {\n /**\n * Card Number (PAN) of the payment card. This value is required to perform a payment.\n */\n cardNumber: string\n /**\n * The name as it appears on the payment card.\n */\n cardholderName?: string\n /**\n * Card Verification Value (CVV/CVC) of the payment card.\n */\n cvv: string\n /**\n * Expiration month of the payment card.\n */\n expMonth: number\n /**\n * Expiration year of the payment card.\n */\n expYear: number\n}\n\n/**\n * A PaymentCard Payload\n */\nexport type PaymentCard = Payload<PaymentCardFields, PaymentCardSchema>\n\n/**\n * Identity function for determine if an object is a PaymentCard\n */\nexport const isPaymentCard = isPayloadOfSchemaType<PaymentCard>(PaymentCardSchema)\n\n/**\n * Identity function for determine if an object is a PaymentCard with sources\n */\nexport const isPaymentCardWithSources = isPayloadOfSchemaTypeWithSources<PaymentCard>(PaymentCardSchema)\n\n/**\n * Identity function for determine if an object is a PaymentCard with meta\n */\nexport const isPaymentCardWithMeta = isPayloadOfSchemaTypeWithMeta<PaymentCard>(PaymentCardSchema)\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const PaymentSchema = `${PaymentsSchema}.payment`\nexport type PaymentSchema = typeof PaymentSchema\n","import { PaymentSchema } from '../Schema.ts'\n\nexport const PaymentInstrumentSchema = `${PaymentSchema}.instrument`\nexport type PaymentInstrumentSchema = typeof PaymentInstrumentSchema\n","import { PaymentInstrumentSchema } from '../Schema.ts'\n\nexport const PaymentCardSchema = `${PaymentInstrumentSchema}.card`\nexport type PaymentCardSchema = typeof PaymentCardSchema\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { SupportedCurrency } from '../Currency.ts'\nimport { PaymentSchema } from './Schema.ts'\n\nexport interface PaymentFields {\n /**\n * The amount paid\n */\n amount: number\n /**\n * The currency of the amount paid\n */\n currency: SupportedCurrency\n}\n\n/**\n * A payment is a record of an amount to be paid\n */\nexport type Payment = PayloadWithSources<PaymentFields, PaymentSchema>\n\n/**\n * Identity function for determine if an object is a Payment\n */\nexport const isPayment = isPayloadOfSchemaType<Payment>(PaymentSchema)\n\n/**\n * Identity function for determine if an object is a Payment with sources\n */\nexport const isPaymentWithSources = isPayloadOfSchemaTypeWithSources<Payment>(PaymentSchema)\n\n/**\n * Identity function for determine if an object is a Payment with meta\n */\nexport const isPaymentWithMeta = isPayloadOfSchemaTypeWithMeta<Payment>(PaymentSchema)\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { PaymentStatusSchema } from './Schema.ts'\n\nexport interface PaymentStatusFields {\n /**\n * The result of the payment (i.e. declined)\n */\n result?: string\n\n /**\n * The status of the payment (i.e. completed)\n */\n status: string\n}\n\n/**\n * A payment status is the outcome of a payment attempt\n */\nexport type PaymentStatus = PayloadWithSources<PaymentStatusFields, PaymentStatusSchema>\n\n/**\n * Identity function for determine if an object is a PaymentStatus\n */\nexport const isPaymentStatus = isPayloadOfSchemaType<PaymentStatus>(PaymentStatusSchema)\n\n/**\n * Identity function for determine if an object is a PaymentStatus with sources\n */\nexport const isPaymentStatusWithSources = isPayloadOfSchemaTypeWithSources<PaymentStatus>(PaymentStatusSchema)\n\n/**\n * Identity function for determine if an object is a PaymentStatus with meta\n */\nexport const isPaymentStatusWithMeta = isPayloadOfSchemaTypeWithMeta<PaymentStatus>(PaymentStatusSchema)\n","import { PaymentSchema } from '../Schema.ts'\n\nexport const PaymentStatusSchema = `${PaymentSchema}.status`\nexport type PaymentStatusSchema = typeof PaymentStatusSchema\n","import type { Hash } from '@xylabs/hex'\nimport type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { PurchaseSchema } from './Schema.ts'\n\nexport interface PurchaseFields {\n /**\n * The things that were purchased\n */\n assets: Hash[]\n /**\n * The receipts for payments for this purchase. Array to allow for multiple payments\n * for a single quote.\n */\n receipts: Hash[]\n}\n\n/**\n * A purchase ties a payment made to a quote\n */\nexport type Purchase = PayloadWithSources<PurchaseFields, PurchaseSchema>\n\n/**\n * Identity function for determine if an object is a Purchase\n */\nexport const isPurchase = isPayloadOfSchemaType<Purchase>(PurchaseSchema)\n\n/**\n * Identity function for determine if an object is a Purchase with sources\n */\nexport const isPurchaseWithSources = isPayloadOfSchemaTypeWithSources<Purchase>(PurchaseSchema)\n\n/**\n * Identity function for determine if an object is a Purchase with meta\n */\nexport const isPurchaseWithMeta = isPayloadOfSchemaTypeWithMeta<Purchase>(PurchaseSchema)\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const PurchaseSchema = `${PaymentsSchema}.purchase`\nexport type PurchaseSchema = typeof PurchaseSchema\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { SupportedCurrency } from '../Currency.ts'\nimport { ReceiptSchema } from './Schema.ts'\n\nexport interface ReceiptFields {\n /**\n * The amount paid\n */\n amount: number\n /**\n * The currency of the amount paid\n */\n currency: SupportedCurrency\n}\n\n/**\n * A receipt is a record of a payment made\n */\nexport type Receipt = PayloadWithSources<ReceiptFields, ReceiptSchema>\n\n/**\n * Identity function for determine if an object is a Receipt\n */\nexport const isReceipt = isPayloadOfSchemaType<Receipt>(ReceiptSchema)\n\n/**\n * Identity function for determine if an object is a Receipt with sources\n */\nexport const isReceiptWithSources = isPayloadOfSchemaTypeWithSources<Receipt>(ReceiptSchema)\n\n/**\n * Identity function for determine if an object is a Receipt with meta\n */\nexport const isReceiptWithMeta = isPayloadOfSchemaTypeWithMeta<Receipt>(ReceiptSchema)\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const ReceiptSchema = `${PaymentsSchema}.receipt`\nexport type ReceiptSchema = typeof ReceiptSchema\n","// import type { Hash } from '@xylabs/hex'\nimport type { DivinerConfig } from '@xyo-network/diviner-model'\n\nexport const PaymentSubtotalDivinerConfigSchema = 'network.xyo.diviner.payments.subtotal.config'\nexport type PaymentSubtotalDivinerConfigSchema = typeof PaymentSubtotalDivinerConfigSchema\n\n/**\n * The configuration for the Coupon Subtotal Diviner\n */\nexport type PaymentSubtotalDivinerConfig = DivinerConfig<\n {},\n PaymentSubtotalDivinerConfigSchema\n>\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../Amount/index.ts'\n\nexport const SubtotalSchema = 'network.xyo.payments.subtotal' as const\nexport type SubtotalSchema = typeof SubtotalSchema\n\nexport interface SubtotalFields extends AmountFields {}\n\n/**\n * The result of a subtotal\n */\nexport type Subtotal = PayloadWithSources<SubtotalFields, SubtotalSchema>\n\n/**\n * Identity function for determining if an object is an Subtotal\n */\nexport const isSubtotal = isPayloadOfSchemaType<Subtotal>(SubtotalSchema)\n\n/**\n * Identity function for determining if an object is an Subtotal with sources\n */\nexport const isSubtotalWithSources = isPayloadOfSchemaTypeWithSources<Subtotal>(SubtotalSchema)\n\n/**\n * Identity function for determining if an object is an Subtotal with meta\n */\nexport const isSubtotalWithMeta = isPayloadOfSchemaTypeWithMeta<Subtotal>(SubtotalSchema)\n","// import type { Hash } from '@xylabs/hex'\nimport type { DivinerConfig } from '@xyo-network/diviner-model'\nimport type { ModuleIdentifier } from '@xyo-network/module-model'\n\nexport const PaymentTotalDivinerConfigSchema = 'network.xyo.diviner.payments.total.config'\nexport type PaymentTotalDivinerConfigSchema = typeof PaymentTotalDivinerConfigSchema\n\n/**\n * The configuration for the Total Diviner\n */\nexport type PaymentTotalDivinerConfig = DivinerConfig<\n {\n /**\n * The Diviner that will be used to determine the discount\n */\n paymentDiscountDiviner?: ModuleIdentifier\n\n /**\n * The Diviner that will be used to determine the subtotal\n */\n paymentSubtotalDiviner?: ModuleIdentifier\n },\n PaymentTotalDivinerConfigSchema\n>\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../Amount/index.ts'\n\nexport const TotalSchema = 'network.xyo.payments.total' as const\nexport type TotalSchema = typeof TotalSchema\n\nexport interface TotalFields extends AmountFields {}\n\n/**\n * The result of a total\n */\nexport type Total = PayloadWithSources<TotalFields, TotalSchema>\n\n/**\n * Identity function for determining if an object is an Total\n */\nexport const isTotal = isPayloadOfSchemaType<Total>(TotalSchema)\n\n/**\n * Identity function for determining if an object is an Total with sources\n */\nexport const isTotalWithSources = isPayloadOfSchemaTypeWithSources<Total>(TotalSchema)\n\n/**\n * Identity function for determining if an object is an Total with meta\n */\nexport const isTotalWithMeta = isPayloadOfSchemaTypeWithMeta<Total>(TotalSchema)\n"],"mappings":";AAsXO,IAAM,uBAA4E;AAAA,EACvF,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,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","names":["isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","SchemaSchema","SchemaSchema","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","SchemaSchema","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","BoundWitnessBuilder","BoundWitnessBuilder","getLogPrefix","errors","isBoundWitnessWithMeta","name","isBoundWitnessWithMeta","name","name","asAddress","name","assertEx","name","assertEx","name","asAddress","name","assertEx","name","assertEx","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources"]}
1
+ {"version":3,"sources":["../../src/Amount/Iso4217Currency.ts","../../src/Amount/Payload.ts","../../src/Billing/Address/Address.ts","../../src/Schema.ts","../../src/Billing/Schema.ts","../../src/Billing/Address/Schema.ts","../../src/Discount/Config.ts","../../src/Discount/Payload/Coupon/Conditions/AppraisalAmountCondition.ts","../../src/Discount/Payload/Coupon/Conditions/AssetQuantityCondition.ts","../../src/Discount/Payload/Coupon/Conditions/BuyerCondition.ts","../../src/Discount/Payload/Coupon/Coupons/FixedAmount.ts","../../src/Discount/Payload/Coupon/Schema.ts","../../src/Discount/Payload/Coupon/Coupons/FixedPercentage.ts","../../src/Discount/Payload/Coupon/Coupons/FixedPrice.ts","../../src/Discount/Payload/Coupon/Payload.ts","../../src/Discount/Payload/Coupon/types/Condition.ts","../../src/Discount/Payload/Coupon/types/isStackable.ts","../../src/Discount/Payload/Discount.ts","../../src/Discount/Payload/NoDiscount.ts","../../src/Escrow/Outcome.ts","../../src/Escrow/Schema.ts","../../src/Escrow/Terms/Terms.ts","../../src/Escrow/util/appraisal/getAppraisalsByAsset.ts","../../src/Escrow/util/appraisal/getSignaturesByAppraisal.ts","../../src/Escrow/util/secret/createEscrowIntent.ts","../../src/Escrow/util/secret/findEscrowPartySecretSignatures.ts","../../src/Escrow/util/secret/getEscrowSecret.ts","../../src/Escrow/util/secret/updateEscrowTermsWithSecret.ts","../../src/Escrow/validators/common/ModuleInstanceValidators/moduleInstanceValidators.ts","../../src/Escrow/validators/common/SecretValidators/getPartySecretSignedValidator.ts","../../src/Escrow/validators/common/TemporalValidators/validateWithinWindow.ts","../../src/Escrow/validators/escrow/agent.ts","../../src/Escrow/validators/escrow/appraisal.ts","../../src/Escrow/validators/escrow/appraisalAuthorities.ts","../../src/Escrow/validators/escrow/assets.ts","../../src/Escrow/validators/escrow/buyer.ts","../../src/Escrow/validators/escrow/buyerSecret.ts","../../src/Escrow/validators/escrow/nbfExp.ts","../../src/Escrow/validators/escrow/paymentAuthorities.ts","../../src/Escrow/validators/escrow/seller.ts","../../src/Escrow/validators/escrow/sellerSecret.ts","../../src/Payment/Instrument/Card/Payload.ts","../../src/Payment/Schema.ts","../../src/Payment/Instrument/Schema.ts","../../src/Payment/Instrument/Card/Schema.ts","../../src/Payment/Payload.ts","../../src/Payment/Status/Payload.ts","../../src/Payment/Status/Schema.ts","../../src/Purchase/Payload.ts","../../src/Purchase/Schema.ts","../../src/Receipt/Payload.ts","../../src/Receipt/Schema.ts","../../src/Subtotal/Diviner/Config.ts","../../src/Subtotal/Diviner/Payload.ts","../../src/Total/Diviner/Config.ts","../../src/Total/Diviner/Payload.ts"],"sourcesContent":["/* eslint-disable max-lines */\n/**\n * ISO 4217 currency codes\n */\nexport type Iso4217AlphabeticalCode =\n 'AED' |\n 'AFN' |\n 'ALL' |\n 'AMD' |\n 'ANG' |\n 'AOA' |\n 'ARS' |\n 'AUD' |\n 'AWG' |\n 'AZN' |\n 'BAM' |\n 'BBD' |\n 'BDT' |\n 'BGN' |\n 'BHD' |\n 'BIF' |\n 'BMD' |\n 'BND' |\n 'BOB' |\n 'BOV' |\n 'BRL' |\n 'BSD' |\n 'BTN' |\n 'BWP' |\n 'BYN' |\n 'BZD' |\n 'CAD' |\n 'CDF' |\n 'CHE' |\n 'CHF' |\n 'CHW' |\n 'CLF' |\n 'CLP' |\n 'CNY' |\n 'COP' |\n 'COU' |\n 'CRC' |\n 'CUP' |\n 'CVE' |\n 'CZK' |\n 'DJF' |\n 'DKK' |\n 'DOP' |\n 'DZD' |\n 'EGP' |\n 'ERN' |\n 'ETB' |\n 'EUR' |\n 'FJD' |\n 'FKP' |\n 'GBP' |\n 'GEL' |\n 'GHS' |\n 'GIP' |\n 'GMD' |\n 'GNF' |\n 'GTQ' |\n 'GYD' |\n 'HKD' |\n 'HNL' |\n 'HTG' |\n 'HUF' |\n 'IDR' |\n 'ILS' |\n 'INR' |\n 'IQD' |\n 'IRR' |\n 'ISK' |\n 'JMD' |\n 'JOD' |\n 'JPY' |\n 'KES' |\n 'KGS' |\n 'KHR' |\n 'KMF' |\n 'KPW' |\n 'KRW' |\n 'KWD' |\n 'KYD' |\n 'KZT' |\n 'LAK' |\n 'LBP' |\n 'LKR' |\n 'LRD' |\n 'LSL' |\n 'LYD' |\n 'MAD' |\n 'MDL' |\n 'MGA' |\n 'MKD' |\n 'MMK' |\n 'MNT' |\n 'MOP' |\n 'MRU' |\n 'MUR' |\n 'MVR' |\n 'MWK' |\n 'MXN' |\n 'MXV' |\n 'MYR' |\n 'MZN' |\n 'NAD' |\n 'NGN' |\n 'NIO' |\n 'NOK' |\n 'NPR' |\n 'NZD' |\n 'OMR' |\n 'PAB' |\n 'PEN' |\n 'PGK' |\n 'PHP' |\n 'PKR' |\n 'PLN' |\n 'PYG' |\n 'QAR' |\n 'RON' |\n 'RSD' |\n 'RUB' |\n 'RWF' |\n 'SAR' |\n 'SBD' |\n 'SCR' |\n 'SDG' |\n 'SEK' |\n 'SGD' |\n 'SHP' |\n 'SLE' |\n 'SOS' |\n 'SRD' |\n 'SSP' |\n 'STN' |\n 'SVC' |\n 'SYP' |\n 'SZL' |\n 'THB' |\n 'TJS' |\n 'TMT' |\n 'TND' |\n 'TOP' |\n 'TRY' |\n 'TTD' |\n 'TWD' |\n 'TZS' |\n 'UAH' |\n 'UGX' |\n 'USD' |\n 'USN' |\n 'UYI' |\n 'UYU' |\n 'UYW' |\n 'UZS' |\n 'VED' |\n 'VES' |\n 'VND' |\n 'VUV' |\n 'WST' |\n 'XAF' |\n 'XAG' |\n 'XAU' |\n 'XBA' |\n 'XBB' |\n 'XBC' |\n 'XBD' |\n 'XCD' |\n 'XDR' |\n 'XOF' |\n 'XPD' |\n 'XPF' |\n 'XPT' |\n 'XSU' |\n 'XTS' |\n 'XUA' |\n 'XXX' |\n 'YER' |\n 'ZAR' |\n 'ZMW' |\n 'ZWG' |\n 'ZWL'\n\n// TODO: Technically, the values should be 3 digit numbers with leading\n// zeros, so we can padStart if we need to be strict\n/**\n * ISO 4217 numeric currency number codes\n */\nexport type Iso4217NumericCode =\n 784 |\n 971 |\n 8 |\n 51 |\n 532 |\n 973 |\n 32 |\n 36 |\n 533 |\n 944 |\n 977 |\n 52 |\n 50 |\n 975 |\n 48 |\n 108 |\n 60 |\n 96 |\n 68 |\n 984 |\n 986 |\n 44 |\n 64 |\n 72 |\n 933 |\n 84 |\n 124 |\n 976 |\n 947 |\n 756 |\n 948 |\n 990 |\n 152 |\n 156 |\n 170 |\n 970 |\n 188 |\n 192 |\n 132 |\n 203 |\n 262 |\n 208 |\n 214 |\n 12 |\n 818 |\n 232 |\n 230 |\n 978 |\n 242 |\n 238 |\n 826 |\n 981 |\n 936 |\n 292 |\n 270 |\n 324 |\n 320 |\n 328 |\n 344 |\n 340 |\n 332 |\n 348 |\n 360 |\n 376 |\n 356 |\n 368 |\n 364 |\n 352 |\n 388 |\n 400 |\n 392 |\n 404 |\n 417 |\n 116 |\n 174 |\n 408 |\n 410 |\n 414 |\n 136 |\n 398 |\n 418 |\n 422 |\n 144 |\n 430 |\n 426 |\n 434 |\n 504 |\n 498 |\n 969 |\n 807 |\n 104 |\n 496 |\n 446 |\n 929 |\n 480 |\n 462 |\n 454 |\n 484 |\n 979 |\n 458 |\n 943 |\n 516 |\n 566 |\n 558 |\n 578 |\n 524 |\n 554 |\n 512 |\n 590 |\n 604 |\n 598 |\n 608 |\n 586 |\n 985 |\n 600 |\n 634 |\n 946 |\n 941 |\n 643 |\n 646 |\n 682 |\n 90 |\n 690 |\n 938 |\n 752 |\n 702 |\n 654 |\n 925 |\n 706 |\n 968 |\n 728 |\n 930 |\n 222 |\n 760 |\n 748 |\n 764 |\n 972 |\n 934 |\n 788 |\n 776 |\n 949 |\n 780 |\n 901 |\n 834 |\n 980 |\n 800 |\n 840 |\n 997 |\n 940 |\n 858 |\n 927 |\n 860 |\n 926 |\n 928 |\n 704 |\n 548 |\n 882 |\n 950 |\n 961 |\n 959 |\n 955 |\n 956 |\n 957 |\n 958 |\n 951 |\n 960 |\n 952 |\n 964 |\n 953 |\n 962 |\n 994 |\n 963 |\n 965 |\n 999 |\n 886 |\n 710 |\n 967 |\n 924 |\n 932\n\n/**\n * Dictionary of ISO 4217 alphabetical currency codes to numeric currency number codes\n */\nexport const Iso4217CurrencyCodes: Record<Iso4217AlphabeticalCode, Iso4217NumericCode> = {\n AED: 784,\n AFN: 971,\n ALL: 8,\n AMD: 51,\n ANG: 532,\n AOA: 973,\n ARS: 32,\n AUD: 36,\n AWG: 533,\n AZN: 944,\n BAM: 977,\n BBD: 52,\n BDT: 50,\n BGN: 975,\n BHD: 48,\n BIF: 108,\n BMD: 60,\n BND: 96,\n BOB: 68,\n BOV: 984,\n BRL: 986,\n BSD: 44,\n BTN: 64,\n BWP: 72,\n BYN: 933,\n BZD: 84,\n CAD: 124,\n CDF: 976,\n CHE: 947,\n CHF: 756,\n CHW: 948,\n CLF: 990,\n CLP: 152,\n CNY: 156,\n COP: 170,\n COU: 970,\n CRC: 188,\n CUP: 192,\n CVE: 132,\n CZK: 203,\n DJF: 262,\n DKK: 208,\n DOP: 214,\n DZD: 12,\n EGP: 818,\n ERN: 232,\n ETB: 230,\n EUR: 978,\n FJD: 242,\n FKP: 238,\n GBP: 826,\n GEL: 981,\n GHS: 936,\n GIP: 292,\n GMD: 270,\n GNF: 324,\n GTQ: 320,\n GYD: 328,\n HKD: 344,\n HNL: 340,\n HTG: 332,\n HUF: 348,\n IDR: 360,\n ILS: 376,\n INR: 356,\n IQD: 368,\n IRR: 364,\n ISK: 352,\n JMD: 388,\n JOD: 400,\n JPY: 392,\n KES: 404,\n KGS: 417,\n KHR: 116,\n KMF: 174,\n KPW: 408,\n KRW: 410,\n KWD: 414,\n KYD: 136,\n KZT: 398,\n LAK: 418,\n LBP: 422,\n LKR: 144,\n LRD: 430,\n LSL: 426,\n LYD: 434,\n MAD: 504,\n MDL: 498,\n MGA: 969,\n MKD: 807,\n MMK: 104,\n MNT: 496,\n MOP: 446,\n MRU: 929,\n MUR: 480,\n MVR: 462,\n MWK: 454,\n MXN: 484,\n MXV: 979,\n MYR: 458,\n MZN: 943,\n NAD: 516,\n NGN: 566,\n NIO: 558,\n NOK: 578,\n NPR: 524,\n NZD: 554,\n OMR: 512,\n PAB: 590,\n PEN: 604,\n PGK: 598,\n PHP: 608,\n PKR: 586,\n PLN: 985,\n PYG: 600,\n QAR: 634,\n RON: 946,\n RSD: 941,\n RUB: 643,\n RWF: 646,\n SAR: 682,\n SBD: 90,\n SCR: 690,\n SDG: 938,\n SEK: 752,\n SGD: 702,\n SHP: 654,\n SLE: 925,\n SOS: 706,\n SRD: 968,\n SSP: 728,\n STN: 930,\n SVC: 222,\n SYP: 760,\n SZL: 748,\n THB: 764,\n TJS: 972,\n TMT: 934,\n TND: 788,\n TOP: 776,\n TRY: 949,\n TTD: 780,\n TWD: 901,\n TZS: 834,\n UAH: 980,\n UGX: 800,\n USD: 840,\n USN: 997,\n UYI: 940,\n UYU: 858,\n UYW: 927,\n UZS: 860,\n VED: 926,\n VES: 928,\n VND: 704,\n VUV: 548,\n WST: 882,\n XAF: 950,\n XAG: 961,\n XAU: 959,\n XBA: 955,\n XBB: 956,\n XBC: 957,\n XBD: 958,\n XCD: 951,\n XDR: 960,\n XOF: 952,\n XPD: 964,\n XPF: 953,\n XPT: 962,\n XSU: 994,\n XTS: 963,\n XUA: 965,\n XXX: 999,\n YER: 886,\n ZAR: 710,\n ZMW: 967,\n ZWG: 924,\n ZWL: 932,\n}\n\nexport const isIso4217CurrencyCode = (code: string): code is Iso4217AlphabeticalCode => Iso4217CurrencyCodes[code as Iso4217AlphabeticalCode] ? true : false\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { Iso4217AlphabeticalCode } from './Iso4217Currency.ts'\n\nexport const AmountSchema = 'network.xyo.payments.amount' as const\nexport type AmountSchema = typeof AmountSchema\n\nexport interface AmountFields {\n amount: number\n currency: Iso4217AlphabeticalCode\n}\n\n/**\n * The result of a amount\n */\nexport type Amount = PayloadWithSources<AmountFields, AmountSchema>\n\n/**\n * Identity function for determining if an object is an Amount\n */\nexport const isAmount = isPayloadOfSchemaType<Amount>(AmountSchema)\n\n/**\n * Identity function for determining if an object is an Amount with sources\n */\nexport const isAmountWithSources = isPayloadOfSchemaTypeWithSources<Amount>(AmountSchema)\n\n/**\n * Identity function for determining if an object is an Amount with meta\n */\nexport const isAmountWithMeta = isPayloadOfSchemaTypeWithMeta<Amount>(AmountSchema)\n","import type { Payload } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { BillingAddressSchema } from './Schema.ts'\n\n/**\n * The fields describing a billing address.\n */\nexport interface BillingAddressFields {\n /** Street address line 1. */\n address?: string\n /** Street address line 2. */\n address2?: string | null\n /** City of the billing address. */\n city?: string\n /** Country code of the billing address, ISO 3166-1 alpha-2 code. */\n country?: string\n /** First name */\n firstName: string\n /** Last name */\n lastName: string\n /** Organization or company name associated with the billing address. */\n organization?: string | null\n /** Postal or ZIP code of the billing address. */\n postalCode?: string\n /** State or region of the billing address. */\n region?: string\n}\n\n/**\n * A BillingAddress Payload\n */\nexport type BillingAddress = Payload<BillingAddressFields, BillingAddressSchema>\n\n/**\n * Identity function for determine if an object is a BillingAddress\n */\nexport const isBillingAddress = isPayloadOfSchemaType<BillingAddress>(BillingAddressSchema)\n\n/**\n * Identity function for determine if an object is a BillingAddress with sources\n */\nexport const isBillingAddressWithSources = isPayloadOfSchemaTypeWithSources<BillingAddress>(BillingAddressSchema)\n\n/**\n * Identity function for determine if an object is a BillingAddress with meta\n */\nexport const isBillingAddressWithMeta = isPayloadOfSchemaTypeWithMeta<BillingAddress>(BillingAddressSchema)\n","export const PaymentsSchema = 'network.xyo.payments'\nexport type PaymentsSchema = typeof PaymentsSchema\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const BillingSchema = `${PaymentsSchema}.billing`\nexport type BillingSchema = typeof BillingSchema\n","import { BillingSchema } from '../Schema.ts'\n\nexport const BillingAddressSchema = `${BillingSchema}.address`\nexport type BillingAddressSchema = typeof BillingAddressSchema\n","// import type { Hash } from '@xylabs/hex'\nimport type { Address } from '@xylabs/hex'\nimport type { DivinerConfig } from '@xyo-network/diviner-model'\nimport type { ModuleIdentifier } from '@xyo-network/module-model'\n\nexport const PaymentDiscountDivinerConfigSchema = 'network.xyo.diviner.payments.discount.config'\nexport type PaymentDiscountDivinerConfigSchema = typeof PaymentDiscountDivinerConfigSchema\n\n/**\n * The configuration for the Payment Discount Diviner\n */\nexport type PaymentDiscountDivinerConfig = DivinerConfig<\n {\n /**\n * The boundwitness diviner used to query for payloads\n */\n boundWitnessDiviner?: ModuleIdentifier\n /**\n * The list of coupon authorities that can be used to get a discount\n */\n couponAuthorities?: Address[]\n\n // /**\n // * The list of coupons that are supported by this diviner\n // */\n // supportedCoupons?: Hash[]\n\n /**\n * The Diviner that can be used to determine the subtotal to apply discounts to\n */\n paymentSubtotalDiviner?: ModuleIdentifier\n },\n PaymentDiscountDivinerConfigSchema\n>\n","/* eslint-disable unicorn/no-thenable */\nimport { SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type { Condition } from '../types/index.ts'\n\n/**\n * Creates a coupon condition that requires an appraisal amount below a certain value\n * @param maximumAppraisalAmount The maximum appraisal amount\n * @returns A condition that requires an appraisal amount below a certain value\n */\nexport const createConditionForMaximumAppraisalAmount = (maximumAppraisalAmount: number): Condition => {\n return {\n schema: SchemaSchema,\n definition: {\n allOf: [\n {\n type: 'array',\n contains: {\n type: 'object',\n properties: {\n schema: { type: 'string', const: 'network.xyo.escrow.terms' },\n appraisals: { type: 'array', minItems: 1 },\n },\n required: ['schema', 'appraisals'],\n },\n },\n {\n type: 'array',\n contains: {\n type: 'object',\n properties: { schema: { type: 'string', const: 'network.xyo.hash.lease.estimate' } },\n required: ['schema'],\n },\n items: {\n type: 'object',\n if: { properties: { schema: { type: 'string', const: 'network.xyo.hash.lease.estimate' } } },\n then: { properties: { price: { type: 'number', maximum: maximumAppraisalAmount } }, required: ['price'] },\n },\n },\n ],\n },\n }\n}\n","import { SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type { Condition } from '../types/index.ts'\n\n/**\n * Returns a coupon condition that requires a minimum quantity of assets\n * @param minimumAssetQuantity The minimum quantity of assets required\n * @returns A condition that requires a minimum quantity of assets\n */\nexport const createConditionForMinimumAssetQuantity = (minimumAssetQuantity: number): Condition => {\n return {\n schema: SchemaSchema,\n definition: {\n type: 'array',\n contains: {\n type: 'object',\n properties: {\n schema: { type: 'string', const: 'network.xyo.escrow.terms' },\n assets: { type: 'array', minItems: minimumAssetQuantity },\n },\n required: ['schema', 'assets'],\n },\n },\n }\n}\n","import type { Address } from '@xylabs/hex'\nimport { SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\nimport type { Condition } from '../types/index.ts'\n\nexport type BuyerCondition = Condition & {\n definition: {\n contains: {\n properties: {\n buyer: {\n items: {\n const: Address\n type: 'string'\n }\n minItems: 1\n type: 'array'\n }\n schema: { const: 'network.xyo.escrow.terms'; type: 'string' }\n }\n required: ['schema', 'buyer']\n type: 'object'\n }\n type: 'array'\n }\n schema: SchemaSchema\n}\n\n/**\n * Creates a coupon condition that requires a specific buyer\n * @param buyer The buyer's address\n * @returns A coupon condition that requires a specific buyer\n */\nexport const createConditionForRequiredBuyer = (buyer: Address): BuyerCondition => {\n return {\n schema: SchemaSchema,\n definition: {\n type: 'array',\n contains: {\n type: 'object',\n properties: {\n schema: { type: 'string', const: 'network.xyo.escrow.terms' },\n buyer: {\n type: 'array', items: { type: 'string', const: buyer }, minItems: 1,\n },\n },\n required: ['schema', 'buyer'],\n },\n },\n }\n}\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../../../Amount/index.ts'\nimport { CouponSchema } from '../Schema.ts'\nimport type { CouponFields } from '../types/index.ts'\n\nexport const FixedAmountCouponSchema = `${CouponSchema}.fixed.amount` as const\nexport type FixedAmountCouponSchema = typeof FixedAmountCouponSchema\n\nexport interface FixedAmountCouponFields extends CouponFields, AmountFields {}\n\n/**\n * A coupon that provides a fixed discount amount\n */\nexport type FixedAmountCoupon = PayloadWithSources<FixedAmountCouponFields, FixedAmountCouponSchema>\n\n/**\n * Identity function for determining if an object is an FixedAmountCoupon\n */\nexport const isFixedAmountCoupon = isPayloadOfSchemaType<FixedAmountCoupon>(FixedAmountCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedAmountCoupon with sources\n */\nexport const isFixedAmountCouponWithSources = isPayloadOfSchemaTypeWithSources<FixedAmountCoupon>(FixedAmountCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedAmountCoupon with meta\n */\nexport const isFixedAmountCouponWithMeta = isPayloadOfSchemaTypeWithMeta<FixedAmountCoupon>(FixedAmountCouponSchema)\n","export const CouponSchema = 'network.xyo.payments.coupon' as const\nexport type CouponSchema = typeof CouponSchema\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { CouponSchema } from '../Schema.ts'\nimport type { CouponFields } from '../types/index.ts'\n\nexport const FixedPercentageCouponSchema = `${CouponSchema}.fixed.percentage` as const\nexport type FixedPercentageCouponSchema = typeof FixedPercentageCouponSchema\n\nexport interface FixedPercentageCouponFields extends CouponFields {\n percentage: number\n}\n\n/**\n * A coupon that provides a fixed discount amount\n */\nexport type FixedPercentageCoupon = PayloadWithSources<FixedPercentageCouponFields, FixedPercentageCouponSchema>\n\n/**\n * Identity function for determining if an object is an FixedPercentageCoupon\n */\nexport const isFixedPercentageCoupon = isPayloadOfSchemaType<FixedPercentageCoupon>(FixedPercentageCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPercentageCoupon with sources\n */\nexport const isFixedPercentageCouponWithSources = isPayloadOfSchemaTypeWithSources<FixedPercentageCoupon>(FixedPercentageCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPercentageCoupon with meta\n */\nexport const isFixedPercentageCouponWithMeta = isPayloadOfSchemaTypeWithMeta<FixedPercentageCoupon>(FixedPercentageCouponSchema)\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../../../Amount/index.ts'\nimport { CouponSchema } from '../Schema.ts'\nimport type { CouponFields } from '../types/index.ts'\n\nexport const FixedPriceCouponSchema = `${CouponSchema}.fixed.price` as const\nexport type FixedPriceCouponSchema = typeof FixedPriceCouponSchema\n\nexport interface FixedPriceCouponFields extends CouponFields, AmountFields { }\n\n/**\n * A coupon that provides a fixed total price\n */\nexport type FixedPriceCoupon = PayloadWithSources<FixedPriceCouponFields, FixedPriceCouponSchema>\n\n/**\n * Identity function for determining if an object is an FixedPriceCoupon\n */\nexport const isFixedPriceCoupon = isPayloadOfSchemaType<FixedPriceCoupon>(FixedPriceCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPriceCoupon with sources\n */\nexport const isFixedPriceCouponWithSources = isPayloadOfSchemaTypeWithSources<FixedPriceCoupon>(FixedPriceCouponSchema)\n\n/**\n * Identity function for determining if an object is an FixedPriceCoupon with meta\n */\nexport const isFixedPriceCouponWithMeta = isPayloadOfSchemaTypeWithMeta<FixedPriceCoupon>(FixedPriceCouponSchema)\n","import {\n type FixedAmountCoupon, type FixedPercentageCoupon, type FixedPriceCoupon,\n isFixedAmountCoupon, isFixedAmountCouponWithMeta, isFixedAmountCouponWithSources, isFixedPercentageCoupon,\n isFixedPercentageCouponWithMeta,\n isFixedPercentageCouponWithSources,\n isFixedPriceCoupon,\n isFixedPriceCouponWithSources,\n} from './Coupons/index.ts'\n\n/**\n * The type of coupons\n */\nexport type Coupon =\n FixedAmountCoupon\n | FixedPercentageCoupon\n | FixedPriceCoupon\n\n/**\n * Identity function for determining if an object is an Coupon\n */\nexport const isCoupon = (x?: unknown | null) =>\n isFixedAmountCoupon(x)\n || isFixedPercentageCoupon(x)\n || isFixedPriceCoupon(x)\n\n/**\n * Identity function for determining if an object is an Coupon with sources\n */\nexport const isCouponWithSources = (x?: unknown | null) =>\n isFixedAmountCouponWithSources(x)\n || isFixedPercentageCouponWithSources(x)\n || isFixedPriceCouponWithSources(x)\n\n/**\n * Identity function for determining if an object is an Coupon with meta\n */\nexport const isCouponWithMeta = (x?: unknown | null) =>\n isFixedAmountCouponWithMeta(x)\n || isFixedPercentageCouponWithMeta(x)\n","import {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources, type WithMeta, type WithOptionalMeta,\n} from '@xyo-network/payload-model'\nimport { type SchemaPayload, SchemaSchema } from '@xyo-network/schema-payload-plugin'\n\n/**\n * The payloads that can be used as conditions for a coupon\n */\nexport type Condition = SchemaPayload | WithOptionalMeta<SchemaPayload> | WithMeta<SchemaPayload>\n\n/**\n * Identity function for determining if an object is a Condition payload\n */\nexport const isCondition = isPayloadOfSchemaType<Condition>(SchemaSchema)\n\n/**\n * Identity function for determining if an object is a Condition payload with sources\n */\nexport const isConditionWithSources = isPayloadOfSchemaTypeWithSources<Condition>(SchemaSchema)\n\n/**\n * Identity function for determining if an object is a Condition payload with meta\n */\nexport const isConditionWithMeta = isPayloadOfSchemaTypeWithMeta<Condition>(SchemaSchema)\n","import type { CouponFields } from './CouponFields.ts'\n\n/**\n * Identity function for determining if coupon is stackable\n */\nexport const isStackable = (x?: unknown | null) => (x as CouponFields ?? { stackable: false })?.stackable\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../Amount/index.ts'\n\nexport const DiscountSchema = 'network.xyo.payments.discount' as const\nexport type DiscountSchema = typeof DiscountSchema\n\nexport interface DiscountFields extends AmountFields { }\n\n/**\n * The result of a discount\n */\nexport type Discount = PayloadWithSources<DiscountFields, DiscountSchema>\n\n/**\n * Identity function for determining if an object is an Discount\n */\nexport const isDiscount = isPayloadOfSchemaType<Discount>(DiscountSchema)\n\n/**\n * Identity function for determining if an object is an Discount with sources\n */\nexport const isDiscountWithSources = isPayloadOfSchemaTypeWithSources<Discount>(DiscountSchema)\n\n/**\n * Identity function for determining if an object is an Discount with meta\n */\nexport const isDiscountWithMeta = isPayloadOfSchemaTypeWithMeta<Discount>(DiscountSchema)\n","import type { Discount } from './Discount.ts'\nimport { DiscountSchema } from './Discount.ts'\n\nexport const NO_DISCOUNT: Discount = {\n schema: DiscountSchema,\n amount: 0,\n currency: 'USD',\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { EscrowSchema } from './Schema.ts'\n\nexport const EscrowOutcomeSchema = `${EscrowSchema}.outcome` as const\nexport type EscrowOutcomeSchema = typeof EscrowOutcomeSchema\n\n/**\n * The possible outcomes for an escrow\n */\nexport type EscrowOutcomes = 'fulfilled' | 'expired' // TODO: More outcomes\n\nexport interface EscrowOutcomeFields {\n outcome: EscrowOutcomes\n terms: Hash\n}\n\n/**\n * The terms of an escrow\n */\nexport type EscrowOutcome = PayloadWithSources<EscrowOutcomeFields, EscrowOutcomeSchema>\n\n/**\n * Identity function for determining if an object is an EscrowOutcome\n */\nexport const isEscrowOutcome = isPayloadOfSchemaType<EscrowOutcome>(EscrowOutcomeSchema)\n\n/**\n * Identity function for determining if an object is an EscrowOutcome with sources\n */\nexport const isEscrowOutcomeWithSources = isPayloadOfSchemaTypeWithSources<EscrowOutcome>(EscrowOutcomeSchema)\n\n/**\n * Identity function for determining if an object is an EscrowOutcome with meta\n */\nexport const isEscrowOutcomeWithMeta = isPayloadOfSchemaTypeWithMeta<EscrowOutcome>(EscrowOutcomeSchema)\n","export const EscrowSchema = 'network.xyo.escrow'\nexport type EscrowSchema = typeof EscrowSchema\n","import type { Address, Hash } from '@xylabs/hex'\nimport type { Payload } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { EscrowSchema } from '../Schema.ts'\n\nexport const EscrowTermsSchema = `${EscrowSchema}.terms` as const\nexport type EscrowTermsSchema = typeof EscrowTermsSchema\n\n// TODO: Include escrow agent in escrow terms\nexport interface EscrowTermsFields {\n /**\n * The trusted estimators for the worth of the things being sold\n */\n appraisalAuthorities: Address[]\n /**\n * The estimated worths of the things being sold\n */\n appraisals: Hash[]\n /**\n * The things being sold\n */\n assets: Hash[]\n /**\n * The buyer\n */\n buyer: Address[]\n /**\n * The buyer\n */\n buyerSecret: Hash\n /**\n * Any discounts (coupons, vouchers, credits, etc.) to be applied to the escrow\n */\n discounts: Hash[]\n /**\n * The escrow agent responsible for the escrow\n */\n escrowAgent: Address\n /**\n * The time the escrow expires\n */\n exp: number\n /**\n * The time the escrow starts\n */\n nbf: number\n /**\n * The trusted payment authorities\n */\n paymentAuthorities: Address[]\n /**\n * The seller\n */\n seller: Address[]\n /**\n * The seller\n */\n sellerSecret: Hash\n}\n\n/**\n * The terms of an escrow\n */\nexport type EscrowTerms = Payload<Partial<EscrowTermsFields>, EscrowTermsSchema>\n\n/**\n * Identity function for determining if an object is an EscrowTerms\n */\nexport const isEscrowTerms = isPayloadOfSchemaType<EscrowTerms>(EscrowTermsSchema)\n\n/**\n * Identity function for determining if an object is an EscrowTerms with sources\n */\nexport const isEscrowTermsWithSources = isPayloadOfSchemaTypeWithSources<EscrowTerms>(EscrowTermsSchema)\n\n/**\n * Identity function for determining if an object is an EscrowTerms with meta\n */\nexport const isEscrowTermsWithMeta = isPayloadOfSchemaTypeWithMeta<EscrowTerms>(EscrowTermsSchema)\n","import type { Hash } from '@xylabs/hex'\nimport { type HashLeaseEstimate, isHashLeaseEstimateWithSources } from '@xyo-network/diviner-hash-lease'\nimport type {\n Payload, WithMeta, WithSources,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\n/**\n * Returns a dictionary of asset hashes and their associated appraisals\n * @param terms The escrow terms\n * @param dictionary The dictionary of payloads associated with the escrow terms\n * @returns A dictionary of asset hashes and their associated appraisals\n */\nexport const getAppraisalsByAsset = (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>): Record<Hash, WithSources<HashLeaseEstimate>[]> => {\n const assets = terms.assets\n if (!assets || assets.length === 0) return {}\n const appraisals = Object.values(dictionary).filter(isHashLeaseEstimateWithSources) as unknown as WithSources<HashLeaseEstimate>[]\n const appraisalsByAsset: Record<Hash, WithSources<HashLeaseEstimate>[]> = {}\n for (const estimate of appraisals) {\n const { sources } = estimate\n if (sources === undefined || sources.length === 0) {\n continue\n }\n for (const asset of assets) {\n if (sources.includes(asset)) {\n if (!appraisalsByAsset[asset]) appraisalsByAsset[asset] = []\n appraisalsByAsset[asset].push(estimate)\n }\n }\n }\n return appraisalsByAsset\n}\n","import type { Hash } from '@xylabs/hex'\nimport { type BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport type { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\n/**\n * Returns a dictionary of appraisals and their associated bound witnesses which are signed by\n * valid appraisal authorities from the escrow terms\n * @param terms The escrow terms\n * @param dictionary The diction of payloads associated with the escrow terms\n * @returns A dictionary of appraisals and their associated bound witnesses\n */\nexport const getSignaturesByAppraisal = (\n terms: EscrowTerms,\n dictionary: Record<Hash, WithMeta<Payload>>,\n): Record<Hash, WithMeta<BoundWitness>[]> => {\n // Validate inputs\n const appraisals = terms.appraisals\n if (!appraisals || appraisals.length === 0) return {}\n const appraisalAuthorities = terms.appraisalAuthorities\n if (!appraisalAuthorities || appraisalAuthorities.length === 0) return {}\n\n // Validate the appraisals are signed by valid appraisal authorities. Validation criteria:\n // - The bw includes the appraisal hash from the escrow terms appraisal\n // - The bw is signed by an approved appraisal authority from the escrow terms appraisalAuthorities\n const appraisalBWsValid: Record<Hash, WithMeta<BoundWitness>[]> = Object.fromEntries(\n appraisals.map<[Hash, WithMeta<BoundWitness>[]]>(hash => [hash, []]),\n )\n for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta)) {\n for (const appraisal of appraisals) {\n if (bw.payload_hashes.includes(appraisal) && bw.addresses.some(address => appraisalAuthorities.includes(address))) {\n appraisalBWsValid[appraisal].push(bw)\n }\n }\n }\n\n return appraisalBWsValid\n}\n","import type { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport type { IdPayload } from '@xyo-network/id-payload-plugin'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\n/**\n * Creates an escrow intent (for a buyer or seller) using the supplied secret\n * @param terms The payload describing the terms for the escrow\n * @param secret The secret for the escrow principal party to use for the escrow\n * @param account The account to create the escrow intent with\n * @returns The escrow intent\n */\nexport const createEscrowIntentWithSecret = async (terms: EscrowTerms, secret: IdPayload, account: AccountInstance) => {\n const result = await new BoundWitnessBuilder({ accounts: [account] }).payloads([terms, secret]).build()\n return result\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport type { Payload, WithMeta } from '@xyo-network/payload-model'\n\nimport type {\n EscrowParty, EscrowPartySecret, EscrowTerms,\n} from '../../Terms/index.ts'\n/**\n * Returns the log prefix for the party\n * @param party The party\n * @returns The log prefix for the party\n */\nconst getLogPrefix = (party: EscrowParty) => {\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n return `EscrowTerms.${partySecret}`\n}\n\n/**\n * Returns an array of BoundWitnesses containing the secret signed by all the parties\n * @param terms The escrow terms\n * @param dictionary A dictionary of all the payloads associated with the escrow\n * @param party The party to get the secret signatures for\n * @returns An array of BoundWitnesses containing the secret signed by all the parties\n */\nexport const findEscrowPartySecretSignatures = (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>, party: EscrowParty): BoundWitness[] => {\n const partyAddresses = terms[party]\n if (partyAddresses === undefined || partyAddresses.length === 0) {\n console.log(`${getLogPrefix(party)}: No ${party}: ${terms[party]}`)\n return []\n }\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n const secretHash = terms[partySecret]\n if (secretHash === undefined) {\n console.log(`${getLogPrefix(party)}: No ${partySecret}: ${terms[partySecret]}`)\n return []\n }\n // BWs containing the secret signed by all the parties\n const partySignedBWs = Object.values(dictionary)\n // Find all BoundWitnesses\n .filter(isBoundWitnessWithMeta)\n // That contain the seller secret\n .filter(bw => bw.payload_hashes.includes(secretHash))\n // That are signed by all the parties\n .filter(bw => partyAddresses.every(address => bw.addresses.includes(address)))\n return partySignedBWs\n}\n","import { Crypto } from '@xylabs/crypto'\nimport type { IdPayload } from '@xyo-network/id-payload-plugin'\nimport { IdSchema } from '@xyo-network/id-payload-plugin'\n\n/**\n * Returns a cryptographically random secret to use for escrow\n * @returns The escrow secret\n */\nexport const getEscrowSecret = (): IdPayload => {\n return { salt: Crypto.randomUUID(), schema: IdSchema }\n}\n","import type { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport type { IdPayload } from '@xyo-network/id-payload-plugin'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\n\nimport type {\n EscrowParty, EscrowPartySecret, EscrowTerms,\n} from '../../Terms/index.ts'\nimport { getEscrowSecret } from './getEscrowSecret.ts'\n\n/**\n * Creates an escrow intent (for a buyer or seller) using the supplied secret\n * @param terms The payload describing the terms for the escrow\n * @param escrowParty The party in the escrow transaction\n * @param account The account(s) to create the escrow intent with\n * @param secret The secret for the escrow principal party to use for the escrow. If\n * not provided, a cryptographically random secret will be generated.\n * @returns The escrow intent\n */\nexport const updateEscrowTermsWithSecret = async (\n terms: EscrowTerms,\n escrowParty: EscrowParty,\n account: AccountInstance | AccountInstance[],\n secret?: IdPayload,\n) => {\n if (!secret) secret = getEscrowSecret()\n const signers = Array.isArray(account) ? account : [account]\n // Add party addresses to escrow terms\n terms[escrowParty] = signers.map(signer => signer.address)\n // Add secret hash to terms\n const secretType: EscrowPartySecret = escrowParty === 'buyer' ? 'buyerSecret' : 'sellerSecret'\n const secretHash = await PayloadBuilder.dataHash(secret)\n terms[secretType] = secretHash\n // Have the parties sign the secret and terms\n const result = await new BoundWitnessBuilder().signers(signers).payloads([terms, secret]).build()\n return result\n}\n","import type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { PayloadValueExpression } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../../Terms/index.ts'\n\n/**\n * Checks if property value of the escrow terms contains one of the valid moduleIdentifiers\n * @param escrowTerms The escrow terms to validate\n * @param propertyExpression The selector to get the property containing the moduleIdentifier(s) from the escrow terms\n * @param moduleIdentifiers The list of allowed moduleIdentifiers\n * @param required Is the property required to be present\n * @returns True if the property value contains one of the valid moduleIdentifiers\n */\nexport const moduleIdentifiersContainsOneOf = (\n escrowTerms: EscrowTerms,\n propertyExpression: PayloadValueExpression<EscrowTerms, 'appraisalAuthorities' | 'buyer' | 'escrowAgent' | 'paymentAuthorities' | 'seller'>,\n moduleIdentifiers: ModuleIdentifier[],\n required: boolean = true,\n) => {\n const termsValue: string | string[] | undefined = propertyExpression(escrowTerms)\n if (termsValue === undefined) {\n return required ? false : true\n } else {\n return Array.isArray(termsValue) ? termsValue.some(address => moduleIdentifiers.includes(address)) : moduleIdentifiers.includes(termsValue)\n }\n}\n\n/**\n * Checks if property value of the escrow terms contains all of the valid moduleIdentifiers\n * @param escrowTerms The escrow terms to validate\n * @param selector The selector to get the property containing the moduleIdentifier(s) from the escrow terms\n * @param moduleIdentifiers The list of allowed moduleIdentifiers\n * @param required Is the property required to be present\n * @returns True if the property value contains all of the valid moduleIdentifiers\n */\nexport const moduleIdentifiersContainsAllOf = (\n escrowTerms: EscrowTerms,\n selector: PayloadValueExpression<EscrowTerms, 'appraisalAuthorities' | 'buyer' | 'escrowAgent' | 'paymentAuthorities' | 'seller'>,\n moduleIdentifiers: ModuleIdentifier[],\n required: boolean = true,\n) => {\n const termsValue: string | string[] | undefined = selector(escrowTerms)\n if (termsValue === undefined) {\n return required ? false : true\n } else {\n return Array.isArray(termsValue) ? termsValue.every(address => moduleIdentifiers.includes(address)) : moduleIdentifiers.includes(termsValue)\n }\n}\n","import type { Hash } from '@xylabs/hex'\nimport { BoundWitnessValidator } from '@xyo-network/boundwitness-validator'\nimport type {\n AsyncPayloadValidationFunction, Payload, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport type {\n EscrowParty, EscrowPartySecret, EscrowTerms,\n} from '../../../Terms/index.ts'\nimport { findEscrowPartySecretSignatures } from '../../../util/index.ts'\n\n/**\n * Returns the log prefix for the party\n * @param party The party\n * @returns The log prefix for the party\n */\nconst getLogPrefix = (party: EscrowParty) => {\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n return `EscrowTerms.${partySecret}`\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the party secret signed by the party\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the party secret signed by the party\n */\nexport const getPartySecretSignedValidator = (dictionary: Record<Hash, WithMeta<Payload>>, party: EscrowParty): AsyncPayloadValidationFunction<EscrowTerms> => {\n const partySecret: EscrowPartySecret = party === 'seller' ? 'sellerSecret' : 'buyerSecret'\n return async (terms: EscrowTerms): Promise<boolean> => {\n // Party-signed party secret BWs\n const buyerSecretBWs = findEscrowPartySecretSignatures(terms, dictionary, party)\n\n // If there are no BWs, return false\n if (buyerSecretBWs.length === 0) {\n console.log(`${getLogPrefix(party)}: No BoundWitnesses supplied for ${partySecret}: ${terms[partySecret]}`)\n return false\n }\n\n // Ensure each BW supplied for the party secret is valid\n const errors = await Promise.all(buyerSecretBWs.map(bw => new BoundWitnessValidator(bw).validate()))\n const validBoundWitnesses = errors.every(errors => errors.length === 0)\n if (!validBoundWitnesses) {\n console.log(`${getLogPrefix(party)}: Invalid BoundWitnesses supplied for ${partySecret}: ${terms[partySecret]}`)\n return false\n }\n return true\n }\n}\n","export type Windowed = { exp?: number; nbf?: number }\n\nexport const validateWithinWindow = (value: Windowed, exp: number, nbf: number = Date.now()): boolean => {\n if (value.nbf === undefined || value.nbf > nbf) return false\n if (value.exp === undefined || value.exp < exp) return false\n return true\n}\n","import type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { moduleIdentifiersContainsOneOf } from '../common/index.ts'\n\nconst name = 'EscrowTerms.escrowAgent'\n\nexport const getEscrowAgentAllowedValidator = (allowedEscrowAgent: ModuleIdentifier): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const result = moduleIdentifiersContainsOneOf(terms, t => t.escrowAgent, [allowedEscrowAgent], true)\n if (!result) {\n console.log(`${name}: Escrow agent not allowed: ${terms.escrowAgent}`)\n }\n return result\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'\nimport type { HashLeaseEstimate } from '@xyo-network/diviner-hash-lease'\nimport type {\n Payload, SyncPayloadValidationFunction, WithMeta, WithSources,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { getAppraisalsByAsset } from '../../util/index.ts'\nimport { validateWithinWindow } from '../common/index.ts'\n\nconst name = 'EscrowTerms.appraisal'\n\n/**\n * A function that validates the escrow terms for tbe existence of appraisals\n * @returns True if the escrow terms contain appraisals, false otherwise\n */\nexport const appraisalsExistValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have appraisals\n const appraisals = terms.appraisals\n if (!appraisals || appraisals.length === 0) {\n console.log(`${name}: No appraisals: ${terms.appraisals}`)\n return false\n }\n return true\n}\n\n/**\n * Returns a function that validates the escrow terms for appraisals which are from valid authorities\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for appraisals which are from valid authorities\n */\nexport const getAppraisalsFromValidAuthoritiesValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const appraisals = assertEx(terms.appraisals, () => `${name}: No appraisals: ${terms.appraisals}`)\n const appraisalAuthorities = assertEx(terms.appraisalAuthorities, () => `${name}: No appraisalAuthorities: ${terms.appraisalAuthorities}`)\n\n // Validate the appraisals are signed by valid appraisal authorities. Validation criteria:\n // - We have a bw for each of the appraisal\n // - The bw is signed by an approved appraisal authority\n const appraisalBWsValid: Record<Hash, WithMeta<BoundWitness>[]> = Object.fromEntries(\n appraisals.map<[Hash, WithMeta<BoundWitness>[]]>(hash => [hash, []]),\n )\n for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta)) {\n for (const appraisal of appraisals) {\n if (bw.payload_hashes.includes(appraisal) && bw.addresses.some(address => appraisalAuthorities.includes(address))) {\n appraisalBWsValid[appraisal].push(bw)\n }\n }\n }\n for (const [appraisal, bws] of Object.entries(appraisalBWsValid)) {\n if (bws.length === 0) {\n console.log(`${name}: No valid appraisals for ${appraisal}`)\n return false\n }\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms for appraisals which are valid\n * @param dictionary Payload dictionary of the escrow terms\n * @param minimumExp The minium amount of time an estimate needs to be valid\n * for in the future (so as not to expire before the escrow is complete)\n * @returns A function that validates the escrow terms for appraisals which are valid\n */\nexport const getAppraisalsValidValidator = (\n dictionary: Record<Hash, WithMeta<Payload>>,\n minimumExp: number,\n): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n // Verify we have an estimate for each of the assets\n const estimatesByAsset = getAppraisalsByAsset(terms, dictionary)\n // Validate each of the estimates are valid (time, price, etc)\n const now = Date.now()\n const exp = now + minimumExp\n for (const [asset, estimates] of Object.entries(estimatesByAsset)) {\n for (const estimate of estimates) {\n if (!validateEstimate(estimate, exp)) {\n console.log(`${name}: Invalid estimate for asset ${asset}: ${estimate}`)\n return false\n }\n }\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms to ensure that they contain an appraisal for each asset\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for appraisals\n */\nexport const getAppraisalsForAllAssetsValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n // Verify we have an estimate for each of the assets\n const assets = assertEx(terms.assets, () => `${name}: No assets: ${terms.assets}`)\n const estimatesByAsset = getAppraisalsByAsset(terms, dictionary)\n if (Object.keys(estimatesByAsset).length !== assets.length) {\n console.log(`${name}: Missing appraisals for all assets: ${assets}`)\n return false\n }\n return true\n }\n}\n\nconst validateEstimate = (estimate: WithSources<HashLeaseEstimate>, exp: number): boolean => {\n if (!validateWithinWindow(estimate, exp)) return false\n if (estimate.currency !== 'USD') return false\n if (estimate.price < 0) return false\n return true\n}\n","import { asAddress } from '@xylabs/hex'\nimport type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { moduleIdentifiersContainsAllOf } from '../common/index.ts'\n\nconst name = 'EscrowTerms.appraisalAuthorities'\n\n/**\n * A function that validates the escrow terms for appraisalAuthorities\n * @returns True if the escrow terms contain appraisalAuthorities, false otherwise\n */\nexport const appraisalAuthoritiesExistValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have appraisalAuthorities\n const appraisalAuthorities = terms.appraisalAuthorities\n if (!appraisalAuthorities || appraisalAuthorities.length === 0) {\n console.log(`${name}: No appraisalAuthorities: ${terms.appraisalAuthorities}`)\n return false\n }\n // Validate the authorities are addresses\n if (appraisalAuthorities.map(x => asAddress(x)).length !== appraisalAuthorities.length) {\n console.log(`${name}: Invalid address: ${terms.appraisalAuthorities}`)\n return false\n }\n return true\n}\n\nexport const getAppraisalAuthoritiesAllowedValidator = (allowed: ModuleIdentifier[]): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const result = moduleIdentifiersContainsAllOf(terms, t => t.appraisalAuthorities, allowed, true)\n if (!result) {\n console.log(`${name}: Appraisal authority not allowed: ${terms.appraisalAuthorities}`)\n }\n return result\n }\n}\n","import type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nconst name = 'EscrowTerms.assets'\n\n/**\n * Returns a function that validates the escrow terms for assets\n * @returns A function that validates the escrow terms for assets\n */\nexport const assetsExistValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have assets\n const assets = terms.assets\n if (!assets || assets.length === 0) {\n console.log(`${name}: No assets: ${terms.assets}`)\n return false\n }\n return true\n}\n","import { asAddress } from '@xylabs/hex'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nconst name = 'EscrowTerms.buyer'\n\n/**\n * A function that validates the escrow terms for buyer\n * @returns True if the escrow terms contain buyer, false otherwise\n */\nexport const buyerExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have buyer\n const buyer = terms.buyer\n if (!buyer || buyer.length === 0) {\n console.log(`${name}: No buyer: ${terms.buyer}`)\n return false\n }\n // Validate the authorities are addresses\n if (buyer.map(x => asAddress(x)).length !== buyer.length) {\n console.log(`${name}: Invalid address: ${terms.buyer}`)\n return false\n }\n return true\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type {\n AsyncPayloadValidationFunction, Payload, SyncPayloadValidationFunction, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { getPartySecretSignedValidator } from '../common/index.ts'\n\nconst name = 'EscrowTerms.buyerSecret'\n\n/**\n * Returns a function that validates the escrow terms for buyerSecret\n * @returns A function that validates the escrow terms for buyerSecret\n */\nexport const buyerSecretExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have buyerSecret\n const buyerSecret = terms.buyerSecret\n if (!buyerSecret || buyerSecret.length === 0) {\n console.log(`${name}: No buyerSecret: ${terms.buyerSecret}`)\n return false\n }\n return true\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the buyerSecret in the dictionary\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the buyerSecret in the dictionary\n */\nexport const getBuyerSecretSuppliedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const buyerSecret = assertEx(terms.buyerSecret, () => `${name}: No buyerSecret: ${terms.buyerSecret}`)\n if (!dictionary[buyerSecret]) {\n console.log(`${name}: Payload not supplied for buyerSecret: ${buyerSecret}`)\n return false\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the buyerSecret signed by the buyer\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the buyerSecret signed by the buyer\n */\nexport const getBuyerSecretSignedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): AsyncPayloadValidationFunction<EscrowTerms> => {\n return getPartySecretSignedValidator(dictionary, 'buyer')\n}\n","import type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nexport const getNbfExpValidator = (now: number, minRequiredDuration: number): SyncPayloadValidationFunction<EscrowTerms> => {\n const minExp = now + minRequiredDuration\n return (terms: EscrowTerms) => {\n const { exp, nbf } = terms\n if (nbf === undefined || nbf < now) {\n console.log(`EscrowTerms.nbf: invalid nbf ${terms.nbf}`)\n return false\n }\n if (exp === undefined || exp < minExp || nbf > exp) {\n console.log(`EscrowTerms.exp: invalid exp ${terms.exp}`)\n return false\n }\n return true\n }\n}\n","import type { ModuleIdentifier } from '@xyo-network/module-model'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { moduleIdentifiersContainsAllOf } from '../common/index.ts'\n\nconst name = 'EscrowTerms.paymentAuthorities'\n\nexport const getPaymentAuthoritiesAllowedValidator = (allowed: ModuleIdentifier[]): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const result = moduleIdentifiersContainsAllOf(terms, t => t.paymentAuthorities, allowed, true)\n if (!result) {\n console.log(`${name}: Payment authority not allowed: ${terms.paymentAuthorities}`)\n }\n return result\n }\n}\n","import { asAddress } from '@xylabs/hex'\nimport type { SyncPayloadValidationFunction } from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\n\nconst name = 'EscrowTerms.seller'\n\n/**\n * A function that validates the escrow terms for seller\n * @returns True if the escrow terms contain seller, false otherwise\n */\nexport const sellerExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have seller\n const seller = terms.seller\n if (!seller || seller.length === 0) {\n console.log(`${name}: No seller: ${terms.seller}`)\n return false\n }\n // Validate the authorities are addresses\n if (seller.map(x => asAddress(x)).length !== seller.length) {\n console.log(`${name}: Invalid address: ${terms.seller}`)\n return false\n }\n return true\n}\n","import { assertEx } from '@xylabs/assert'\nimport type { Hash } from '@xylabs/hex'\nimport type {\n AsyncPayloadValidationFunction, Payload, SyncPayloadValidationFunction, WithMeta,\n} from '@xyo-network/payload-model'\n\nimport type { EscrowTerms } from '../../Terms/index.ts'\nimport { getPartySecretSignedValidator } from '../common/index.ts'\n\nconst name = 'EscrowTerms.sellerSecret'\n\n/**\n * Returns a function that validates the escrow terms for sellerSecret\n * @returns A function that validates the escrow terms for sellerSecret\n */\nexport const sellerSecretExistsValidator: SyncPayloadValidationFunction<EscrowTerms> = (terms: EscrowTerms) => {\n // Validate we have sellerSecret\n const sellerSecret = terms.sellerSecret\n if (!sellerSecret || sellerSecret.length === 0) {\n console.log(`${name}: No sellerSecret: ${terms.sellerSecret}`)\n return false\n }\n return true\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the sellerSecret in the dictionary\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the sellerSecret in the dictionary\n */\nexport const getSellerSecretSuppliedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {\n return (terms: EscrowTerms) => {\n const sellerSecret = assertEx(terms.sellerSecret, () => `${name}: No sellerSecret: ${terms.sellerSecret}`)\n if (!dictionary[sellerSecret]) {\n console.log(`${name}: Payload not supplied for sellerSecret: ${sellerSecret}`)\n return false\n }\n return true\n }\n}\n\n/**\n * Returns a function that validates the escrow terms for the existence of the sellerSecret signed by the seller\n * @param dictionary Payload dictionary of the escrow terms\n * @returns A function that validates the escrow terms for the existence of the sellerSecret signed by the seller\n */\nexport const getSellerSecretSignedValidator = (dictionary: Record<Hash, WithMeta<Payload>>): AsyncPayloadValidationFunction<EscrowTerms> => {\n return getPartySecretSignedValidator(dictionary, 'seller')\n}\n","import type { Payload } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType, isPayloadOfSchemaTypeWithMeta, isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { PaymentCardSchema } from './Schema.ts'\n\n/**\n * The fields describing a payment card.\n */\nexport interface PaymentCardFields {\n /**\n * Card Number (PAN) of the payment card. This value is required to perform a payment.\n */\n cardNumber: string\n /**\n * The name as it appears on the payment card.\n */\n cardholderName?: string\n /**\n * Card Verification Value (CVV/CVC) of the payment card.\n */\n cvv: string\n /**\n * Expiration month of the payment card.\n */\n expMonth: number\n /**\n * Expiration year of the payment card.\n */\n expYear: number\n}\n\n/**\n * A PaymentCard Payload\n */\nexport type PaymentCard = Payload<PaymentCardFields, PaymentCardSchema>\n\n/**\n * Identity function for determine if an object is a PaymentCard\n */\nexport const isPaymentCard = isPayloadOfSchemaType<PaymentCard>(PaymentCardSchema)\n\n/**\n * Identity function for determine if an object is a PaymentCard with sources\n */\nexport const isPaymentCardWithSources = isPayloadOfSchemaTypeWithSources<PaymentCard>(PaymentCardSchema)\n\n/**\n * Identity function for determine if an object is a PaymentCard with meta\n */\nexport const isPaymentCardWithMeta = isPayloadOfSchemaTypeWithMeta<PaymentCard>(PaymentCardSchema)\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const PaymentSchema = `${PaymentsSchema}.payment`\nexport type PaymentSchema = typeof PaymentSchema\n","import { PaymentSchema } from '../Schema.ts'\n\nexport const PaymentInstrumentSchema = `${PaymentSchema}.instrument`\nexport type PaymentInstrumentSchema = typeof PaymentInstrumentSchema\n","import { PaymentInstrumentSchema } from '../Schema.ts'\n\nexport const PaymentCardSchema = `${PaymentInstrumentSchema}.card`\nexport type PaymentCardSchema = typeof PaymentCardSchema\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { SupportedCurrency } from '../Currency.ts'\nimport { PaymentSchema } from './Schema.ts'\n\nexport interface PaymentFields {\n /**\n * The amount paid\n */\n amount: number\n /**\n * The currency of the amount paid\n */\n currency: SupportedCurrency\n}\n\n/**\n * A payment is a record of an amount to be paid\n */\nexport type Payment = PayloadWithSources<PaymentFields, PaymentSchema>\n\n/**\n * Identity function for determine if an object is a Payment\n */\nexport const isPayment = isPayloadOfSchemaType<Payment>(PaymentSchema)\n\n/**\n * Identity function for determine if an object is a Payment with sources\n */\nexport const isPaymentWithSources = isPayloadOfSchemaTypeWithSources<Payment>(PaymentSchema)\n\n/**\n * Identity function for determine if an object is a Payment with meta\n */\nexport const isPaymentWithMeta = isPayloadOfSchemaTypeWithMeta<Payment>(PaymentSchema)\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { PaymentStatusSchema } from './Schema.ts'\n\nexport interface PaymentStatusFields {\n /**\n * The result of the payment (i.e. declined)\n */\n result?: string\n\n /**\n * The status of the payment (i.e. completed)\n */\n status: string\n}\n\n/**\n * A payment status is the outcome of a payment attempt\n */\nexport type PaymentStatus = PayloadWithSources<PaymentStatusFields, PaymentStatusSchema>\n\n/**\n * Identity function for determine if an object is a PaymentStatus\n */\nexport const isPaymentStatus = isPayloadOfSchemaType<PaymentStatus>(PaymentStatusSchema)\n\n/**\n * Identity function for determine if an object is a PaymentStatus with sources\n */\nexport const isPaymentStatusWithSources = isPayloadOfSchemaTypeWithSources<PaymentStatus>(PaymentStatusSchema)\n\n/**\n * Identity function for determine if an object is a PaymentStatus with meta\n */\nexport const isPaymentStatusWithMeta = isPayloadOfSchemaTypeWithMeta<PaymentStatus>(PaymentStatusSchema)\n","import { PaymentSchema } from '../Schema.ts'\n\nexport const PaymentStatusSchema = `${PaymentSchema}.status`\nexport type PaymentStatusSchema = typeof PaymentStatusSchema\n","import type { Hash } from '@xylabs/hex'\nimport type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport { PurchaseSchema } from './Schema.ts'\n\nexport interface PurchaseFields {\n /**\n * The things that were purchased\n */\n assets: Hash[]\n /**\n * The receipts for payments for this purchase. Array to allow for multiple payments\n * for a single quote.\n */\n receipts: Hash[]\n}\n\n/**\n * A purchase ties a payment made to a quote\n */\nexport type Purchase = PayloadWithSources<PurchaseFields, PurchaseSchema>\n\n/**\n * Identity function for determine if an object is a Purchase\n */\nexport const isPurchase = isPayloadOfSchemaType<Purchase>(PurchaseSchema)\n\n/**\n * Identity function for determine if an object is a Purchase with sources\n */\nexport const isPurchaseWithSources = isPayloadOfSchemaTypeWithSources<Purchase>(PurchaseSchema)\n\n/**\n * Identity function for determine if an object is a Purchase with meta\n */\nexport const isPurchaseWithMeta = isPayloadOfSchemaTypeWithMeta<Purchase>(PurchaseSchema)\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const PurchaseSchema = `${PaymentsSchema}.purchase`\nexport type PurchaseSchema = typeof PurchaseSchema\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { SupportedCurrency } from '../Currency.ts'\nimport { ReceiptSchema } from './Schema.ts'\n\nexport interface ReceiptFields {\n /**\n * The amount paid\n */\n amount: number\n /**\n * The currency of the amount paid\n */\n currency: SupportedCurrency\n}\n\n/**\n * A receipt is a record of a payment made\n */\nexport type Receipt = PayloadWithSources<ReceiptFields, ReceiptSchema>\n\n/**\n * Identity function for determine if an object is a Receipt\n */\nexport const isReceipt = isPayloadOfSchemaType<Receipt>(ReceiptSchema)\n\n/**\n * Identity function for determine if an object is a Receipt with sources\n */\nexport const isReceiptWithSources = isPayloadOfSchemaTypeWithSources<Receipt>(ReceiptSchema)\n\n/**\n * Identity function for determine if an object is a Receipt with meta\n */\nexport const isReceiptWithMeta = isPayloadOfSchemaTypeWithMeta<Receipt>(ReceiptSchema)\n","import { PaymentsSchema } from '../Schema.ts'\n\nexport const ReceiptSchema = `${PaymentsSchema}.receipt`\nexport type ReceiptSchema = typeof ReceiptSchema\n","// import type { Hash } from '@xylabs/hex'\nimport type { DivinerConfig } from '@xyo-network/diviner-model'\n\nexport const PaymentSubtotalDivinerConfigSchema = 'network.xyo.diviner.payments.subtotal.config'\nexport type PaymentSubtotalDivinerConfigSchema = typeof PaymentSubtotalDivinerConfigSchema\n\n/**\n * The configuration for the Coupon Subtotal Diviner\n */\nexport type PaymentSubtotalDivinerConfig = DivinerConfig<\n {},\n PaymentSubtotalDivinerConfigSchema\n>\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../Amount/index.ts'\n\nexport const SubtotalSchema = 'network.xyo.payments.subtotal' as const\nexport type SubtotalSchema = typeof SubtotalSchema\n\nexport interface SubtotalFields extends AmountFields {}\n\n/**\n * The result of a subtotal\n */\nexport type Subtotal = PayloadWithSources<SubtotalFields, SubtotalSchema>\n\n/**\n * Identity function for determining if an object is an Subtotal\n */\nexport const isSubtotal = isPayloadOfSchemaType<Subtotal>(SubtotalSchema)\n\n/**\n * Identity function for determining if an object is an Subtotal with sources\n */\nexport const isSubtotalWithSources = isPayloadOfSchemaTypeWithSources<Subtotal>(SubtotalSchema)\n\n/**\n * Identity function for determining if an object is an Subtotal with meta\n */\nexport const isSubtotalWithMeta = isPayloadOfSchemaTypeWithMeta<Subtotal>(SubtotalSchema)\n","// import type { Hash } from '@xylabs/hex'\nimport type { DivinerConfig } from '@xyo-network/diviner-model'\nimport type { ModuleIdentifier } from '@xyo-network/module-model'\n\nexport const PaymentTotalDivinerConfigSchema = 'network.xyo.diviner.payments.total.config'\nexport type PaymentTotalDivinerConfigSchema = typeof PaymentTotalDivinerConfigSchema\n\n/**\n * The configuration for the Total Diviner\n */\nexport type PaymentTotalDivinerConfig = DivinerConfig<\n {\n /**\n * The Diviner that will be used to determine the discount\n */\n paymentDiscountDiviner?: ModuleIdentifier\n\n /**\n * The Diviner that will be used to determine the subtotal\n */\n paymentSubtotalDiviner?: ModuleIdentifier\n },\n PaymentTotalDivinerConfigSchema\n>\n","import type { PayloadWithSources } from '@xyo-network/payload-model'\nimport {\n isPayloadOfSchemaType,\n isPayloadOfSchemaTypeWithMeta,\n isPayloadOfSchemaTypeWithSources,\n} from '@xyo-network/payload-model'\n\nimport type { AmountFields } from '../../Amount/index.ts'\n\nexport const TotalSchema = 'network.xyo.payments.total' as const\nexport type TotalSchema = typeof TotalSchema\n\nexport interface TotalFields extends AmountFields {}\n\n/**\n * The result of a total\n */\nexport type Total = PayloadWithSources<TotalFields, TotalSchema>\n\n/**\n * Identity function for determining if an object is an Total\n */\nexport const isTotal = isPayloadOfSchemaType<Total>(TotalSchema)\n\n/**\n * Identity function for determining if an object is an Total with sources\n */\nexport const isTotalWithSources = isPayloadOfSchemaTypeWithSources<Total>(TotalSchema)\n\n/**\n * Identity function for determining if an object is an Total with meta\n */\nexport const isTotalWithMeta = isPayloadOfSchemaTypeWithMeta<Total>(TotalSchema)\n"],"mappings":";AAsXO,IAAM,uBAA4E;AAAA,EACvF,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,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","names":["isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","SchemaSchema","SchemaSchema","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","SchemaSchema","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isBoundWitnessWithMeta","BoundWitnessBuilder","BoundWitnessBuilder","getLogPrefix","errors","isBoundWitnessWithMeta","name","isBoundWitnessWithMeta","name","name","asAddress","name","assertEx","name","assertEx","name","asAddress","name","assertEx","name","assertEx","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources","isPayloadOfSchemaType","isPayloadOfSchemaTypeWithMeta","isPayloadOfSchemaTypeWithSources"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/payment-payload-plugins",
3
- "version": "3.0.25",
3
+ "version": "3.0.27",
4
4
  "description": "Typescript/Javascript Plugins for XYO Platform",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -32,23 +32,24 @@
32
32
  "@xylabs/assert": "^4.0.10",
33
33
  "@xylabs/crypto": "^4.0.10",
34
34
  "@xylabs/hex": "^4.0.10",
35
- "@xyo-network/account-model": "^3.1.11",
36
- "@xyo-network/boundwitness-builder": "^3.1.11",
37
- "@xyo-network/boundwitness-model": "^3.1.11",
38
- "@xyo-network/boundwitness-validator": "^3.1.11",
39
- "@xyo-network/diviner-hash-lease": "^3.1.11",
40
- "@xyo-network/diviner-model": "^3.1.11",
41
- "@xyo-network/id-payload-plugin": "^3.1.11",
42
- "@xyo-network/module-model": "^3.1.11",
43
- "@xyo-network/payload-model": "^3.1.11",
44
- "@xyo-network/schema-payload-plugin": "^3.1.11",
45
- "@xyo-network/xns-record-payload-plugins": "^3.0.25"
35
+ "@xyo-network/account-model": "^3.1.14",
36
+ "@xyo-network/boundwitness-builder": "^3.1.14",
37
+ "@xyo-network/boundwitness-model": "^3.1.14",
38
+ "@xyo-network/boundwitness-validator": "^3.1.14",
39
+ "@xyo-network/diviner-hash-lease": "^3.1.14",
40
+ "@xyo-network/diviner-model": "^3.1.14",
41
+ "@xyo-network/id-payload-plugin": "^3.1.14",
42
+ "@xyo-network/module-model": "^3.1.14",
43
+ "@xyo-network/payload-builder": "^3.1.14",
44
+ "@xyo-network/payload-model": "^3.1.14",
45
+ "@xyo-network/schema-payload-plugin": "^3.1.14",
46
+ "@xyo-network/xns-record-payload-plugins": "^3.0.27"
46
47
  },
47
48
  "devDependencies": {
48
49
  "@xylabs/ts-scripts-yarn3": "^4.0.7",
49
50
  "@xylabs/tsconfig": "^4.0.7",
50
- "@xyo-network/account": "^3.1.11",
51
- "@xyo-network/payload-builder": "^3.1.11",
51
+ "@xyo-network/account": "^3.1.14",
52
+ "@xyo-network/payload-builder": "^3.1.14",
52
53
  "typescript": "^5.5.4"
53
54
  },
54
55
  "publishConfig": {
@@ -0,0 +1,33 @@
1
+ import type { Hash } from '@xylabs/hex'
2
+ import { type HashLeaseEstimate, isHashLeaseEstimateWithSources } from '@xyo-network/diviner-hash-lease'
3
+ import type {
4
+ Payload, WithMeta, WithSources,
5
+ } from '@xyo-network/payload-model'
6
+
7
+ import type { EscrowTerms } from '../../Terms/index.ts'
8
+
9
+ /**
10
+ * Returns a dictionary of asset hashes and their associated appraisals
11
+ * @param terms The escrow terms
12
+ * @param dictionary The dictionary of payloads associated with the escrow terms
13
+ * @returns A dictionary of asset hashes and their associated appraisals
14
+ */
15
+ export const getAppraisalsByAsset = (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>): Record<Hash, WithSources<HashLeaseEstimate>[]> => {
16
+ const assets = terms.assets
17
+ if (!assets || assets.length === 0) return {}
18
+ const appraisals = Object.values(dictionary).filter(isHashLeaseEstimateWithSources) as unknown as WithSources<HashLeaseEstimate>[]
19
+ const appraisalsByAsset: Record<Hash, WithSources<HashLeaseEstimate>[]> = {}
20
+ for (const estimate of appraisals) {
21
+ const { sources } = estimate
22
+ if (sources === undefined || sources.length === 0) {
23
+ continue
24
+ }
25
+ for (const asset of assets) {
26
+ if (sources.includes(asset)) {
27
+ if (!appraisalsByAsset[asset]) appraisalsByAsset[asset] = []
28
+ appraisalsByAsset[asset].push(estimate)
29
+ }
30
+ }
31
+ }
32
+ return appraisalsByAsset
33
+ }
@@ -0,0 +1,39 @@
1
+ import type { Hash } from '@xylabs/hex'
2
+ import { type BoundWitness, isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'
3
+ import type { Payload, WithMeta } from '@xyo-network/payload-model'
4
+
5
+ import type { EscrowTerms } from '../../Terms/index.ts'
6
+
7
+ /**
8
+ * Returns a dictionary of appraisals and their associated bound witnesses which are signed by
9
+ * valid appraisal authorities from the escrow terms
10
+ * @param terms The escrow terms
11
+ * @param dictionary The diction of payloads associated with the escrow terms
12
+ * @returns A dictionary of appraisals and their associated bound witnesses
13
+ */
14
+ export const getSignaturesByAppraisal = (
15
+ terms: EscrowTerms,
16
+ dictionary: Record<Hash, WithMeta<Payload>>,
17
+ ): Record<Hash, WithMeta<BoundWitness>[]> => {
18
+ // Validate inputs
19
+ const appraisals = terms.appraisals
20
+ if (!appraisals || appraisals.length === 0) return {}
21
+ const appraisalAuthorities = terms.appraisalAuthorities
22
+ if (!appraisalAuthorities || appraisalAuthorities.length === 0) return {}
23
+
24
+ // Validate the appraisals are signed by valid appraisal authorities. Validation criteria:
25
+ // - The bw includes the appraisal hash from the escrow terms appraisal
26
+ // - The bw is signed by an approved appraisal authority from the escrow terms appraisalAuthorities
27
+ const appraisalBWsValid: Record<Hash, WithMeta<BoundWitness>[]> = Object.fromEntries(
28
+ appraisals.map<[Hash, WithMeta<BoundWitness>[]]>(hash => [hash, []]),
29
+ )
30
+ for (const bw of Object.values(dictionary).filter(isBoundWitnessWithMeta)) {
31
+ for (const appraisal of appraisals) {
32
+ if (bw.payload_hashes.includes(appraisal) && bw.addresses.some(address => appraisalAuthorities.includes(address))) {
33
+ appraisalBWsValid[appraisal].push(bw)
34
+ }
35
+ }
36
+ }
37
+
38
+ return appraisalBWsValid
39
+ }
@@ -0,0 +1,2 @@
1
+ export * from './getAppraisalsByAsset.ts'
2
+ export * from './getSignaturesByAppraisal.ts'
@@ -1 +1,2 @@
1
+ export * from './appraisal/index.ts'
1
2
  export * from './secret/index.ts'
@@ -3,12 +3,12 @@ import type { Hash } from '@xylabs/hex'
3
3
  import type { BoundWitness } from '@xyo-network/boundwitness-model'
4
4
  import { isBoundWitnessWithMeta } from '@xyo-network/boundwitness-model'
5
5
  import type { HashLeaseEstimate } from '@xyo-network/diviner-hash-lease'
6
- import { isHashLeaseEstimateWithSources } from '@xyo-network/diviner-hash-lease'
7
6
  import type {
8
7
  Payload, SyncPayloadValidationFunction, WithMeta, WithSources,
9
8
  } from '@xyo-network/payload-model'
10
9
 
11
10
  import type { EscrowTerms } from '../../Terms/index.ts'
11
+ import { getAppraisalsByAsset } from '../../util/index.ts'
12
12
  import { validateWithinWindow } from '../common/index.ts'
13
13
 
14
14
  const name = 'EscrowTerms.appraisal'
@@ -73,7 +73,7 @@ export const getAppraisalsValidValidator = (
73
73
  ): SyncPayloadValidationFunction<EscrowTerms> => {
74
74
  return (terms: EscrowTerms) => {
75
75
  // Verify we have an estimate for each of the assets
76
- const estimatesByAsset = getEstimatesByAsset(terms, dictionary)
76
+ const estimatesByAsset = getAppraisalsByAsset(terms, dictionary)
77
77
  // Validate each of the estimates are valid (time, price, etc)
78
78
  const now = Date.now()
79
79
  const exp = now + minimumExp
@@ -97,8 +97,8 @@ export const getAppraisalsValidValidator = (
97
97
  export const getAppraisalsForAllAssetsValidator = (dictionary: Record<Hash, WithMeta<Payload>>): SyncPayloadValidationFunction<EscrowTerms> => {
98
98
  return (terms: EscrowTerms) => {
99
99
  // Verify we have an estimate for each of the assets
100
- const estimatesByAsset = getEstimatesByAsset(terms, dictionary)
101
100
  const assets = assertEx(terms.assets, () => `${name}: No assets: ${terms.assets}`)
101
+ const estimatesByAsset = getAppraisalsByAsset(terms, dictionary)
102
102
  if (Object.keys(estimatesByAsset).length !== assets.length) {
103
103
  console.log(`${name}: Missing appraisals for all assets: ${assets}`)
104
104
  return false
@@ -113,23 +113,3 @@ const validateEstimate = (estimate: WithSources<HashLeaseEstimate>, exp: number)
113
113
  if (estimate.price < 0) return false
114
114
  return true
115
115
  }
116
-
117
- const getEstimatesByAsset = (terms: EscrowTerms, dictionary: Record<Hash, WithMeta<Payload>>): Record<Hash, WithSources<HashLeaseEstimate>[]> => {
118
- const assets = assertEx(terms.assets, () => `${name}: No assets: ${terms.assets}`)
119
- const estimates = Object.values(dictionary).filter(isHashLeaseEstimateWithSources) as unknown as WithSources<HashLeaseEstimate>[]
120
- const estimatesByAsset: Record<Hash, WithSources<HashLeaseEstimate>[]> = {}
121
- for (const estimate of estimates) {
122
- const { sources } = estimate
123
- if (sources === undefined || sources.length === 0) {
124
- console.log(`${name}: No sources: ${estimate}`)
125
- continue
126
- }
127
- for (const asset of assets) {
128
- if (sources.includes(asset)) {
129
- if (!estimatesByAsset[asset]) estimatesByAsset[asset] = []
130
- estimatesByAsset[asset].push(estimate)
131
- }
132
- }
133
- }
134
- return estimatesByAsset
135
- }