@getalby/lightning-tools 4.1.0 → 4.2.0

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.
package/README.md CHANGED
@@ -215,6 +215,20 @@ await l402.fetchWithL402(
215
215
  );
216
216
  ```
217
217
 
218
+ ### Basic invoice decoding
219
+
220
+ You can initialize an `Invoice` to decode a payment request.
221
+
222
+ ```js
223
+ const { Invoice } = require("alby-tools");
224
+
225
+ const invoice = new Invoice({ pr });
226
+
227
+ const { paymentHash, satoshi, description, createdDate, expiryDate } = invoice;
228
+ ```
229
+
230
+ > If you need more details about the invoice, use a dedicated BOLT11 decoding library.
231
+
218
232
  ### 💵 Fiat conversions
219
233
 
220
234
  Helpers to convert sats values to fiat and fiat values to sats.
@@ -1,10 +1,10 @@
1
1
  (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
2
- var e=require("crypto-js/enc-hex.js"),t=require("crypto-js/sha256.js"),r=require("light-bolt11-decoder");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=/*#__PURE__*/n(e),a=/*#__PURE__*/n(t),i=/*#__PURE__*/function(){function e(e){this.storage=void 0,this.storage=e||{}}var t=e.prototype;return t.getItem=function(e){return this.storage[e]},t.setItem=function(e,t){this.storage[e]=t},e}(),s={__proto__:null,MemoryStorage:i,NoStorage:/*#__PURE__*/function(){function e(e){}var t=e.prototype;return t.getItem=function(e){return null},t.setItem=function(e,t){},e}(),default:i},u=new i,c=function(e,t,r){try{var n,o=function(r){return n?r:(t.headers["Accept-Authenticate"]=a,Promise.resolve(fetch(e,t)).then(function(r){var n=r.headers.get("www-authenticate");if(!n)return r;var o,u=(o=n.replace("L402","").replace("LSAT","").split(",").map(function(e){var t=e.split("=").map(function(e){return e.trim()});return[t[0],t[1].match(/"?([^"]*)"?/)[1]]}),Object.fromEntries(o)),c=u.token||u.macaroon,l=u.invoice;return Promise.resolve(i.enable()).then(function(){return Promise.resolve(i.sendPayment(l)).then(function(r){return s.setItem(e,JSON.stringify({token:c,preimage:r.preimage})),t.headers.Authorization=a+" "+c+":"+r.preimage,Promise.resolve(fetch(e,t))})})}))};r||(r={});var a=r.headerKey||"L402",i=r.webln||globalThis.webln;if(!i)throw new Error("WebLN is missing");var s=r.store||u;t||(t={}),t.cache="no-store",t.mode="cors",t.headers||(t.headers={});var c=s.getItem(e),l=function(){if(c){var r=JSON.parse(c);return t.headers.Authorization=a+" "+r.token+":"+r.preimage,Promise.resolve(fetch(e,t)).then(function(e){return n=1,e})}}();return Promise.resolve(l&&l.then?l.then(o):o(l))}catch(e){return Promise.reject(e)}},l={__proto__:null,storage:s,fetchWithL402:c,default:c},h=function(e,t){try{var r=e.boost,n=e.amount;t||(t={});var o=t.webln||globalThis.webln;n||(n=Math.floor(r.value_msat/1e3));var a={destination:e.destination,amount:n,customRecords:{7629169:JSON.stringify(r)}};return e.customKey&&e.customValue&&(a.customRecords[e.customKey]=e.customValue),Promise.resolve(o.enable()).then(function(){return Promise.resolve(o.keysend(a))})}catch(e){return Promise.reject(e)}},m={__proto__:null,boost:h,default:h};function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},f.apply(this,arguments)}var v=/((([A-Za-z]{3,9}:(?:\/\/)?)(?:[-;:&=\+\$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=\+\$,\w]+@)[A-Za-z0-9.-]+)((?:\/[\+~%\/.\w-_]*)?\??(?:[-\+=&;%@.\w_]*)#?(?:[\w]*))?)/,p=function(e){return!!e&&v.test(e)},d=function(e){var t=e.amount;return t>0&&t>=e.min&&t<=e.max},y=/*#__PURE__*/function(){function e(e){var t,n;this.paymentRequest=void 0,this.paymentHash=void 0,this.preimage=void 0,this.verify=void 0,this.paymentRequest=e.pr,this.paymentHash=function(e){if(!e)return null;try{var t=r.decode(e);if(!t||!t.sections)return null;var n=t.sections.find(function(e){return"payment_hash"===e.name});return n&&n.value?n.value.toString():null}catch(e){return null}}(this.paymentRequest),this.verify=null!=(t=e.verify)?t:null,this.preimage=null!=(n=e.preimage)?n:null}var t=e.prototype;return t.isPaid=function(){try{var e=this;if(e.preimage)return Promise.resolve(e.validatePreimage(e.preimage));if(e.verify)return Promise.resolve(e.verifyPayment());throw new Error("Could not verify payment")}catch(e){return Promise.reject(e)}},t.validatePreimage=function(e){if(!e||!this.paymentHash)return!1;try{var t=a.default(o.default.parse(e)).toString(o.default);return this.paymentHash===t}catch(e){return!1}},t.verifyPayment=function(){try{var e=this;if(!e.verify)throw new Error("LNURL verify not available");return Promise.resolve(fetch(e.verify)).then(function(t){return Promise.resolve(t.json()).then(function(t){return t.preimage&&(e.preimage=t.preimage),t.settled})})}catch(e){return Promise.reject(e)}},e}(),w=function(e,t){var r=e.satoshi,n=e.comment,o=e.p,a=e.e,i=e.relays;void 0===t&&(t={});try{var s=t.nostr||globalThis.nostr;if(!s)throw new Error("nostr option or window.nostr is not available");var u=[["relays"].concat(i),["amount",r.toString()]];return o&&u.push(["p",o]),a&&u.push(["e",a]),Promise.resolve(s.getPublicKey()).then(function(e){var t={pubkey:e,created_at:Math.floor(Date.now()/1e3),kind:9734,tags:u,content:null!=n?n:""};return t.id=P(t),Promise.resolve(s.signEvent(t))})}catch(a){return Promise.reject(a)}};function g(e){if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if(!Array.isArray(e.tags))return!1;for(var t=0;t<e.tags.length;t++){var r=e.tags[t];if(!Array.isArray(r))return!1;for(var n=0;n<r.length;n++)if("object"==typeof r[n])return!1}return!0}function b(e){if(!g(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function P(e){return a.default(b(e)).toString(o.default)}function k(e,t){var r,n,o,a;return t&&e&&(n=(r=null==(o=e.names)?void 0:o[t])?null==(a=e.relays)?void 0:a[r]:void 0),[e,r,n]}var j={__proto__:null,generateZapEvent:w,validateEvent:g,serializeEvent:b,getEventHash:P,parseNostrResponse:k},E=/^((?:[^<>()\[\]\\.,;:\s@"]+(?:\.[^<>()\[\]\\.,;:\s@"]+)*)|(?:".+"))@((?:\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(?:(?:[a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,x=/*#__PURE__*/function(){function e(e,t){this.address=void 0,this.options=void 0,this.username=void 0,this.domain=void 0,this.pubkey=void 0,this.lnurlpData=void 0,this.keysendData=void 0,this.nostrData=void 0,this.nostrPubkey=void 0,this.nostrRelays=void 0,this.webln=void 0,this.address=e,this.options={proxy:"https://api.getalby.com/lnurl"},this.options=Object.assign(this.options,t),this.parse(),this.webln=this.options.webln}var t=e.prototype;return t.parse=function(){var e=E.exec(this.address.toLowerCase());e&&(this.username=e[1],this.domain=e[2])},t.getWebLN=function(){return this.webln||globalThis.webln},t.fetch=function(){try{var e=this;return Promise.resolve(e.options.proxy?e.fetchWithProxy():e.fetchWithoutProxy())}catch(e){return Promise.reject(e)}},t.fetchWithProxy=function(){try{var e=this;return Promise.resolve(fetch(e.options.proxy+"/lightning-address-details?"+new URLSearchParams({ln:e.address}).toString())).then(function(t){return Promise.resolve(t.json()).then(function(t){e.parseResponse(t.lnurlp,t.keysend,t.nostr)})})}catch(e){return Promise.reject(e)}},t.fetchWithoutProxy=function(){try{var e=this;return e.domain&&e.username?Promise.resolve(fetch(e.lnurlpUrl())).then(function(t){return Promise.resolve(fetch(e.keysendUrl())).then(function(r){return Promise.resolve(fetch(e.nostrUrl())).then(function(n){function o(){function t(){function t(){e.parseResponse(a,o,r)}var r,i=function(){if(n.ok)return Promise.resolve(n.json()).then(function(e){r=e})}();return i&&i.then?i.then(t):t()}var o,i=function(){if(r.ok)return Promise.resolve(r.json()).then(function(e){o=e})}();return i&&i.then?i.then(t):t()}var a,i=function(){if(t.ok)return Promise.resolve(t.json()).then(function(e){a=e})}();return i&&i.then?i.then(o):o()})})}):Promise.resolve()}catch(e){return Promise.reject(e)}},t.lnurlpUrl=function(){return"https://"+this.domain+"/.well-known/lnurlp/"+this.username},t.keysendUrl=function(){return"https://"+this.domain+"/.well-known/keysend/"+this.username},t.nostrUrl=function(){return"https://"+this.domain+"/.well-known/nostr.json?name="+this.username},t.generateInvoice=function(e){try{var t,r=function(e){var r=t&&t.pr&&t.pr.toString();if(!r)throw new Error("Invalid pay service invoice");var n={pr:r};return t&&t.verify&&(n.verify=t.verify.toString()),new y(n)},n=this,o=function(){if(n.options.proxy)return Promise.resolve(fetch(n.options.proxy+"/generate-invoice?"+new URLSearchParams(f({ln:n.address},e)).toString())).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e.invoice})});if(!n.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!n.lnurlpData.callback||!p(n.lnurlpData.callback))throw new Error("Valid callback does not exist in lnurlpData");var r=new URL(n.lnurlpData.callback);return r.search=new URLSearchParams(e).toString(),Promise.resolve(fetch(r)).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e})})}();return Promise.resolve(o&&o.then?o.then(r):r())}catch(e){return Promise.reject(e)}},t.requestInvoice=function(e){try{var t=this;if(!t.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");var r=1e3*e.satoshi,n=t.lnurlpData,o=n.commentAllowed;if(!d({amount:r,min:n.min,max:n.max}))throw new Error("Invalid amount");if(e.comment&&o&&o>0&&e.comment.length>o)throw new Error("The comment length must be "+o+" characters or fewer");var a={amount:r.toString()};return e.comment&&(a.comment=e.comment),e.payerdata&&(a.payerdata=JSON.stringify(e.payerdata)),Promise.resolve(t.generateInvoice(a))}catch(e){return Promise.reject(e)}},t.boost=function(e,t){void 0===t&&(t=0);try{var r=this;if(!r.keysendData)throw new Error("No keysendData available. Please call fetch() first.");var n=r.keysendData,o=n.destination,a=n.customKey,i=n.customValue,s=r.getWebLN();if(!s)throw new Error("WebLN not available");return Promise.resolve(h({destination:o,customKey:a,customValue:i,amount:t,boost:e},{webln:s}))}catch(e){return Promise.reject(e)}},t.zapInvoice=function(e,t){var r=e.satoshi,n=e.comment,o=e.relays,a=e.e;void 0===t&&(t={});try{var i=this;if(!i.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!i.nostrPubkey)throw new Error("Nostr Pubkey is missing");var s=i.nostrPubkey,u=1e3*r,c=i.lnurlpData,l=c.allowsNostr;if(!d({amount:u,min:c.min,max:c.max}))throw new Error("Invalid amount");if(!l)throw new Error("Your provider does not support zaps");return Promise.resolve(w({satoshi:u,comment:n,p:s,e:a,relays:o},t)).then(function(e){var t={amount:u.toString(),nostr:JSON.stringify(e)};return Promise.resolve(i.generateInvoice(t))})}catch(a){return Promise.reject(a)}},t.zap=function(e,t){void 0===t&&(t={});try{var r=this.zapInvoice(e,t),n=this.getWebLN();if(!n)throw new Error("WebLN not available");return Promise.resolve(n.enable()).then(function(){var e=n.sendPayment;return Promise.resolve(r).then(function(t){return e.call(n,t.paymentRequest)})})}catch(e){return Promise.reject(e)}},t.parseResponse=function(e,t,r){if(e&&(this.lnurlpData=function(e){if("payRequest"!==e.tag)throw new Error("Invalid pay service params");var t=(e.callback+"").trim();if(!p(t))throw new Error("Callback must be a valid url");var r,n,i=Math.ceil(Number(e.minSendable||0)),s=Math.floor(Number(e.maxSendable));if(!i||!s||i>s)throw new Error("Invalid pay service params");try{r=JSON.parse(e.metadata+""),n=a.default(e.metadata+"").toString(o.default)}catch(e){r=[],n=a.default("[]").toString(o.default)}for(var u="",c="",l="",h=0;h<r.length;h++){var m=r[h],f=m[0],v=m[1];switch(f){case"text/plain":c=v;break;case"text/identifier":l=v;break;case"image/png;base64":case"image/jpeg;base64":u="data:"+f+","+v}}var d,y=e.payerData;try{d=new URL(t).hostname}catch(e){}return{callback:t,fixed:i===s,min:i,max:s,domain:d,metadata:r,metadataHash:n,identifier:l,description:c,image:u,payerData:y,commentAllowed:Number(e.commentAllowed)||0,rawData:e,allowsNostr:e.allowsNostr||!1}}(e)),t&&(this.keysendData=function(e){if("keysend"!==e.tag)throw new Error("Invalid keysend params");if("OK"!==e.status)throw new Error("Keysend status not OK");if(!("customKey"in e.customData[0])||"696969"!=e.customData[0].customKey)throw new Error("Unable to find customKey");if(!("customValue"in e.customData[0])||!e.customData[0].customValue)throw new Error("Unable to find customValue");if(!e.pubkey)throw new Error("Pubkey does not exist");return{destination:e.pubkey,customKey:e.customData[0].customKey,customValue:e.customData[0].customValue}}(t)),r){var n=k(r,this.username);this.nostrData=n[0],this.nostrPubkey=n[1],this.nostrRelays=n[2]}},e}(),D=function(e){try{var t="https://getalby.com/api/rates/"+e.toLowerCase()+".json";return Promise.resolve(fetch(t)).then(function(e){return Promise.resolve(e.json()).then(function(e){return e.rate_float/1e8})})}catch(e){return Promise.reject(e)}},S=function(e){var t=e.satoshi;return Promise.resolve(D(e.currency)).then(function(e){return Number(t)*e})},N={__proto__:null,getFiatBtcRate:D,getFiatValue:S,getSatoshiValue:function(e){var t=e.amount;return Promise.resolve(D(e.currency)).then(function(e){return Math.floor(Number(t)/e)})},getFormattedFiatValue:function(e){var t=e.currency,r=e.locale;return r||(r="en"),Promise.resolve(S({satoshi:e.satoshi,currency:t})).then(function(e){return e.toLocaleString(r,{style:"currency",currency:t})})}};exports.Invoice=y,exports.LightningAddress=x,exports.boostagrams=m,exports.fetchWithL402=c,exports.fiat=N,exports.l402=l,exports.nostr=j,exports.sendBoostagram=h;
2
+ var e=require("crypto-js/enc-hex.js"),t=require("crypto-js/sha256.js"),r=require("light-bolt11-decoder");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=/*#__PURE__*/n(e),i=/*#__PURE__*/n(t),a=/*#__PURE__*/function(){function e(e){this.storage=void 0,this.storage=e||{}}var t=e.prototype;return t.getItem=function(e){return this.storage[e]},t.setItem=function(e,t){this.storage[e]=t},e}(),s={__proto__:null,MemoryStorage:a,NoStorage:/*#__PURE__*/function(){function e(e){}var t=e.prototype;return t.getItem=function(e){return null},t.setItem=function(e,t){},e}(),default:a},u=new a,l=function(e,t,r){try{var n,o=function(r){return n?r:(t.headers["Accept-Authenticate"]=i,Promise.resolve(fetch(e,t)).then(function(r){var n=r.headers.get("www-authenticate");if(!n)return r;var o,u=(o=n.replace("L402","").replace("LSAT","").split(",").map(function(e){var t=e.split("=").map(function(e){return e.trim()});return[t[0],t[1].match(/"?([^"]*)"?/)[1]]}),Object.fromEntries(o)),l=u.token||u.macaroon,c=u.invoice;return Promise.resolve(a.enable()).then(function(){return Promise.resolve(a.sendPayment(c)).then(function(r){return s.setItem(e,JSON.stringify({token:l,preimage:r.preimage})),t.headers.Authorization=i+" "+l+":"+r.preimage,Promise.resolve(fetch(e,t))})})}))};r||(r={});var i=r.headerKey||"L402",a=r.webln||globalThis.webln;if(!a)throw new Error("WebLN is missing");var s=r.store||u;t||(t={}),t.cache="no-store",t.mode="cors",t.headers||(t.headers={});var l=s.getItem(e),c=function(){if(l){var r=JSON.parse(l);return t.headers.Authorization=i+" "+r.token+":"+r.preimage,Promise.resolve(fetch(e,t)).then(function(e){return n=1,e})}}();return Promise.resolve(c&&c.then?c.then(o):o(c))}catch(e){return Promise.reject(e)}},c={__proto__:null,storage:s,fetchWithL402:l,default:l},h=function(e,t){try{var r=e.boost;t||(t={});var n=t.webln||globalThis.webln;if(!n)throw new Error("WebLN not available");if(!n.keysend)throw new Error("Keysend not available in current WebLN provider");var o=e.amount||Math.floor(r.value_msat/1e3),i={destination:e.destination,amount:o,customRecords:{7629169:JSON.stringify(r)}};return e.customKey&&e.customValue&&(i.customRecords[e.customKey]=e.customValue),Promise.resolve(n.enable()).then(function(){return Promise.resolve(n.keysend(i))})}catch(e){return Promise.reject(e)}},m={__proto__:null,boost:h,default:h};function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},f.apply(this,arguments)}var v=/((([A-Za-z]{3,9}:(?:\/\/)?)(?:[-;:&=+$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=+$,\w]+@)[A-Za-z0-9.-]+)((?:\/[+~%/.\w-_]*)?\??(?:[-+=&;%@.\w_]*)#?(?:[\w]*))?)/,p=function(e){return!!e&&v.test(e)},d=function(e){var t=e.amount;return t>0&&t>=e.min&&t<=e.max},y=/*#__PURE__*/function(){function e(e){var t,n,o;if(this.paymentRequest=void 0,this.paymentHash=void 0,this.preimage=void 0,this.verify=void 0,this.satoshi=void 0,this.expiry=void 0,this.timestamp=void 0,this.createdDate=void 0,this.expiryDate=void 0,this.description=void 0,this.paymentRequest=e.pr,!this.paymentRequest)throw new Error("Invalid payment request");var i=function(e){if(!e)return null;try{var t=r.decode(e);if(!t||!t.sections)return null;var n=t.sections.find(function(e){return"payment_hash"===e.name});if("payment_hash"!==(null==n?void 0:n.name)||!n.value)return null;var o=n.value,i=t.sections.find(function(e){return"amount"===e.name});if("amount"!==(null==i?void 0:i.name)||void 0===i.value)return null;var a=parseInt(i.value)/1e3,s=t.sections.find(function(e){return"expiry"===e.name}),u=t.sections.find(function(e){return"timestamp"===e.name});if("timestamp"!==(null==u?void 0:u.name)||!u.value)return null;var l=u.value;if("expiry"!==(null==s?void 0:s.name)||void 0===s.value)return null;var c=s.value,h=t.sections.find(function(e){return"description"===e.name});return{paymentHash:o,satoshi:a,timestamp:l,expiry:c,description:"description"===(null==h?void 0:h.name)?null==h?void 0:h.value:void 0}}catch(e){return null}}(this.paymentRequest);if(!i)throw new Error("Failed to decode payment request");this.paymentHash=i.paymentHash,this.satoshi=i.satoshi,this.timestamp=i.timestamp,this.expiry=i.expiry,this.createdDate=new Date(1e3*this.timestamp),this.expiryDate=new Date(1e3*(this.timestamp+this.expiry)),this.description=null!=(t=i.description)?t:null,this.verify=null!=(n=e.verify)?n:null,this.preimage=null!=(o=e.preimage)?o:null}var t=e.prototype;return t.isPaid=function(){try{var e=this;if(e.preimage)return Promise.resolve(e.validatePreimage(e.preimage));if(e.verify)return Promise.resolve(e.verifyPayment());throw new Error("Could not verify payment")}catch(e){return Promise.reject(e)}},t.validatePreimage=function(e){if(!e||!this.paymentHash)return!1;try{var t=i.default(o.default.parse(e)).toString(o.default);return this.paymentHash===t}catch(e){return!1}},t.verifyPayment=function(){try{var e=this;if(!e.verify)throw new Error("LNURL verify not available");return Promise.resolve(fetch(e.verify)).then(function(t){return Promise.resolve(t.json()).then(function(t){return t.preimage&&(e.preimage=t.preimage),t.settled})})}catch(e){return Promise.reject(e)}},e}(),w=function(e,t){var r=e.satoshi,n=e.comment,o=e.p,i=e.e,a=e.relays;void 0===t&&(t={});try{var s=t.nostr||globalThis.nostr;if(!s)throw new Error("nostr option or window.nostr is not available");var u=[["relays"].concat(a),["amount",r.toString()]];return o&&u.push(["p",o]),i&&u.push(["e",i]),Promise.resolve(s.getPublicKey()).then(function(e){var t={pubkey:e,created_at:Math.floor(Date.now()/1e3),kind:9734,tags:u,content:null!=n?n:""};return t.id=P(t),Promise.resolve(s.signEvent(t))})}catch(i){return Promise.reject(i)}};function g(e){if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if(!Array.isArray(e.tags))return!1;for(var t=0;t<e.tags.length;t++){var r=e.tags[t];if(!Array.isArray(r))return!1;for(var n=0;n<r.length;n++)if("object"==typeof r[n])return!1}return!0}function b(e){if(!g(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function P(e){return i.default(b(e)).toString(o.default)}function k(e,t){var r,n,o,i;return t&&e&&(n=(r=null==(o=e.names)?void 0:o[t])?null==(i=e.relays)?void 0:i[r]:void 0),[e,r,n]}var x={__proto__:null,generateZapEvent:w,validateEvent:g,serializeEvent:b,getEventHash:P,parseNostrResponse:k},D=/^((?:[^<>()[\]\\.,;:\s@"]+(?:\.[^<>()[\]\\.,;:\s@"]+)*)|(?:".+"))@((?:\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(?:(?:[a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,j=/*#__PURE__*/function(){function e(e,t){this.address=void 0,this.options=void 0,this.username=void 0,this.domain=void 0,this.pubkey=void 0,this.lnurlpData=void 0,this.keysendData=void 0,this.nostrData=void 0,this.nostrPubkey=void 0,this.nostrRelays=void 0,this.webln=void 0,this.address=e,this.options={proxy:"https://api.getalby.com/lnurl"},this.options=Object.assign(this.options,t),this.parse(),this.webln=this.options.webln}var t=e.prototype;return t.parse=function(){var e=D.exec(this.address.toLowerCase());e&&(this.username=e[1],this.domain=e[2])},t.getWebLN=function(){return this.webln||globalThis.webln},t.fetch=function(){try{var e=this;return Promise.resolve(e.options.proxy?e.fetchWithProxy():e.fetchWithoutProxy())}catch(e){return Promise.reject(e)}},t.fetchWithProxy=function(){try{var e=this;return Promise.resolve(fetch(e.options.proxy+"/lightning-address-details?"+new URLSearchParams({ln:e.address}).toString())).then(function(t){return Promise.resolve(t.json()).then(function(t){e.parseResponse(t.lnurlp,t.keysend,t.nostr)})})}catch(e){return Promise.reject(e)}},t.fetchWithoutProxy=function(){try{var e=this;return e.domain&&e.username?Promise.resolve(fetch(e.lnurlpUrl())).then(function(t){return Promise.resolve(fetch(e.keysendUrl())).then(function(r){return Promise.resolve(fetch(e.nostrUrl())).then(function(n){function o(){function t(){function t(){e.parseResponse(i,o,r)}var r,a=function(){if(n.ok)return Promise.resolve(n.json()).then(function(e){r=e})}();return a&&a.then?a.then(t):t()}var o,a=function(){if(r.ok)return Promise.resolve(r.json()).then(function(e){o=e})}();return a&&a.then?a.then(t):t()}var i,a=function(){if(t.ok)return Promise.resolve(t.json()).then(function(e){i=e})}();return a&&a.then?a.then(o):o()})})}):Promise.resolve()}catch(e){return Promise.reject(e)}},t.lnurlpUrl=function(){return"https://"+this.domain+"/.well-known/lnurlp/"+this.username},t.keysendUrl=function(){return"https://"+this.domain+"/.well-known/keysend/"+this.username},t.nostrUrl=function(){return"https://"+this.domain+"/.well-known/nostr.json?name="+this.username},t.generateInvoice=function(e){try{var t,r=function(e){var r=t&&t.pr&&t.pr.toString();if(!r)throw new Error("Invalid pay service invoice");var n={pr:r};return t&&t.verify&&(n.verify=t.verify.toString()),new y(n)},n=this,o=function(){if(n.options.proxy)return Promise.resolve(fetch(n.options.proxy+"/generate-invoice?"+new URLSearchParams(f({ln:n.address},e)).toString())).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e.invoice})});if(!n.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!n.lnurlpData.callback||!p(n.lnurlpData.callback))throw new Error("Valid callback does not exist in lnurlpData");var r=new URL(n.lnurlpData.callback);return r.search=new URLSearchParams(e).toString(),Promise.resolve(fetch(r)).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e})})}();return Promise.resolve(o&&o.then?o.then(r):r())}catch(e){return Promise.reject(e)}},t.requestInvoice=function(e){try{var t=this;if(!t.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");var r=1e3*e.satoshi,n=t.lnurlpData,o=n.commentAllowed;if(!d({amount:r,min:n.min,max:n.max}))throw new Error("Invalid amount");if(e.comment&&o&&o>0&&e.comment.length>o)throw new Error("The comment length must be "+o+" characters or fewer");var i={amount:r.toString()};return e.comment&&(i.comment=e.comment),e.payerdata&&(i.payerdata=JSON.stringify(e.payerdata)),Promise.resolve(t.generateInvoice(i))}catch(e){return Promise.reject(e)}},t.boost=function(e,t){void 0===t&&(t=0);try{var r=this;if(!r.keysendData)throw new Error("No keysendData available. Please call fetch() first.");var n=r.keysendData,o=n.destination,i=n.customKey,a=n.customValue,s=r.getWebLN();if(!s)throw new Error("WebLN not available");return Promise.resolve(h({destination:o,customKey:i,customValue:a,amount:t,boost:e},{webln:s}))}catch(e){return Promise.reject(e)}},t.zapInvoice=function(e,t){var r=e.satoshi,n=e.comment,o=e.relays,i=e.e;void 0===t&&(t={});try{var a=this;if(!a.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!a.nostrPubkey)throw new Error("Nostr Pubkey is missing");var s=a.nostrPubkey,u=1e3*r,l=a.lnurlpData,c=l.allowsNostr;if(!d({amount:u,min:l.min,max:l.max}))throw new Error("Invalid amount");if(!c)throw new Error("Your provider does not support zaps");return Promise.resolve(w({satoshi:u,comment:n,p:s,e:i,relays:o},t)).then(function(e){var t={amount:u.toString(),nostr:JSON.stringify(e)};return Promise.resolve(a.generateInvoice(t))})}catch(i){return Promise.reject(i)}},t.zap=function(e,t){void 0===t&&(t={});try{var r=this.zapInvoice(e,t),n=this.getWebLN();if(!n)throw new Error("WebLN not available");return Promise.resolve(n.enable()).then(function(){var e=n.sendPayment;return Promise.resolve(r).then(function(t){return e.call(n,t.paymentRequest)})})}catch(e){return Promise.reject(e)}},t.parseResponse=function(e,t,r){if(e&&(this.lnurlpData=function(e){if("payRequest"!==e.tag)throw new Error("Invalid pay service params");var t=(e.callback+"").trim();if(!p(t))throw new Error("Callback must be a valid url");var r,n,a=Math.ceil(Number(e.minSendable||0)),s=Math.floor(Number(e.maxSendable));if(!a||!s||a>s)throw new Error("Invalid pay service params");try{r=JSON.parse(e.metadata+""),n=i.default(e.metadata+"").toString(o.default)}catch(e){r=[],n=i.default("[]").toString(o.default)}for(var u="",l="",c="",h=0;h<r.length;h++){var m=r[h],f=m[0],v=m[1];switch(f){case"text/plain":l=v;break;case"text/identifier":c=v;break;case"image/png;base64":case"image/jpeg;base64":u="data:"+f+","+v}}var d,y=e.payerData;try{d=new URL(t).hostname}catch(e){}return{callback:t,fixed:a===s,min:a,max:s,domain:d,metadata:r,metadataHash:n,identifier:c,description:l,image:u,payerData:y,commentAllowed:Number(e.commentAllowed)||0,rawData:e,allowsNostr:e.allowsNostr||!1}}(e)),t&&(this.keysendData=function(e){if("keysend"!==e.tag)throw new Error("Invalid keysend params");if("OK"!==e.status)throw new Error("Keysend status not OK");if(!("customKey"in e.customData[0])||"696969"!=e.customData[0].customKey)throw new Error("Unable to find customKey");if(!("customValue"in e.customData[0])||!e.customData[0].customValue)throw new Error("Unable to find customValue");if(!e.pubkey)throw new Error("Pubkey does not exist");return{destination:e.pubkey,customKey:e.customData[0].customKey,customValue:e.customData[0].customValue}}(t)),r){var n=k(r,this.username);this.nostrData=n[0],this.nostrPubkey=n[1],this.nostrRelays=n[2]}},e}(),E=function(e){try{var t="https://getalby.com/api/rates/"+e.toLowerCase()+".json";return Promise.resolve(fetch(t)).then(function(e){return Promise.resolve(e.json()).then(function(e){return e.rate_float/1e8})})}catch(e){return Promise.reject(e)}},N=function(e){var t=e.satoshi;return Promise.resolve(E(e.currency)).then(function(e){return Number(t)*e})},S={__proto__:null,getFiatBtcRate:E,getFiatValue:N,getSatoshiValue:function(e){var t=e.amount;return Promise.resolve(E(e.currency)).then(function(e){return Math.floor(Number(t)/e)})},getFormattedFiatValue:function(e){var t=e.currency,r=e.locale;return r||(r="en"),Promise.resolve(N({satoshi:e.satoshi,currency:t})).then(function(e){return e.toLocaleString(r,{style:"currency",currency:t})})}};exports.Invoice=y,exports.LightningAddress=j,exports.boostagrams=m,exports.fetchWithL402=l,exports.fiat=S,exports.l402=c,exports.nostr=x,exports.sendBoostagram=h;
3
3
 
4
4
 
5
5
  },{"crypto-js/enc-hex.js":6,"crypto-js/sha256.js":7,"light-bolt11-decoder":8}],2:[function(require,module,exports){
6
6
  // assign alby-tools exports to global window object (for index.browser.js)
7
- // @ts-ignore
7
+ // @ts-ignore this file is created at build time
8
8
  window["lightningTools"] = require("./index.cjs");
9
9
 
10
10
  },{"./index.cjs":1}],3:[function(require,module,exports){
package/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- var e=require("crypto-js/enc-hex.js"),t=require("crypto-js/sha256.js"),r=require("light-bolt11-decoder");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=/*#__PURE__*/n(e),a=/*#__PURE__*/n(t),i=/*#__PURE__*/function(){function e(e){this.storage=void 0,this.storage=e||{}}var t=e.prototype;return t.getItem=function(e){return this.storage[e]},t.setItem=function(e,t){this.storage[e]=t},e}(),s={__proto__:null,MemoryStorage:i,NoStorage:/*#__PURE__*/function(){function e(e){}var t=e.prototype;return t.getItem=function(e){return null},t.setItem=function(e,t){},e}(),default:i},u=new i,c=function(e,t,r){try{var n,o=function(r){return n?r:(t.headers["Accept-Authenticate"]=a,Promise.resolve(fetch(e,t)).then(function(r){var n=r.headers.get("www-authenticate");if(!n)return r;var o,u=(o=n.replace("L402","").replace("LSAT","").split(",").map(function(e){var t=e.split("=").map(function(e){return e.trim()});return[t[0],t[1].match(/"?([^"]*)"?/)[1]]}),Object.fromEntries(o)),c=u.token||u.macaroon,l=u.invoice;return Promise.resolve(i.enable()).then(function(){return Promise.resolve(i.sendPayment(l)).then(function(r){return s.setItem(e,JSON.stringify({token:c,preimage:r.preimage})),t.headers.Authorization=a+" "+c+":"+r.preimage,Promise.resolve(fetch(e,t))})})}))};r||(r={});var a=r.headerKey||"L402",i=r.webln||globalThis.webln;if(!i)throw new Error("WebLN is missing");var s=r.store||u;t||(t={}),t.cache="no-store",t.mode="cors",t.headers||(t.headers={});var c=s.getItem(e),l=function(){if(c){var r=JSON.parse(c);return t.headers.Authorization=a+" "+r.token+":"+r.preimage,Promise.resolve(fetch(e,t)).then(function(e){return n=1,e})}}();return Promise.resolve(l&&l.then?l.then(o):o(l))}catch(e){return Promise.reject(e)}},l={__proto__:null,storage:s,fetchWithL402:c,default:c},h=function(e,t){try{var r=e.boost,n=e.amount;t||(t={});var o=t.webln||globalThis.webln;n||(n=Math.floor(r.value_msat/1e3));var a={destination:e.destination,amount:n,customRecords:{7629169:JSON.stringify(r)}};return e.customKey&&e.customValue&&(a.customRecords[e.customKey]=e.customValue),Promise.resolve(o.enable()).then(function(){return Promise.resolve(o.keysend(a))})}catch(e){return Promise.reject(e)}},m={__proto__:null,boost:h,default:h};function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},f.apply(this,arguments)}var v=/((([A-Za-z]{3,9}:(?:\/\/)?)(?:[-;:&=\+\$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=\+\$,\w]+@)[A-Za-z0-9.-]+)((?:\/[\+~%\/.\w-_]*)?\??(?:[-\+=&;%@.\w_]*)#?(?:[\w]*))?)/,p=function(e){return!!e&&v.test(e)},d=function(e){var t=e.amount;return t>0&&t>=e.min&&t<=e.max},y=/*#__PURE__*/function(){function e(e){var t,n;this.paymentRequest=void 0,this.paymentHash=void 0,this.preimage=void 0,this.verify=void 0,this.paymentRequest=e.pr,this.paymentHash=function(e){if(!e)return null;try{var t=r.decode(e);if(!t||!t.sections)return null;var n=t.sections.find(function(e){return"payment_hash"===e.name});return n&&n.value?n.value.toString():null}catch(e){return null}}(this.paymentRequest),this.verify=null!=(t=e.verify)?t:null,this.preimage=null!=(n=e.preimage)?n:null}var t=e.prototype;return t.isPaid=function(){try{var e=this;if(e.preimage)return Promise.resolve(e.validatePreimage(e.preimage));if(e.verify)return Promise.resolve(e.verifyPayment());throw new Error("Could not verify payment")}catch(e){return Promise.reject(e)}},t.validatePreimage=function(e){if(!e||!this.paymentHash)return!1;try{var t=a.default(o.default.parse(e)).toString(o.default);return this.paymentHash===t}catch(e){return!1}},t.verifyPayment=function(){try{var e=this;if(!e.verify)throw new Error("LNURL verify not available");return Promise.resolve(fetch(e.verify)).then(function(t){return Promise.resolve(t.json()).then(function(t){return t.preimage&&(e.preimage=t.preimage),t.settled})})}catch(e){return Promise.reject(e)}},e}(),w=function(e,t){var r=e.satoshi,n=e.comment,o=e.p,a=e.e,i=e.relays;void 0===t&&(t={});try{var s=t.nostr||globalThis.nostr;if(!s)throw new Error("nostr option or window.nostr is not available");var u=[["relays"].concat(i),["amount",r.toString()]];return o&&u.push(["p",o]),a&&u.push(["e",a]),Promise.resolve(s.getPublicKey()).then(function(e){var t={pubkey:e,created_at:Math.floor(Date.now()/1e3),kind:9734,tags:u,content:null!=n?n:""};return t.id=P(t),Promise.resolve(s.signEvent(t))})}catch(a){return Promise.reject(a)}};function g(e){if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if(!Array.isArray(e.tags))return!1;for(var t=0;t<e.tags.length;t++){var r=e.tags[t];if(!Array.isArray(r))return!1;for(var n=0;n<r.length;n++)if("object"==typeof r[n])return!1}return!0}function b(e){if(!g(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function P(e){return a.default(b(e)).toString(o.default)}function k(e,t){var r,n,o,a;return t&&e&&(n=(r=null==(o=e.names)?void 0:o[t])?null==(a=e.relays)?void 0:a[r]:void 0),[e,r,n]}var j={__proto__:null,generateZapEvent:w,validateEvent:g,serializeEvent:b,getEventHash:P,parseNostrResponse:k},E=/^((?:[^<>()\[\]\\.,;:\s@"]+(?:\.[^<>()\[\]\\.,;:\s@"]+)*)|(?:".+"))@((?:\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(?:(?:[a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,x=/*#__PURE__*/function(){function e(e,t){this.address=void 0,this.options=void 0,this.username=void 0,this.domain=void 0,this.pubkey=void 0,this.lnurlpData=void 0,this.keysendData=void 0,this.nostrData=void 0,this.nostrPubkey=void 0,this.nostrRelays=void 0,this.webln=void 0,this.address=e,this.options={proxy:"https://api.getalby.com/lnurl"},this.options=Object.assign(this.options,t),this.parse(),this.webln=this.options.webln}var t=e.prototype;return t.parse=function(){var e=E.exec(this.address.toLowerCase());e&&(this.username=e[1],this.domain=e[2])},t.getWebLN=function(){return this.webln||globalThis.webln},t.fetch=function(){try{var e=this;return Promise.resolve(e.options.proxy?e.fetchWithProxy():e.fetchWithoutProxy())}catch(e){return Promise.reject(e)}},t.fetchWithProxy=function(){try{var e=this;return Promise.resolve(fetch(e.options.proxy+"/lightning-address-details?"+new URLSearchParams({ln:e.address}).toString())).then(function(t){return Promise.resolve(t.json()).then(function(t){e.parseResponse(t.lnurlp,t.keysend,t.nostr)})})}catch(e){return Promise.reject(e)}},t.fetchWithoutProxy=function(){try{var e=this;return e.domain&&e.username?Promise.resolve(fetch(e.lnurlpUrl())).then(function(t){return Promise.resolve(fetch(e.keysendUrl())).then(function(r){return Promise.resolve(fetch(e.nostrUrl())).then(function(n){function o(){function t(){function t(){e.parseResponse(a,o,r)}var r,i=function(){if(n.ok)return Promise.resolve(n.json()).then(function(e){r=e})}();return i&&i.then?i.then(t):t()}var o,i=function(){if(r.ok)return Promise.resolve(r.json()).then(function(e){o=e})}();return i&&i.then?i.then(t):t()}var a,i=function(){if(t.ok)return Promise.resolve(t.json()).then(function(e){a=e})}();return i&&i.then?i.then(o):o()})})}):Promise.resolve()}catch(e){return Promise.reject(e)}},t.lnurlpUrl=function(){return"https://"+this.domain+"/.well-known/lnurlp/"+this.username},t.keysendUrl=function(){return"https://"+this.domain+"/.well-known/keysend/"+this.username},t.nostrUrl=function(){return"https://"+this.domain+"/.well-known/nostr.json?name="+this.username},t.generateInvoice=function(e){try{var t,r=function(e){var r=t&&t.pr&&t.pr.toString();if(!r)throw new Error("Invalid pay service invoice");var n={pr:r};return t&&t.verify&&(n.verify=t.verify.toString()),new y(n)},n=this,o=function(){if(n.options.proxy)return Promise.resolve(fetch(n.options.proxy+"/generate-invoice?"+new URLSearchParams(f({ln:n.address},e)).toString())).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e.invoice})});if(!n.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!n.lnurlpData.callback||!p(n.lnurlpData.callback))throw new Error("Valid callback does not exist in lnurlpData");var r=new URL(n.lnurlpData.callback);return r.search=new URLSearchParams(e).toString(),Promise.resolve(fetch(r)).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e})})}();return Promise.resolve(o&&o.then?o.then(r):r())}catch(e){return Promise.reject(e)}},t.requestInvoice=function(e){try{var t=this;if(!t.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");var r=1e3*e.satoshi,n=t.lnurlpData,o=n.commentAllowed;if(!d({amount:r,min:n.min,max:n.max}))throw new Error("Invalid amount");if(e.comment&&o&&o>0&&e.comment.length>o)throw new Error("The comment length must be "+o+" characters or fewer");var a={amount:r.toString()};return e.comment&&(a.comment=e.comment),e.payerdata&&(a.payerdata=JSON.stringify(e.payerdata)),Promise.resolve(t.generateInvoice(a))}catch(e){return Promise.reject(e)}},t.boost=function(e,t){void 0===t&&(t=0);try{var r=this;if(!r.keysendData)throw new Error("No keysendData available. Please call fetch() first.");var n=r.keysendData,o=n.destination,a=n.customKey,i=n.customValue,s=r.getWebLN();if(!s)throw new Error("WebLN not available");return Promise.resolve(h({destination:o,customKey:a,customValue:i,amount:t,boost:e},{webln:s}))}catch(e){return Promise.reject(e)}},t.zapInvoice=function(e,t){var r=e.satoshi,n=e.comment,o=e.relays,a=e.e;void 0===t&&(t={});try{var i=this;if(!i.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!i.nostrPubkey)throw new Error("Nostr Pubkey is missing");var s=i.nostrPubkey,u=1e3*r,c=i.lnurlpData,l=c.allowsNostr;if(!d({amount:u,min:c.min,max:c.max}))throw new Error("Invalid amount");if(!l)throw new Error("Your provider does not support zaps");return Promise.resolve(w({satoshi:u,comment:n,p:s,e:a,relays:o},t)).then(function(e){var t={amount:u.toString(),nostr:JSON.stringify(e)};return Promise.resolve(i.generateInvoice(t))})}catch(a){return Promise.reject(a)}},t.zap=function(e,t){void 0===t&&(t={});try{var r=this.zapInvoice(e,t),n=this.getWebLN();if(!n)throw new Error("WebLN not available");return Promise.resolve(n.enable()).then(function(){var e=n.sendPayment;return Promise.resolve(r).then(function(t){return e.call(n,t.paymentRequest)})})}catch(e){return Promise.reject(e)}},t.parseResponse=function(e,t,r){if(e&&(this.lnurlpData=function(e){if("payRequest"!==e.tag)throw new Error("Invalid pay service params");var t=(e.callback+"").trim();if(!p(t))throw new Error("Callback must be a valid url");var r,n,i=Math.ceil(Number(e.minSendable||0)),s=Math.floor(Number(e.maxSendable));if(!i||!s||i>s)throw new Error("Invalid pay service params");try{r=JSON.parse(e.metadata+""),n=a.default(e.metadata+"").toString(o.default)}catch(e){r=[],n=a.default("[]").toString(o.default)}for(var u="",c="",l="",h=0;h<r.length;h++){var m=r[h],f=m[0],v=m[1];switch(f){case"text/plain":c=v;break;case"text/identifier":l=v;break;case"image/png;base64":case"image/jpeg;base64":u="data:"+f+","+v}}var d,y=e.payerData;try{d=new URL(t).hostname}catch(e){}return{callback:t,fixed:i===s,min:i,max:s,domain:d,metadata:r,metadataHash:n,identifier:l,description:c,image:u,payerData:y,commentAllowed:Number(e.commentAllowed)||0,rawData:e,allowsNostr:e.allowsNostr||!1}}(e)),t&&(this.keysendData=function(e){if("keysend"!==e.tag)throw new Error("Invalid keysend params");if("OK"!==e.status)throw new Error("Keysend status not OK");if(!("customKey"in e.customData[0])||"696969"!=e.customData[0].customKey)throw new Error("Unable to find customKey");if(!("customValue"in e.customData[0])||!e.customData[0].customValue)throw new Error("Unable to find customValue");if(!e.pubkey)throw new Error("Pubkey does not exist");return{destination:e.pubkey,customKey:e.customData[0].customKey,customValue:e.customData[0].customValue}}(t)),r){var n=k(r,this.username);this.nostrData=n[0],this.nostrPubkey=n[1],this.nostrRelays=n[2]}},e}(),D=function(e){try{var t="https://getalby.com/api/rates/"+e.toLowerCase()+".json";return Promise.resolve(fetch(t)).then(function(e){return Promise.resolve(e.json()).then(function(e){return e.rate_float/1e8})})}catch(e){return Promise.reject(e)}},S=function(e){var t=e.satoshi;return Promise.resolve(D(e.currency)).then(function(e){return Number(t)*e})},N={__proto__:null,getFiatBtcRate:D,getFiatValue:S,getSatoshiValue:function(e){var t=e.amount;return Promise.resolve(D(e.currency)).then(function(e){return Math.floor(Number(t)/e)})},getFormattedFiatValue:function(e){var t=e.currency,r=e.locale;return r||(r="en"),Promise.resolve(S({satoshi:e.satoshi,currency:t})).then(function(e){return e.toLocaleString(r,{style:"currency",currency:t})})}};exports.Invoice=y,exports.LightningAddress=x,exports.boostagrams=m,exports.fetchWithL402=c,exports.fiat=N,exports.l402=l,exports.nostr=j,exports.sendBoostagram=h;
1
+ var e=require("crypto-js/enc-hex.js"),t=require("crypto-js/sha256.js"),r=require("light-bolt11-decoder");function n(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var o=/*#__PURE__*/n(e),i=/*#__PURE__*/n(t),a=/*#__PURE__*/function(){function e(e){this.storage=void 0,this.storage=e||{}}var t=e.prototype;return t.getItem=function(e){return this.storage[e]},t.setItem=function(e,t){this.storage[e]=t},e}(),s={__proto__:null,MemoryStorage:a,NoStorage:/*#__PURE__*/function(){function e(e){}var t=e.prototype;return t.getItem=function(e){return null},t.setItem=function(e,t){},e}(),default:a},u=new a,l=function(e,t,r){try{var n,o=function(r){return n?r:(t.headers["Accept-Authenticate"]=i,Promise.resolve(fetch(e,t)).then(function(r){var n=r.headers.get("www-authenticate");if(!n)return r;var o,u=(o=n.replace("L402","").replace("LSAT","").split(",").map(function(e){var t=e.split("=").map(function(e){return e.trim()});return[t[0],t[1].match(/"?([^"]*)"?/)[1]]}),Object.fromEntries(o)),l=u.token||u.macaroon,c=u.invoice;return Promise.resolve(a.enable()).then(function(){return Promise.resolve(a.sendPayment(c)).then(function(r){return s.setItem(e,JSON.stringify({token:l,preimage:r.preimage})),t.headers.Authorization=i+" "+l+":"+r.preimage,Promise.resolve(fetch(e,t))})})}))};r||(r={});var i=r.headerKey||"L402",a=r.webln||globalThis.webln;if(!a)throw new Error("WebLN is missing");var s=r.store||u;t||(t={}),t.cache="no-store",t.mode="cors",t.headers||(t.headers={});var l=s.getItem(e),c=function(){if(l){var r=JSON.parse(l);return t.headers.Authorization=i+" "+r.token+":"+r.preimage,Promise.resolve(fetch(e,t)).then(function(e){return n=1,e})}}();return Promise.resolve(c&&c.then?c.then(o):o(c))}catch(e){return Promise.reject(e)}},c={__proto__:null,storage:s,fetchWithL402:l,default:l},h=function(e,t){try{var r=e.boost;t||(t={});var n=t.webln||globalThis.webln;if(!n)throw new Error("WebLN not available");if(!n.keysend)throw new Error("Keysend not available in current WebLN provider");var o=e.amount||Math.floor(r.value_msat/1e3),i={destination:e.destination,amount:o,customRecords:{7629169:JSON.stringify(r)}};return e.customKey&&e.customValue&&(i.customRecords[e.customKey]=e.customValue),Promise.resolve(n.enable()).then(function(){return Promise.resolve(n.keysend(i))})}catch(e){return Promise.reject(e)}},m={__proto__:null,boost:h,default:h};function f(){return f=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},f.apply(this,arguments)}var v=/((([A-Za-z]{3,9}:(?:\/\/)?)(?:[-;:&=+$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=+$,\w]+@)[A-Za-z0-9.-]+)((?:\/[+~%/.\w-_]*)?\??(?:[-+=&;%@.\w_]*)#?(?:[\w]*))?)/,p=function(e){return!!e&&v.test(e)},d=function(e){var t=e.amount;return t>0&&t>=e.min&&t<=e.max},y=/*#__PURE__*/function(){function e(e){var t,n,o;if(this.paymentRequest=void 0,this.paymentHash=void 0,this.preimage=void 0,this.verify=void 0,this.satoshi=void 0,this.expiry=void 0,this.timestamp=void 0,this.createdDate=void 0,this.expiryDate=void 0,this.description=void 0,this.paymentRequest=e.pr,!this.paymentRequest)throw new Error("Invalid payment request");var i=function(e){if(!e)return null;try{var t=r.decode(e);if(!t||!t.sections)return null;var n=t.sections.find(function(e){return"payment_hash"===e.name});if("payment_hash"!==(null==n?void 0:n.name)||!n.value)return null;var o=n.value,i=t.sections.find(function(e){return"amount"===e.name});if("amount"!==(null==i?void 0:i.name)||void 0===i.value)return null;var a=parseInt(i.value)/1e3,s=t.sections.find(function(e){return"expiry"===e.name}),u=t.sections.find(function(e){return"timestamp"===e.name});if("timestamp"!==(null==u?void 0:u.name)||!u.value)return null;var l=u.value;if("expiry"!==(null==s?void 0:s.name)||void 0===s.value)return null;var c=s.value,h=t.sections.find(function(e){return"description"===e.name});return{paymentHash:o,satoshi:a,timestamp:l,expiry:c,description:"description"===(null==h?void 0:h.name)?null==h?void 0:h.value:void 0}}catch(e){return null}}(this.paymentRequest);if(!i)throw new Error("Failed to decode payment request");this.paymentHash=i.paymentHash,this.satoshi=i.satoshi,this.timestamp=i.timestamp,this.expiry=i.expiry,this.createdDate=new Date(1e3*this.timestamp),this.expiryDate=new Date(1e3*(this.timestamp+this.expiry)),this.description=null!=(t=i.description)?t:null,this.verify=null!=(n=e.verify)?n:null,this.preimage=null!=(o=e.preimage)?o:null}var t=e.prototype;return t.isPaid=function(){try{var e=this;if(e.preimage)return Promise.resolve(e.validatePreimage(e.preimage));if(e.verify)return Promise.resolve(e.verifyPayment());throw new Error("Could not verify payment")}catch(e){return Promise.reject(e)}},t.validatePreimage=function(e){if(!e||!this.paymentHash)return!1;try{var t=i.default(o.default.parse(e)).toString(o.default);return this.paymentHash===t}catch(e){return!1}},t.verifyPayment=function(){try{var e=this;if(!e.verify)throw new Error("LNURL verify not available");return Promise.resolve(fetch(e.verify)).then(function(t){return Promise.resolve(t.json()).then(function(t){return t.preimage&&(e.preimage=t.preimage),t.settled})})}catch(e){return Promise.reject(e)}},e}(),w=function(e,t){var r=e.satoshi,n=e.comment,o=e.p,i=e.e,a=e.relays;void 0===t&&(t={});try{var s=t.nostr||globalThis.nostr;if(!s)throw new Error("nostr option or window.nostr is not available");var u=[["relays"].concat(a),["amount",r.toString()]];return o&&u.push(["p",o]),i&&u.push(["e",i]),Promise.resolve(s.getPublicKey()).then(function(e){var t={pubkey:e,created_at:Math.floor(Date.now()/1e3),kind:9734,tags:u,content:null!=n?n:""};return t.id=P(t),Promise.resolve(s.signEvent(t))})}catch(i){return Promise.reject(i)}};function g(e){if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if(!Array.isArray(e.tags))return!1;for(var t=0;t<e.tags.length;t++){var r=e.tags[t];if(!Array.isArray(r))return!1;for(var n=0;n<r.length;n++)if("object"==typeof r[n])return!1}return!0}function b(e){if(!g(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function P(e){return i.default(b(e)).toString(o.default)}function k(e,t){var r,n,o,i;return t&&e&&(n=(r=null==(o=e.names)?void 0:o[t])?null==(i=e.relays)?void 0:i[r]:void 0),[e,r,n]}var x={__proto__:null,generateZapEvent:w,validateEvent:g,serializeEvent:b,getEventHash:P,parseNostrResponse:k},D=/^((?:[^<>()[\]\\.,;:\s@"]+(?:\.[^<>()[\]\\.,;:\s@"]+)*)|(?:".+"))@((?:\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(?:(?:[a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,j=/*#__PURE__*/function(){function e(e,t){this.address=void 0,this.options=void 0,this.username=void 0,this.domain=void 0,this.pubkey=void 0,this.lnurlpData=void 0,this.keysendData=void 0,this.nostrData=void 0,this.nostrPubkey=void 0,this.nostrRelays=void 0,this.webln=void 0,this.address=e,this.options={proxy:"https://api.getalby.com/lnurl"},this.options=Object.assign(this.options,t),this.parse(),this.webln=this.options.webln}var t=e.prototype;return t.parse=function(){var e=D.exec(this.address.toLowerCase());e&&(this.username=e[1],this.domain=e[2])},t.getWebLN=function(){return this.webln||globalThis.webln},t.fetch=function(){try{var e=this;return Promise.resolve(e.options.proxy?e.fetchWithProxy():e.fetchWithoutProxy())}catch(e){return Promise.reject(e)}},t.fetchWithProxy=function(){try{var e=this;return Promise.resolve(fetch(e.options.proxy+"/lightning-address-details?"+new URLSearchParams({ln:e.address}).toString())).then(function(t){return Promise.resolve(t.json()).then(function(t){e.parseResponse(t.lnurlp,t.keysend,t.nostr)})})}catch(e){return Promise.reject(e)}},t.fetchWithoutProxy=function(){try{var e=this;return e.domain&&e.username?Promise.resolve(fetch(e.lnurlpUrl())).then(function(t){return Promise.resolve(fetch(e.keysendUrl())).then(function(r){return Promise.resolve(fetch(e.nostrUrl())).then(function(n){function o(){function t(){function t(){e.parseResponse(i,o,r)}var r,a=function(){if(n.ok)return Promise.resolve(n.json()).then(function(e){r=e})}();return a&&a.then?a.then(t):t()}var o,a=function(){if(r.ok)return Promise.resolve(r.json()).then(function(e){o=e})}();return a&&a.then?a.then(t):t()}var i,a=function(){if(t.ok)return Promise.resolve(t.json()).then(function(e){i=e})}();return a&&a.then?a.then(o):o()})})}):Promise.resolve()}catch(e){return Promise.reject(e)}},t.lnurlpUrl=function(){return"https://"+this.domain+"/.well-known/lnurlp/"+this.username},t.keysendUrl=function(){return"https://"+this.domain+"/.well-known/keysend/"+this.username},t.nostrUrl=function(){return"https://"+this.domain+"/.well-known/nostr.json?name="+this.username},t.generateInvoice=function(e){try{var t,r=function(e){var r=t&&t.pr&&t.pr.toString();if(!r)throw new Error("Invalid pay service invoice");var n={pr:r};return t&&t.verify&&(n.verify=t.verify.toString()),new y(n)},n=this,o=function(){if(n.options.proxy)return Promise.resolve(fetch(n.options.proxy+"/generate-invoice?"+new URLSearchParams(f({ln:n.address},e)).toString())).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e.invoice})});if(!n.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!n.lnurlpData.callback||!p(n.lnurlpData.callback))throw new Error("Valid callback does not exist in lnurlpData");var r=new URL(n.lnurlpData.callback);return r.search=new URLSearchParams(e).toString(),Promise.resolve(fetch(r)).then(function(e){return Promise.resolve(e.json()).then(function(e){t=e})})}();return Promise.resolve(o&&o.then?o.then(r):r())}catch(e){return Promise.reject(e)}},t.requestInvoice=function(e){try{var t=this;if(!t.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");var r=1e3*e.satoshi,n=t.lnurlpData,o=n.commentAllowed;if(!d({amount:r,min:n.min,max:n.max}))throw new Error("Invalid amount");if(e.comment&&o&&o>0&&e.comment.length>o)throw new Error("The comment length must be "+o+" characters or fewer");var i={amount:r.toString()};return e.comment&&(i.comment=e.comment),e.payerdata&&(i.payerdata=JSON.stringify(e.payerdata)),Promise.resolve(t.generateInvoice(i))}catch(e){return Promise.reject(e)}},t.boost=function(e,t){void 0===t&&(t=0);try{var r=this;if(!r.keysendData)throw new Error("No keysendData available. Please call fetch() first.");var n=r.keysendData,o=n.destination,i=n.customKey,a=n.customValue,s=r.getWebLN();if(!s)throw new Error("WebLN not available");return Promise.resolve(h({destination:o,customKey:i,customValue:a,amount:t,boost:e},{webln:s}))}catch(e){return Promise.reject(e)}},t.zapInvoice=function(e,t){var r=e.satoshi,n=e.comment,o=e.relays,i=e.e;void 0===t&&(t={});try{var a=this;if(!a.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!a.nostrPubkey)throw new Error("Nostr Pubkey is missing");var s=a.nostrPubkey,u=1e3*r,l=a.lnurlpData,c=l.allowsNostr;if(!d({amount:u,min:l.min,max:l.max}))throw new Error("Invalid amount");if(!c)throw new Error("Your provider does not support zaps");return Promise.resolve(w({satoshi:u,comment:n,p:s,e:i,relays:o},t)).then(function(e){var t={amount:u.toString(),nostr:JSON.stringify(e)};return Promise.resolve(a.generateInvoice(t))})}catch(i){return Promise.reject(i)}},t.zap=function(e,t){void 0===t&&(t={});try{var r=this.zapInvoice(e,t),n=this.getWebLN();if(!n)throw new Error("WebLN not available");return Promise.resolve(n.enable()).then(function(){var e=n.sendPayment;return Promise.resolve(r).then(function(t){return e.call(n,t.paymentRequest)})})}catch(e){return Promise.reject(e)}},t.parseResponse=function(e,t,r){if(e&&(this.lnurlpData=function(e){if("payRequest"!==e.tag)throw new Error("Invalid pay service params");var t=(e.callback+"").trim();if(!p(t))throw new Error("Callback must be a valid url");var r,n,a=Math.ceil(Number(e.minSendable||0)),s=Math.floor(Number(e.maxSendable));if(!a||!s||a>s)throw new Error("Invalid pay service params");try{r=JSON.parse(e.metadata+""),n=i.default(e.metadata+"").toString(o.default)}catch(e){r=[],n=i.default("[]").toString(o.default)}for(var u="",l="",c="",h=0;h<r.length;h++){var m=r[h],f=m[0],v=m[1];switch(f){case"text/plain":l=v;break;case"text/identifier":c=v;break;case"image/png;base64":case"image/jpeg;base64":u="data:"+f+","+v}}var d,y=e.payerData;try{d=new URL(t).hostname}catch(e){}return{callback:t,fixed:a===s,min:a,max:s,domain:d,metadata:r,metadataHash:n,identifier:c,description:l,image:u,payerData:y,commentAllowed:Number(e.commentAllowed)||0,rawData:e,allowsNostr:e.allowsNostr||!1}}(e)),t&&(this.keysendData=function(e){if("keysend"!==e.tag)throw new Error("Invalid keysend params");if("OK"!==e.status)throw new Error("Keysend status not OK");if(!("customKey"in e.customData[0])||"696969"!=e.customData[0].customKey)throw new Error("Unable to find customKey");if(!("customValue"in e.customData[0])||!e.customData[0].customValue)throw new Error("Unable to find customValue");if(!e.pubkey)throw new Error("Pubkey does not exist");return{destination:e.pubkey,customKey:e.customData[0].customKey,customValue:e.customData[0].customValue}}(t)),r){var n=k(r,this.username);this.nostrData=n[0],this.nostrPubkey=n[1],this.nostrRelays=n[2]}},e}(),E=function(e){try{var t="https://getalby.com/api/rates/"+e.toLowerCase()+".json";return Promise.resolve(fetch(t)).then(function(e){return Promise.resolve(e.json()).then(function(e){return e.rate_float/1e8})})}catch(e){return Promise.reject(e)}},N=function(e){var t=e.satoshi;return Promise.resolve(E(e.currency)).then(function(e){return Number(t)*e})},S={__proto__:null,getFiatBtcRate:E,getFiatValue:N,getSatoshiValue:function(e){var t=e.amount;return Promise.resolve(E(e.currency)).then(function(e){return Math.floor(Number(t)/e)})},getFormattedFiatValue:function(e){var t=e.currency,r=e.locale;return r||(r="en"),Promise.resolve(N({satoshi:e.satoshi,currency:t})).then(function(e){return e.toLocaleString(r,{style:"currency",currency:t})})}};exports.Invoice=y,exports.LightningAddress=j,exports.boostagrams=m,exports.fetchWithL402=l,exports.fiat=S,exports.l402=c,exports.nostr=x,exports.sendBoostagram=h;
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../src/utils/storage.ts","../src/l402/index.ts","../src/l402/parse.js","../src/podcasting2/boostagrams.ts","../src/utils/keysend.ts","../src/utils/lnurl.ts","../src/invoice.ts","../src/utils/invoice.ts","../src/utils/nostr.ts","../src/lightning-address.ts","../src/utils/fiat.ts"],"sourcesContent":["export class MemoryStorage {\n storage;\n\n constructor(initial?: any) {\n this.storage = initial || {};\n }\n\n getItem(key) {\n return this.storage[key];\n }\n\n setItem(key, value) {\n this.storage[key] = value;\n }\n}\n\nexport class NoStorage {\n constructor(initial?: any) {}\n\n getItem(key) {\n return null;\n }\n\n setItem(key, value) {}\n}\n\nexport default MemoryStorage;\n","import MemoryStorage from \"../utils/storage\";\nimport { WebLNProvider } from \"@webbtc/webln-types\";\nimport { parseL402 } from \"./parse\";\n\nexport * as storage from \"../utils/storage\";\nconst memoryStorage = new MemoryStorage();\n\nconst HEADER_KEY = \"L402\"; // we have to update this to L402 at some point\n\nexport const fetchWithL402 = async (\n url: string,\n fetchArgs: Record<string, any>,\n options: Record<string, any>,\n) => {\n if (!options) {\n options = {};\n }\n const headerKey = options.headerKey || HEADER_KEY;\n const webln: WebLNProvider = options.webln || globalThis.webln;\n if (!webln) {\n throw new Error(\"WebLN is missing\");\n }\n let store = options.store || memoryStorage;\n if (!fetchArgs) {\n fetchArgs = {};\n }\n fetchArgs.cache = \"no-store\";\n fetchArgs.mode = \"cors\";\n if (!fetchArgs.headers) {\n fetchArgs.headers = {};\n }\n const cachedL402Data = store.getItem(url);\n if (cachedL402Data) {\n const data = JSON.parse(cachedL402Data);\n fetchArgs.headers[\n \"Authorization\"\n ] = `${headerKey} ${data.token}:${data.preimage}`;\n return await fetch(url, fetchArgs);\n }\n\n fetchArgs.headers[\"Accept-Authenticate\"] = headerKey;\n const initResp = await fetch(url, fetchArgs);\n const header = initResp.headers.get(\"www-authenticate\");\n if (!header) {\n return initResp;\n }\n\n const details = parseL402(header);\n const token = details.token || details.macaroon;\n const inv = details.invoice;\n\n await webln.enable();\n const invResp = await webln.sendPayment(inv);\n\n store.setItem(\n url,\n JSON.stringify({\n token: token,\n preimage: invResp.preimage,\n }),\n );\n\n fetchArgs.headers[\n \"Authorization\"\n ] = `${headerKey} ${token}:${invResp.preimage}`;\n return await fetch(url, fetchArgs);\n};\n\nexport default fetchWithL402;\n","export const parseL402 = (string) => {\n string = string.replace(\"L402\", \"\");\n string = string.replace(\"LSAT\", \"\");\n // Split the string into key-value pairs\n const pairs = string.split(\",\");\n\n // Split each pair into key and value\n const keyValuePairArray = pairs.map((pair) => {\n const [key, valuePotentiallyQuoted] = pair.split(\"=\").map((e) => e.trim());\n const valueMatch = valuePotentiallyQuoted.match(/\"?([^\"]*)\"?/);\n const value = valueMatch[1];\n return [key, value];\n });\n\n return Object.fromEntries(keyValuePairArray);\n};\n","import { WebLNProvider } from \"@webbtc/webln-types\";\n\ntype BoostOptions = {\n webln?: unknown;\n};\n\ntype BoostArguments = {\n destination: string;\n customKey?: string;\n customValue?: string;\n amount?: number;\n boost: Boost;\n};\n\ntype WeblnBoostParams = {\n destination: string;\n amount: number;\n customRecords: Record<string, string>;\n};\n\nexport type Boost = {\n action: string;\n value_msat: number;\n value_msat_total: number;\n app_name: string;\n app_version: string;\n feedId: string;\n podcast: string;\n episode: string;\n ts: number;\n name: string;\n sender_name: string;\n};\n\nexport const boost = async (args: BoostArguments, options?: BoostOptions) => {\n let { boost, amount } = args;\n if (!options) {\n options = {};\n }\n const webln: WebLNProvider = options.webln || globalThis.webln;\n if (!amount) {\n amount = Math.floor(boost.value_msat / 1000);\n }\n\n let weblnParams: WeblnBoostParams = {\n destination: args.destination,\n amount: amount,\n customRecords: {\n \"7629169\": JSON.stringify(boost),\n },\n };\n if (args.customKey && args.customValue) {\n weblnParams.customRecords[args.customKey] = args.customValue;\n }\n await webln.enable();\n const response = await webln.keysend(weblnParams);\n return response;\n};\n\nexport default boost;\n","import type { KeysendResponse } from \"../types\";\n\nconst TAG_KEYSEND = \"keysend\";\n\nexport const parseKeysendResponse = (\n data: Record<string, any>,\n): KeysendResponse => {\n if (data.tag !== TAG_KEYSEND) throw new Error(\"Invalid keysend params\");\n if (data.status !== \"OK\") throw new Error(\"Keysend status not OK\");\n\n if (\n !(\"customKey\" in data.customData[0]) ||\n data.customData[0][\"customKey\"] != \"696969\"\n )\n throw new Error(\"Unable to find customKey\");\n\n if (\n !(\"customValue\" in data.customData[0]) ||\n !data.customData[0][\"customValue\"]\n )\n throw new Error(\"Unable to find customValue\");\n\n if (!data.pubkey) throw new Error(\"Pubkey does not exist\");\n\n const destination = data.pubkey;\n const customKey = data.customData[0][\"customKey\"];\n const customValue = data.customData[0][\"customValue\"];\n\n return {\n destination,\n customKey,\n customValue,\n };\n};\n","import Hex from \"crypto-js/enc-hex.js\";\nimport sha256 from \"crypto-js/sha256.js\";\n\nimport type { LUD18ServicePayerData, LnUrlPayResponse } from \"../types\";\n\nconst URL_REGEX =\n /((([A-Za-z]{3,9}:(?:\\/\\/)?)(?:[-;:&=\\+\\$,\\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=\\+\\$,\\w]+@)[A-Za-z0-9.-]+)((?:\\/[\\+~%\\/.\\w-_]*)?\\??(?:[-\\+=&;%@.\\w_]*)#?(?:[\\w]*))?)/;\n\nexport const isUrl = (url: string | null): url is string => {\n if (!url) return false;\n return URL_REGEX.test(url);\n};\n\nexport const isValidAmount = ({\n amount,\n min,\n max,\n}: {\n amount: number;\n min: number;\n max: number;\n}): boolean => {\n return amount > 0 && amount >= min && amount <= max;\n};\n\nconst TAG_PAY_REQUEST = \"payRequest\";\n\n// From: https://github.com/dolcalmi/lnurl-pay/blob/main/src/request-pay-service-params.ts\nexport const parseLnUrlPayResponse = (\n data: Record<string, any>,\n): LnUrlPayResponse => {\n if (data.tag !== TAG_PAY_REQUEST)\n throw new Error(\"Invalid pay service params\");\n\n const callback = (data.callback + \"\").trim();\n if (!isUrl(callback)) throw new Error(\"Callback must be a valid url\");\n\n const min = Math.ceil(Number(data.minSendable || 0));\n const max = Math.floor(Number(data.maxSendable));\n if (!(min && max) || min > max) throw new Error(\"Invalid pay service params\");\n\n let metadata: Array<Array<string>>;\n let metadataHash: string;\n try {\n metadata = JSON.parse(data.metadata + \"\");\n metadataHash = sha256(data.metadata + \"\").toString(Hex);\n } catch {\n metadata = [];\n metadataHash = sha256(\"[]\").toString(Hex);\n }\n\n let image = \"\";\n let description = \"\";\n let identifier = \"\";\n for (let i = 0; i < metadata.length; i++) {\n const [k, v] = metadata[i];\n switch (k) {\n case \"text/plain\":\n description = v;\n break;\n case \"text/identifier\":\n identifier = v;\n break;\n case \"image/png;base64\":\n case \"image/jpeg;base64\":\n image = \"data:\" + k + \",\" + v;\n break;\n }\n }\n let payerData = data.payerData as LUD18ServicePayerData | undefined;\n\n let domain;\n try {\n domain = new URL(callback).hostname;\n } catch {\n // fail silently and let domain remain undefined if callback is not a valid URL\n }\n\n return {\n callback,\n fixed: min === max,\n min,\n max,\n domain,\n metadata,\n metadataHash,\n identifier,\n description,\n image,\n payerData,\n commentAllowed: Number(data.commentAllowed) || 0,\n rawData: data,\n allowsNostr: data.allowsNostr || false,\n };\n};\n","import { getHashFromInvoice } from \"./utils/invoice\";\nimport Hex from \"crypto-js/enc-hex.js\";\nimport sha256 from \"crypto-js/sha256.js\";\nimport { InvoiceArgs } from \"./types\";\n\nexport default class Invoice {\n paymentRequest: string;\n paymentHash: string;\n preimage: string | null;\n verify: string | null;\n\n constructor(args: InvoiceArgs) {\n this.paymentRequest = args.pr;\n this.paymentHash = getHashFromInvoice(this.paymentRequest) as string;\n this.verify = args.verify ?? null;\n this.preimage = args.preimage ?? null;\n }\n\n async isPaid(): Promise<boolean> {\n if (this.preimage) return this.validatePreimage(this.preimage);\n else if (this.verify) {\n return await this.verifyPayment();\n } else {\n throw new Error(\"Could not verify payment\");\n }\n }\n\n validatePreimage(preimage: string): boolean {\n if (!preimage || !this.paymentHash) return false;\n\n try {\n const preimageHash = sha256(Hex.parse(preimage)).toString(Hex);\n return this.paymentHash === preimageHash;\n } catch {\n return false;\n }\n }\n\n async verifyPayment(): Promise<boolean> {\n if (!this.verify) throw new Error(\"LNURL verify not available\");\n const result = await fetch(this.verify);\n const json = await result.json();\n if (json.preimage) {\n this.preimage = json.preimage;\n }\n\n return json.settled;\n }\n}\n","import { decode } from \"light-bolt11-decoder\";\n\nexport const getHashFromInvoice = (invoice) => {\n if (!invoice) return null;\n\n try {\n const decoded = decode(invoice);\n if (!decoded || !decoded.sections) return null;\n\n const hashTag = decoded.sections.find(\n (value) => value.name === \"payment_hash\",\n );\n if (!hashTag || !hashTag.value) return null;\n\n return hashTag.value.toString();\n } catch {\n return null;\n }\n};\n","import Hex from \"crypto-js/enc-hex.js\";\nimport sha256 from \"crypto-js/sha256.js\";\nimport { Event, NostrResponse, ZapArgs, ZapOptions } from \"../types\";\n\nexport async function generateZapEvent(\n { satoshi, comment, p, e, relays }: ZapArgs,\n options: ZapOptions = {},\n): Promise<Event> {\n const nostr = options.nostr || globalThis.nostr;\n if (!nostr) {\n throw new Error(\"nostr option or window.nostr is not available\");\n }\n\n const nostrTags = [\n [\"relays\", ...relays],\n [\"amount\", satoshi.toString()],\n ];\n if (p) {\n nostrTags.push([\"p\", p]);\n }\n if (e) {\n nostrTags.push([\"e\", e]);\n }\n\n const pubkey = await nostr.getPublicKey();\n\n const nostrEvent: Event = {\n pubkey,\n created_at: Math.floor(Date.now() / 1000),\n kind: 9734,\n tags: nostrTags,\n content: comment ?? \"\",\n };\n\n nostrEvent.id = getEventHash(nostrEvent);\n return await nostr.signEvent(nostrEvent);\n}\n\nexport function validateEvent(event: Event): boolean {\n if (typeof event.content !== \"string\") return false;\n if (typeof event.created_at !== \"number\") return false;\n // ignore these checks because if the pubkey is not set we add it to the event. same for the ID.\n // if (typeof event.pubkey !== \"string\") return false;\n // if (!event.pubkey.match(/^[a-f0-9]{64}$/)) return false;\n\n if (!Array.isArray(event.tags)) return false;\n for (let i = 0; i < event.tags.length; i++) {\n const tag = event.tags[i];\n if (!Array.isArray(tag)) return false;\n for (let j = 0; j < tag.length; j++) {\n if (typeof tag[j] === \"object\") return false;\n }\n }\n\n return true;\n}\n\nexport function serializeEvent(evt: Event): string {\n if (!validateEvent(evt))\n throw new Error(\"can't serialize event with wrong or missing properties\");\n\n return JSON.stringify([\n 0,\n evt.pubkey,\n evt.created_at,\n evt.kind,\n evt.tags,\n evt.content,\n ]);\n}\n\nexport function getEventHash(event: Event): string {\n return sha256(serializeEvent(event)).toString(Hex);\n}\n\nexport function parseNostrResponse(\n nostrData: NostrResponse,\n username: string | undefined,\n) {\n let nostrPubkey: string | undefined;\n let nostrRelays: string[] | undefined;\n if (username && nostrData) {\n nostrPubkey = nostrData.names?.[username];\n nostrRelays = nostrPubkey ? nostrData.relays?.[nostrPubkey] : undefined;\n }\n\n return [nostrData, nostrPubkey, nostrRelays] as const;\n}\n","import { parseKeysendResponse } from \"./utils/keysend\";\nimport { isUrl, isValidAmount, parseLnUrlPayResponse } from \"./utils/lnurl\";\nimport Invoice from \"./invoice\";\nimport {\n InvoiceArgs,\n LnUrlPayResponse,\n NostrResponse,\n RequestInvoiceArgs,\n ZapArgs,\n ZapOptions,\n} from \"./types\";\nimport { generateZapEvent, parseNostrResponse } from \"./utils/nostr\";\nimport type { Boost } from \"./podcasting2/boostagrams\";\nimport { boost as booster } from \"./podcasting2/boostagrams\";\nimport { WebLNProvider, SendPaymentResponse } from \"@webbtc/webln-types\";\nimport { KeysendResponse } from \"./types\";\n\nconst LN_ADDRESS_REGEX =\n /^((?:[^<>()\\[\\]\\\\.,;:\\s@\"]+(?:\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(?:\".+\"))@((?:\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(?:(?:[a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\n\nexport const DEFAULT_PROXY = \"https://api.getalby.com/lnurl\";\n\ntype LightningAddressOptions = {\n proxy?: string | false;\n webln?: WebLNProvider;\n};\n\nexport default class LightningAddress {\n address: string;\n options: LightningAddressOptions;\n username: string | undefined;\n domain: string | undefined;\n pubkey: string | undefined;\n lnurlpData: LnUrlPayResponse | undefined;\n keysendData: KeysendResponse | undefined;\n nostrData: NostrResponse | undefined;\n nostrPubkey: string | undefined;\n nostrRelays: string[] | undefined;\n webln: WebLNProvider | undefined;\n\n constructor(address: string, options?: LightningAddressOptions) {\n this.address = address;\n this.options = { proxy: DEFAULT_PROXY };\n this.options = Object.assign(this.options, options);\n this.parse();\n this.webln = this.options.webln;\n }\n\n parse() {\n const result = LN_ADDRESS_REGEX.exec(this.address.toLowerCase());\n if (result) {\n this.username = result[1];\n this.domain = result[2];\n }\n }\n\n getWebLN() {\n return this.webln || globalThis.webln\n }\n\n async fetch() {\n if (this.options.proxy) {\n return this.fetchWithProxy();\n } else {\n return this.fetchWithoutProxy();\n }\n }\n\n async fetchWithProxy() {\n const result = await fetch(\n `${this.options.proxy}/lightning-address-details?${new URLSearchParams({\n ln: this.address,\n }).toString()}`,\n );\n const json = await result.json();\n\n this.parseResponse(json.lnurlp, json.keysend, json.nostr);\n }\n\n async fetchWithoutProxy() {\n if (!this.domain || !this.username) {\n return;\n }\n const lnurlResult = await fetch(this.lnurlpUrl());\n const keysendResult = await fetch(this.keysendUrl());\n const nostrResult = await fetch(this.nostrUrl());\n\n let lnurlData: Record<string, string> | undefined;\n if (lnurlResult.ok) {\n lnurlData = await lnurlResult.json();\n }\n let keysendData: Record<string, string> | undefined;\n if (keysendResult.ok) {\n keysendData = await keysendResult.json();\n }\n let nostrData: NostrResponse | undefined;\n if (nostrResult.ok) {\n nostrData = await nostrResult.json();\n }\n\n this.parseResponse(lnurlData, keysendData, nostrData);\n }\n\n lnurlpUrl() {\n return `https://${this.domain}/.well-known/lnurlp/${this.username}`;\n }\n\n keysendUrl() {\n return `https://${this.domain}/.well-known/keysend/${this.username}`;\n }\n\n nostrUrl() {\n return `https://${this.domain}/.well-known/nostr.json?name=${this.username}`;\n }\n\n async generateInvoice(params: Record<string, string>): Promise<Invoice> {\n let data;\n if (this.options.proxy) {\n const invoiceResult = await fetch(\n `${this.options.proxy}/generate-invoice?${new URLSearchParams({\n ln: this.address,\n ...params,\n }).toString()}`,\n );\n const json = await invoiceResult.json();\n data = json.invoice;\n } else {\n if (!this.lnurlpData) {\n throw new Error(\"No lnurlpData available. Please call fetch() first.\");\n }\n if (!this.lnurlpData.callback || !isUrl(this.lnurlpData.callback))\n throw new Error(\"Valid callback does not exist in lnurlpData\");\n const callbackUrl = new URL(this.lnurlpData.callback);\n callbackUrl.search = new URLSearchParams(params).toString();\n const invoiceResult = await fetch(callbackUrl);\n data = await invoiceResult.json();\n }\n\n const paymentRequest = data && data.pr && data.pr.toString();\n if (!paymentRequest) throw new Error(\"Invalid pay service invoice\");\n\n const invoiceArgs: InvoiceArgs = { pr: paymentRequest };\n if (data && data.verify) invoiceArgs.verify = data.verify.toString();\n\n return new Invoice(invoiceArgs);\n }\n\n async requestInvoice(args: RequestInvoiceArgs): Promise<Invoice> {\n if (!this.lnurlpData) {\n throw new Error(\"No lnurlpData available. Please call fetch() first.\");\n }\n const msat = args.satoshi * 1000;\n const { commentAllowed, min, max } = this.lnurlpData;\n\n if (!isValidAmount({ amount: msat, min, max }))\n throw new Error(\"Invalid amount\");\n if (\n args.comment &&\n commentAllowed &&\n commentAllowed > 0 &&\n args.comment.length > commentAllowed\n )\n throw new Error(\n `The comment length must be ${commentAllowed} characters or fewer`,\n );\n\n const invoiceParams: {\n amount: string;\n comment?: string;\n payerdata?: string;\n } = { amount: msat.toString() };\n if (args.comment) invoiceParams.comment = args.comment;\n if (args.payerdata)\n invoiceParams.payerdata = JSON.stringify(args.payerdata);\n\n return this.generateInvoice(invoiceParams);\n }\n\n async boost(boost: Boost, amount: number = 0) {\n if (!this.keysendData) {\n throw new Error(\"No keysendData available. Please call fetch() first.\");\n }\n const { destination, customKey, customValue } = this.keysendData;\n const webln = this.getWebLN()\n if (!webln) {\n throw new Error(\"WebLN not available\");\n }\n return booster(\n {\n destination,\n customKey,\n customValue,\n amount,\n boost,\n },\n { webln },\n );\n }\n\n async zapInvoice(\n { satoshi, comment, relays, e }: ZapArgs,\n options: ZapOptions = {},\n ): Promise<Invoice> {\n if (!this.lnurlpData) {\n throw new Error(\"No lnurlpData available. Please call fetch() first.\");\n }\n if (!this.nostrPubkey) {\n throw new Error(\"Nostr Pubkey is missing\");\n }\n const p = this.nostrPubkey;\n const msat = satoshi * 1000;\n const { allowsNostr, min, max } = this.lnurlpData;\n\n if (!isValidAmount({ amount: msat, min, max }))\n throw new Error(\"Invalid amount\");\n if (!allowsNostr) throw new Error(\"Your provider does not support zaps\");\n\n const event = await generateZapEvent(\n {\n satoshi: msat,\n comment,\n p,\n e,\n relays,\n },\n options,\n );\n const zapParams: { amount: string; nostr: string } = {\n amount: msat.toString(),\n nostr: JSON.stringify(event),\n };\n\n const invoice = await this.generateInvoice(zapParams);\n return invoice;\n }\n\n async zap(\n args: ZapArgs,\n options: ZapOptions = {},\n ): Promise<SendPaymentResponse> {\n const invoice = this.zapInvoice(args, options);\n const webln = this.getWebLN()\n if (!webln) {\n throw new Error(\"WebLN not available\");\n }\n await webln.enable();\n const response = webln.sendPayment((await invoice).paymentRequest);\n return response;\n }\n\n private parseResponse(\n lnurlpData: Record<string, string> | undefined,\n keysendData: Record<string, string> | undefined,\n nostrData: NostrResponse | undefined,\n ) {\n if (lnurlpData) {\n this.lnurlpData = parseLnUrlPayResponse(lnurlpData);\n }\n if (keysendData) {\n this.keysendData = parseKeysendResponse(keysendData);\n }\n if (nostrData) {\n [this.nostrData, this.nostrPubkey, this.nostrRelays] = parseNostrResponse(\n nostrData,\n this.username,\n );\n }\n }\n}\n","const numSatsInBtc = 100_000_000;\n\nexport const getFiatBtcRate = async (currency: string): Promise<number> => {\n const url =\n \"https://getalby.com/api/rates/\" + currency.toLowerCase() + \".json\";\n const response = await fetch(url);\n const data = await response.json();\n\n return data.rate_float / numSatsInBtc;\n};\n\nexport const getFiatValue = async ({\n satoshi,\n currency,\n}: {\n satoshi: number | string;\n currency: string;\n}) => {\n const rate = await getFiatBtcRate(currency);\n\n return Number(satoshi) * rate;\n};\n\nexport const getSatoshiValue = async ({\n amount,\n currency,\n}: {\n amount: number | string;\n currency: string;\n}) => {\n const rate = await getFiatBtcRate(currency);\n\n return Math.floor(Number(amount) / rate);\n};\n\nexport const getFormattedFiatValue = async ({\n satoshi,\n currency,\n locale,\n}: {\n satoshi: number | string;\n currency: string;\n locale: string;\n}) => {\n if (!locale) {\n locale = \"en\";\n }\n const fiatValue = await getFiatValue({ satoshi, currency });\n return fiatValue.toLocaleString(locale, {\n style: \"currency\",\n currency,\n });\n};\n"],"names":["MemoryStorage","initial","storage","this","getItem","key","setItem","value","NoStorage","memoryStorage","fetchWithL402","url","fetchArgs","options","_exit2","_temp3","_result","headers","headerKey","fetch","then","initResp","header","get","keyValuePairArray","details","replace","split","map","pair","e","trim","_pair$split$map","match","Object","fromEntries","token","macaroon","inv","invoice","Promise","resolve","webln","enable","sendPayment","invResp","store","JSON","stringify","preimage","globalThis","Error","cache","mode","_temp4","cachedL402Data","data","parse","_await$fetch","reject","boost","args","amount","Math","floor","value_msat","weblnParams","destination","customRecords","customKey","customValue","keysend","URL_REGEX","test","_ref","min","max","Invoice","_args$verify","_args$preimage","paymentRequest","paymentHash","verify","pr","decoded","decode","sections","hashTag","find","name","toString","_unused","getHashFromInvoice","isPaid","_this2","validatePreimage","verifyPayment","preimageHash","sha256","Hex","_proto","_this4","result","json","settled","generateZapEvent","satoshi","comment","p","relays","nostr","nostrTags","concat","push","getPublicKey","pubkey","nostrEvent","created_at","Date","now","kind","tags","content","id","getEventHash","signEvent","event","Array","isArray","i","length","tag","j","serializeEvent","evt","validateEvent","parseNostrResponse","nostrData","username","nostrPubkey","nostrRelays","_nostrData$names","names","_nostrData$relays","undefined","LN_ADDRESS_REGEX","LightningAddress","address","domain","lnurlpData","keysendData","proxy","assign","exec","toLowerCase","getWebLN","fetchWithProxy","fetchWithoutProxy","URLSearchParams","ln","parseResponse","lnurlp","_this6","lnurlpUrl","lnurlResult","keysendUrl","keysendResult","nostrUrl","nostrResult","_temp6","_temp2","lnurlData","_temp","ok","_nostrResult$json","_keysendResult$json","_lnurlResult$json","_temp5","generateInvoice","params","_temp9","invoiceArgs","_this8","_extends","invoiceResult","callback","isUrl","callbackUrl","URL","search","_invoiceResult$json","requestInvoice","_this10","msat","_this10$lnurlpData","commentAllowed","isValidAmount","invoiceParams","payerdata","_this12","_this12$keysendData","booster","zapInvoice","_this14","_this14$lnurlpData","allowsNostr","zapParams","zap","_sendPayment","_invoice","metadata","metadataHash","ceil","Number","minSendable","maxSendable","description","_metadata$i","k","v","identifier","image","payerData","hostname","_unused2","fixed","rawData","parseLnUrlPayResponse","status","customData","parseKeysendResponse","_parseNostrResponse","getFiatBtcRate","currency","response","rate_float","getFiatValue","rate","_ref2","_ref3","locale","fiatValue","toLocaleString","style"],"mappings":"4OAGE,WAAA,SAAAA,EAAYC,QAFZC,aAAO,EAGLC,KAAKD,QAAUD,GAAW,CAAA,CAC5B,CAAC,IAEDG,EAAAA,EAAAA,UASF,OATEA,EAAAA,QAAA,SAAQC,GACN,OAAOF,KAAKD,QAAQG,EACtB,EAEAC,EAAAA,QAAA,SAAQD,EAAKE,GACXJ,KAAKD,QAAQG,GAAOE,CACtB,EAGFP,CAAA,CAbE,4DAcA,WAAA,SAAAQ,EAAYP,IAAiB,IAE7BG,EAAAA,EAAAA,UAIsB,OAJtBA,EAAAA,QAAA,SAAQC,GACN,OACF,IAAA,IAEAC,QAAA,SAAQD,EAAKE,GAAS,EAAAC,CAAA,CANtB,cCZiBC,EAAG,IAAIT,EAIbU,WACXC,EACAC,EACAC,GACE,IAAA,IAoDgCC,EApDhCC,EAAA,SAAAC,GAAA,OAAAF,EAAAE,GA2BFJ,EAAUK,QAAQ,uBAAyBC,kBACpBC,MAAMR,EAAKC,IAAUQ,KAAA,SAAtCC,GACN,IAAMC,EAASD,EAASJ,QAAQM,IAAI,oBACpC,IAAKD,EACH,OAAOD,EAGT,ICxCMG,EDwCOC,GCxCPD,EDwCoBF,EC9CVI,QAAQ,OAAQ,IAChBA,QAAQ,OAAQ,IAEXC,MAAM,KAGKC,IAAI,SAACC,GACnC,IAAsCA,EAAAA,EAAKF,MAAM,KAAKC,IAAI,SAACE,GAAMA,OAAAA,EAAEC,MAAM,GAGzE,MAAO,CAHGC,EAAA,GAAwBA,EAAA,GACQC,MAAM,eACvB,GAE3B,GAEaC,OAACC,YAAYX,IDkCfY,EAAGX,EAAQW,OAASX,EAAQY,SAC9BC,EAAGb,EAAQc,QAAQ,OAAAC,QAAAC,QAEtBC,EAAMC,UAAQvB,KAAA,WAAA,OAAAoB,QAAAC,QACEC,EAAME,YAAYN,IAAIlB,KAAA,SAAtCyB,GAY0C,OAVhDC,EAAMxC,QACJK,EACAoC,KAAKC,UAAU,CACbZ,MAAOA,EACPa,SAAUJ,EAAQI,YAItBrC,EAAUK,QACO,cACVC,EAAS,IAAIkB,EAAK,IAAIS,EAAQI,yBACxB9B,MAAMR,EAAKC,GAAU,EAAA,EAAA,GAAA,EAnD7BC,IACHA,EAAU,CACX,GACD,MAAkBA,EAAQK,WAVT,OAWXwB,EAAuB7B,EAAQ6B,OAASQ,WAAWR,MACzD,IAAKA,EACH,MAAUS,IAAAA,MAAM,oBAElB,IAASL,EAAGjC,EAAQiC,OAASrC,EACxBG,IACHA,EAAY,CAAA,GAEdA,EAAUwC,MAAQ,WAClBxC,EAAUyC,KAAO,OACZzC,EAAUK,UACbL,EAAUK,QAAU,CACrB,GACD,MAAuB6B,EAAM1C,QAAQO,GAAK2C,EAAA,WAAA,GACtCC,EACF,CAAA,IAAUC,EAAGT,KAAKU,MAAMF,GAG0B,OAFlD3C,EAAUK,QACO,cACVC,EAAasC,IAAAA,EAAKpB,UAASoB,EAAKP,yBAC1B9B,MAAMR,EAAKC,IAAUQ,KAAA,SAAAsC,GAAA,OAAA5C,EAAA,EAAA4C,CAAA,EAAA,CAAA,CANM,GAMN,OAAAlB,QAAAC,QAAAa,GAAAA,EAAAlC,KAAAkC,EAAAlC,KAAAL,GAAAA,EAAAuC,GA6BrC,CAAA,MAAAxB,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,yDEhCY8B,EAAAA,SAAeC,EAAsBhD,GAA0B,IAC1E,IAAM+C,EAAkBC,EAAlBD,MAAOE,EAAWD,EAAXC,OACRjD,IACHA,EAAU,CACX,GACD,IAAM6B,EAAuB7B,EAAQ6B,OAASQ,WAAWR,MACpDoB,IACHA,EAASC,KAAKC,MAAMJ,EAAMK,WAAa,MAGzC,IAAIC,EAAgC,CAClCC,YAAaN,EAAKM,YAClBL,OAAQA,EACRM,cAAe,CACb,QAAWrB,KAAKC,UAAUY,KAK7B,OAFGC,EAAKQ,WAAaR,EAAKS,cACzBJ,EAAYE,cAAcP,EAAKQ,WAAaR,EAAKS,aAClD9B,QAAAC,QACKC,EAAMC,UACWD,KAAAA,WAAAA,OAAAA,QAAAA,QAAAA,EAAM6B,QAAQL,GAAY,EAElD,CAAA,MAAApC,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,2QCvDD,MCIE,sKAEmB,SAACnB,GACpB,QAAKA,GACW6D,EAACC,KAAK9D,EACxB,IAE6B,SAAH+D,GACxBZ,IAAAA,IAAAA,OAQA,OAAOA,EAAS,GAAKA,GAPrBa,EAAAA,KAOsCb,GANnCY,EAAHE,GAOF,EClBqBC,eAMnB,WAAA,SAAAA,EAAYhB,GAAiB,IAAAiB,EAAAC,EAAA5E,KAL7B6E,oBAAc,EAAA7E,KACd8E,iBAAW,EAAA9E,KACX8C,cACAiC,EAAAA,KAAAA,cAGE/E,KAAK6E,eAAiBnB,EAAKsB,GAC3BhF,KAAK8E,YCXyB,SAAC1C,GACjC,IAAKA,EAAS,OAAO,KAErB,IACE,IAAM6C,EAAUC,EAAMA,OAAC9C,GACvB,IAAK6C,IAAYA,EAAQE,SAAU,OAAW,KAE9C,IAAMC,EAAUH,EAAQE,SAASE,KAC/B,SAACjF,SAAyB,iBAAVA,EAACkF,IAAuB,GAE1C,OAAKF,GAAYA,EAAQhF,MAEXgF,EAAChF,MAAMmF,WAFsB,IAK5C,CAFC,MAAAC,GACA,OAAO,IACR,CACH,CDLuBC,CAAmBzF,KAAK6E,gBAC3C7E,KAAK+E,cAAMJ,EAAGjB,EAAKqB,UAAU,KAC7B/E,KAAK8C,gBAAWY,EAAAA,EAAKZ,YAAY,IACnC,CAAC,IAEK4C,EAAAA,EAAAA,UA6BL,OA7BKA,EAAAA,OAAM,WAAA,IAAA,IAAAC,EACN3F,KAAJ,GAAI2F,EAAK7C,SAAU,OAAAT,QAAAC,QAAOqD,EAAKC,iBAAiBD,EAAK7C,WAChD,GAAI6C,EAAKZ,OAAQ,OAAA1C,QAAAC,QACPqD,EAAKE,iBAElB,MAAU7C,IAAAA,MAAM,2BAIpB4C,CAFC,MAEDA,GAAAA,OAAAA,QAAAA,OAAAA,EAAAA,CAAAA,EAAAA,EAAAA,iBAAA,SAAiB9C,GACf,IAAKA,IAAa9C,KAAK8E,YAAa,OAAY,EAEhD,IACE,IAAkBgB,EAAGC,UAAOC,EAAAA,QAAI1C,MAAMR,IAAWyC,SAASS,EAAAA,SAC1D,OAAWhG,KAAC8E,cAAgBgB,CAG7B,CAFC,SACA,OACD,CAAA,CACH,EAACG,EAEKJ,cAAa,WAAA,IAAA,IAAAK,EACZlG,KAAL,IAAKkG,EAAKnB,OAAQ,MAAU/B,IAAAA,MAAM,8BAA8B,OAAAX,QAAAC,QAC3CtB,MAAMkF,EAAKnB,SAA1BoB,KAAAA,SAAAA,GACaA,OAAAA,QAAAA,QAAAA,EAAOC,QAApBA,KAAAA,SAAAA,GAKN,OAJIA,EAAKtD,WACPoD,EAAKpD,SAAWsD,EAAKtD,UAGhBsD,EAAKC,OAAQ,EAAA,EACrB,CAAA,MAAA1E,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,EAAA+C,CAAA,CApCD,GEPoB4B,WAAgB/B,EAEpC7D,GADE6F,IAAAA,IAAAA,QAASC,EAAOjC,EAAPiC,QAASC,EAAAA,EAAAA,EAAG9E,EAAC4C,EAAD5C,EAAG+E,EAAAA,EAAAA,gBAC1BhG,IAAAA,EAAsB,CAAA,GAAE,IAExB,IAAWiG,EAAGjG,EAAQiG,OAAS5D,WAAW4D,MAC1C,IAAKA,EACH,MAAM,IAAS3D,MAAC,iDAGlB,IAAe4D,EAAG,EACf,UAAQC,OAAKH,GACd,CAAC,SAAUH,EAAQhB,aAOpB,OALGkB,GACFG,EAAUE,KAAK,CAAC,IAAKL,IAEnB9E,GACFiF,EAAUE,KAAK,CAAC,IAAKnF,IAGFgF,QAAAA,QAAAA,EAAMI,8BAArBC,GAEN,IAAgBC,EAAU,CACxBD,OAAAA,EACAE,WAAYtD,KAAKC,MAAMsD,KAAKC,MAAQ,KACpCC,KAAM,KACNC,KAAMV,EACNW,QAAgB,MAAPf,EAAAA,EAAW,IAGmB,OAAzCS,EAAWO,GAAKC,EAAaR,GAChBN,QAAAA,QAAAA,EAAMe,UAAUT,GAAW,EACzC,CAAA,MAAAtF,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,EAEK,WAAwBgG,GAC5B,GAA6B,iBAAbA,EAACJ,QAAsB,OAAY,EACnD,GAAgC,iBAAhBI,EAACT,WAAyB,OAAY,EAKtD,IAAKU,MAAMC,QAAQF,EAAML,MAAO,OAAO,EACvC,IAAK,MAAQ,EAAGQ,EAAIH,EAAML,KAAKS,OAAQD,IAAK,CAC1C,IAASE,EAAGL,EAAML,KAAKQ,GACvB,IAAKF,MAAMC,QAAQG,GAAM,OAAO,EAChC,IAAK,MAAQ,EAAGC,EAAID,EAAID,OAAQE,IAC9B,GAAsB,mBAAPA,GAAiB,OACjC,CACF,CAED,OAAO,CACT,CAEM,SAAwBC,EAACC,GAC7B,IAAKC,EAAcD,GACjB,MAAM,IAASnF,MAAC,0DAElB,OAAOJ,KAAKC,UAAU,CACpB,EACAsF,EAAInB,OACJmB,EAAIjB,WACJiB,EAAId,KACJc,EAAIb,KACJa,EAAIZ,SAER,UAE4BE,EAACE,GAC3B,SAAa,QAACO,EAAeP,IAAQpC,SAASS,EAAG,QACnD,UAEkCqC,EAChCC,EACAC,GAEA,IAAmCC,EAC/BC,MAMJ,OALIF,GAAYD,IAEdG,GADAD,EAA6B,OAAlBE,EAAGJ,EAAUK,YAAK,EAAfD,EAAkBH,IACJ,OAAAD,EAAAA,EAAU5B,aAAV,EAAAkC,EAAmBJ,QAAeK,GAGzD,CAACP,EAAWE,EAAaC,EAClC,gHCtEMK,EACJ,sKASmBC,eAanB,WAAA,SAAAA,EAAYC,EAAiBtI,GAAiCV,KAZ9DgJ,aAAO,EAAAhJ,KACPU,aAAO,EAAAV,KACPuI,cAAQ,EAAAvI,KACRiJ,YACAjC,EAAAA,KAAAA,YACAkC,EAAAA,KAAAA,uBACAC,iBAAW,EAAAnJ,KACXsI,eAAS,EAAAtI,KACTwI,iBACAC,EAAAA,KAAAA,iBACAlG,EAAAA,KAAAA,WAGE,EAAAvC,KAAKgJ,QAAUA,EACfhJ,KAAKU,QAAU,CAAE0I,MAtBQ,iCAuBzBpJ,KAAKU,QAAUqB,OAAOsH,OAAOrJ,KAAKU,QAASA,GAC3CV,KAAKsD,QACLtD,KAAKuC,MAAQvC,KAAKU,QAAQ6B,KAC5B,CAAC,IAEDe,EAAAA,EAAAA,iBAAAA,EAAAA,MAAA,WACE,IAAM6C,EAAS2C,EAAiBQ,KAAKtJ,KAAKgJ,QAAQO,eAC9CpD,IACFnG,KAAKuI,SAAWpC,EAAO,GACvBnG,KAAKiJ,OAAS9C,EAAO,GAEzB,EAACF,EAEDuD,SAAA,WACE,OAAWxJ,KAACuC,OAASQ,WAAWR,KAClC,IAEMvB,MAAK,WAAA,IACL,IAAA2E,EAAA3F,KAAJ,OACEqC,QAAAC,QADEqD,EAAKjF,QAAQ0I,MACRzD,EAAK8D,iBAEL9D,EAAK+D,oBAIVD,CAFL,MAEKA,GAAAA,OAAAA,QAAAA,OAAAA,EAAAA,CAAAA,EAAAA,EAAAA,eAAc,WAAA,IAAA,IAAAvD,EAEblG,KADgBgB,OAAAA,QAAAA,QAAAA,MAChBkF,EAAKxF,QAAQ0I,MAAmC,8BAAA,IAAmBO,gBAAC,CACrEC,GAAI1D,EAAK8C,UACRzD,2BAHCY,GAAM,OAAA9D,QAAAC,QAKO6D,EAAOC,QAApBA,KAAAA,SAAAA,GAENF,EAAK2D,cAAczD,EAAK0D,OAAQ1D,EAAKhC,QAASgC,EAAKO,MAAO,EAC5D,GAAC,sCAEK+C,kBAAiB,WAAA,IAChB,IAAAK,EAAA/J,KAAL,OAAK+J,EAAKd,QAAWc,EAAKxB,yBAGAvH,MAAM+I,EAAKC,cAAY/I,KAAA,SAA3CgJ,GAAW,OAAA5H,QAAAC,QACWtB,MAAM+I,EAAKG,eAAajJ,KAAA,SAA9CkJ,GAAa,OAAA9H,QAAAC,QACOtB,MAAM+I,EAAKK,aAAWnJ,KAAA,SAA1CoJ,GAAW,SAAAC,IAAA,SAAAnH,IAAA,SAAAoH,IAejBR,EAAKF,cAAcW,EAAWrB,EAAab,EAAW,CALtD,IAAIA,EAAqCmC,EAAA,WAAA,GACrCJ,EAAYK,GAAE,OAAArI,QAAAC,QACE+H,EAAYjE,QAAMnF,KAAA,SAAA0J,GAApCrC,EAASqC,CAA4B,EANvC,CAIyC,GAJzC,OAAAF,GAAAA,EAAAxJ,KAAAwJ,EAAAxJ,KAAAsJ,GAAAA,GAAA,CAAA,MAAoD3J,EAAA,WAAA,GAChDuJ,EAAcO,GAAE,OAAArI,QAAAC,QACE6H,EAAc/D,QAAMnF,KAAA,SAAA2J,GAAxCzB,EAAWyB,CAA8B,EAN3C,CAIoD,GAJpD,OAAAhK,GAAAA,EAAAK,KAAAL,EAAAK,KAAAkC,GAAAA,GAAA,CAAA,IAAiDqH,kBAC7CP,EAAYS,GAAE,OAAArI,QAAAC,QACE2H,EAAY7D,QAAMnF,KAAA,SAAA4J,GAApCL,EAAqCK,CAAA,EAAA,IAAA,OAAAC,GAAAA,EAAA7J,KAAA6J,EAAA7J,KAAAqJ,GAAAA,GAAA,EAAA,EAAA,GAPtCjI,QAAAC,SAmBF,CAAA,MAAAX,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,EAAAsE,EAED+D,UAAA,WACE,iBAAkBhK,KAAKiJ,OAAM,uBAAuBjJ,KAAKuI,QAC3D,IAEA2B,WAAA,WACE,MAAkB,WAAAlK,KAAKiJ,+BAA8BjJ,KAAKuI,QAC5D,EAEA6B,EAAAA,SAAA,WACE,MAAkB,WAAApK,KAAKiJ,OAAsC,gCAAAjJ,KAAKuI,QACpE,EAEMwC,EAAAA,gBAAgBC,SAAAA,GAA8B,IAAA,IAC1C3H,EAD0C4H,EAAA,SAAApK,GAuBlD,IAAMgE,EAAiBxB,GAAQA,EAAK2B,IAAM3B,EAAK2B,GAAGO,WAClD,IAAKV,EAAgB,UAAe7B,MAAC,+BAErC,IAAiBkI,EAAgB,CAAElG,GAAIH,GAGvC,OAFIxB,GAAQA,EAAK0B,SAAQmG,EAAYnG,OAAS1B,EAAK0B,OAAOQ,YAE/Cb,IAAAA,EAAQwG,EAAa,EA3B5BC,EAAAnL,qBAAAmL,EAAKzK,QAAQ0I,MACapI,OAAAA,QAAAA,QAAAA,MACvBmK,EAAKzK,QAAQ0I,MAA0B,qBAAA,IAAmBO,gBAAAyB,EAAA,CAC3DxB,GAAIuB,EAAKnC,SACNgC,IACFzF,aACJtE,KAAA,SALKoK,GAMaA,OAAAA,QAAAA,QAAAA,EAAcjF,QAAMnF,KAAA,SAAjCmF,GACN/C,EAAO+C,EAAKhE,OAAQ,EAEpB,GAAA,IAAK+I,EAAKjC,WACR,MAAM,IAASlG,MAAC,uDAElB,IAAKmI,EAAKjC,WAAWoC,WAAaC,EAAMJ,EAAKjC,WAAWoC,UACtD,UAAetI,MAAC,+CAClB,IAAiBwI,EAAG,IAAOC,IAACN,EAAKjC,WAAWoC,UACgB,OAA5DE,EAAYE,OAAS,oBAAoBV,GAAQzF,WACrBvE,QAAAA,QAAAA,MAAMwK,IAAYvK,KAAA,SAAxCoK,GACOA,OAAAA,QAAAA,QAAAA,EAAcjF,QAAMnF,KAAA,SAAA0K,GAAjCtI,EAAIsI,CAA8B,uDAUrC,CAAA,MAAAhK,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,EAAAsE,EAEK2F,eAAc,SAAClI,GAAwB,IACtC,IAAAmI,EAAA7L,KAAL,IAAK6L,EAAK3C,WACR,MAAM,UAAU,uDAElB,IAAM4C,EAAsB,IAAfpI,EAAK6C,QACmBwF,EAAAF,EAAK3C,WAAlC8C,EAAAA,EAAAA,eAER,IAAKC,EAAc,CAAEtI,OAAQmI,EAAMtH,IAFXA,EAAAA,IAEgBC,MAFXA,MAG3B,MAAM,IAASzB,MAAC,kBAClB,GACEU,EAAK8C,SACLwF,GACAA,EAAiB,GACjBtI,EAAK8C,QAAQuB,OAASiE,EAEtB,MAAUhJ,IAAAA,MACsBgJ,8BAAAA,EAC/B,wBAEH,IAAmBE,EAIf,CAAEvI,OAAQmI,EAAKvG,YAKnB,OAJI7B,EAAK8C,UAAS0F,EAAc1F,QAAU9C,EAAK8C,SAC3C9C,EAAKyI,YACPD,EAAcC,UAAYvJ,KAAKC,UAAUa,EAAKyI,YAEhD9J,QAAAC,QAAOuJ,EAAKd,gBAAgBmB,GAGxBzI,CAFL,MAEKA,GAAAA,OAAAA,QAAAA,OAAAA,EAAAA,CAAAA,EAAAA,EAAAA,MAAMA,SAAAA,EAAcE,YAAAA,IAAAA,EAAiB,GAAC,UACrC3D,KAAL,IAAKoM,EAAKjD,YACR,MAAUnG,IAAAA,MAAM,wDAElB,IAAgDqJ,EAAAD,EAAKjD,YAA7CnF,EAAAA,EAAAA,YAAaE,EAAAA,EAAAA,UAAWC,EAAWkI,EAAXlI,YACrB5B,EAAG6J,EAAK5C,WACnB,IAAKjH,EACH,MAAM,UAAU,uBAElB,OAAO+J,QAAAA,QAAAA,EACL,CACEtI,YAAAA,EACAE,UAAAA,EACAC,YAAAA,EACAR,OAAAA,EACAF,MAAAA,GAEF,CAAElB,MAAAA,IAEL,CAAA,MAAAZ,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,EAAAsE,EAEKsG,WAAU,SAAAhI,EAEd7D,OADS6F,EAAAhC,EAAPgC,QAASC,EAAAA,EAAAA,QAASE,EAAAA,EAAAA,OAAQ/E,EAAC4C,EAAD5C,OAC5BjB,IAAAA,IAAAA,EAAsB,CAAE,GAAA,IAAA,IAAA8L,EAEnBxM,KAAL,IAAKwM,EAAKtD,WACR,MAAUlG,IAAAA,MAAM,uDAElB,IAAKwJ,EAAKhE,YACR,MAAUxF,IAAAA,MAAM,2BAElB,IAAOyD,EAAG+F,EAAKhE,YACTsD,EAAiB,IAAVvF,EACbkG,EAAkCD,EAAKtD,WAA/BwD,EAAWD,EAAXC,YAER,IAAKT,EAAc,CAAEtI,OAAQmI,EAAMtH,IAFXiI,EAAHjI,IAEmBC,IAFdA,EAAAA,MAGxB,MAAUzB,IAAAA,MAAM,kBAClB,IAAK0J,EAAa,UAAe1J,MAAC,uCAAuC,OAAAX,QAAAC,QAErDgE,EAClB,CACEC,QAASuF,EACTtF,QAAAA,EACAC,EAAAA,EACA9E,EAAAA,EACA+E,OAAAA,GAEFhG,IACDO,KAAA,SATK0G,GAUN,IAAegF,EAAsC,CACnDhJ,OAAQmI,EAAKvG,WACboB,MAAO/D,KAAKC,UAAU8E,IACtB,OAAAtF,QAAAC,QAEoBkK,EAAKzB,gBAAgB4B,GAAU,EAIjDC,CAFL,MAEKA,GAAAA,OAAAA,QAAAA,OAAAA,EAAAA,CAAAA,EAAAA,EAAAA,IACJlJ,SAAAA,EACAhD,YAAAA,IAAAA,EAAsB,CAAA,GAAE,IAAA,IAEX0B,EAAGpC,KAAKuM,WAAW7I,EAAMhD,GAC3B6B,EADKvC,KACGwJ,WACnB,IAAKjH,EACH,MAAM,IAASS,MAAC,uBACjB,OACKT,QAAAA,QAAAA,EAAMC,UAAQvB,KAAA,WAAA,IAAA4L,EACHtK,EAAME,YAAmBL,OAAAA,QAAAA,QAAAA,oBAC1C,OADiBG,EAAAA,KAAAA,EAAkBuK,EAAgBjI,eACnC,EAClB,GAAC,sCAEOgF,cAAA,SACNX,EACAC,EACAb,GAQA,GANIY,IACFlJ,KAAKkJ,WJpO0B,SACnC7F,GAEA,GANsB,eAMlBA,EAAK2E,IACP,MAAUhF,IAAAA,MAAM,8BAElB,OAAkBK,EAAKiI,SAAW,IAAI1J,OACtC,IAAK2J,EAAMD,GAAW,MAAM,IAAStI,MAAC,gCAEtC,IAII+J,EACAC,EALKxI,EAAGZ,KAAKqJ,KAAKC,OAAO7J,EAAK8J,aAAe,IAC3C1I,EAAMb,KAAKC,MAAMqJ,OAAO7J,EAAK+J,cACnC,IAAM5I,IAAOC,GAAQD,EAAMC,EAAK,MAAM,IAASzB,MAAC,8BAIhD,IACE+J,EAAWnK,KAAKU,MAAMD,EAAK0J,SAAW,IACtCC,EAAejH,EAAM,QAAC1C,EAAK0J,SAAW,IAAIxH,SAASS,UAIpD,CAHC,SACA+G,EAAW,GACXC,EAAejH,UAAO,MAAMR,SAASS,EAAG,QACzC,CAKD,IAHA,MAAY,GACGqH,EAAG,KACD,GACPvF,EAAG,EAAGA,EAAIiF,EAAShF,OAAQD,IAAK,CACxC,IAAAwF,EAAeP,EAASjF,GAAjByF,EAAGC,EAAAA,GAAAA,OACV,OAAQD,GACN,IAAK,aACHF,EAAcG,EACd,MACF,IAAK,kBACHC,EAAaD,EACb,MACF,IAAK,mBACL,IAAK,oBACHE,EAAQ,QAAUH,EAAI,IAAMC,EAGjC,CACD,IAEUvE,EAFG0E,EAAGtK,EAAKsK,UAGrB,IACE1E,EAAS,IAAIwC,IAAIH,GAAUsC,QAK7B,CAJE,MAAAC,GAIF,CAAA,MAAO,CACLvC,SAAAA,EACAwC,MAAOtJ,IAAQC,EACfD,IAAAA,EACAC,IAAAA,EACAwE,OAAAA,EACA8D,SAAAA,EACAC,aAAAA,EACAS,WAAAA,EACAJ,YAAAA,EACAK,MAAAA,EACAC,UAAAA,EACA3B,eAAgBkB,OAAO7J,EAAK2I,iBAAmB,EAC/C+B,QAAS1K,EACTqJ,YAAarJ,EAAKqJ,cAAe,EAErC,CIkKwBsB,CAAsB9E,IAEtCC,IACFnJ,KAAKmJ,YL/PyB,SAClC9F,GAEA,GALkB,YAKdA,EAAK2E,IAAqB,MAAM,IAAShF,MAAC,0BAC9C,GAAoB,OAAhBK,EAAK4K,OAAiB,UAAejL,MAAC,yBAE1C,KACI,gBAAoBkL,WAAW,KACE,UAAnC7K,EAAK6K,WAAW,GAAc,UAE9B,UAAelL,MAAC,4BAElB,KACI,gBAAiBK,EAAK6K,WAAW,MAClC7K,EAAK6K,WAAW,GAAgB,YAEjC,MAAUlL,IAAAA,MAAM,8BAElB,IAAKK,EAAK2D,OAAQ,MAAUhE,IAAAA,MAAM,yBAMlC,MAAO,CACLgB,YALkBX,EAAK2D,OAMvB9C,UALgBb,EAAK6K,WAAW,GAAc,UAM9C/J,YALkBd,EAAK6K,WAAW,GAAgB,YAOtD,CKkOyBC,CAAqBhF,IAEtCb,EAAW,CAAA,IAAA8F,EAC0C/F,EACrDC,EACAtI,KAAKuI,UAFNvI,KAAKsI,UAAS8F,EAAA,GAAEpO,KAAKwI,YAAa4F,EAAA,GAAApO,KAAKyI,YAAW2F,EAAA,EAIpD,CACH,IAnOA,KCtCWC,SAAwBC,GAAgB,IACnD,IAAM9N,EACJ,iCAAmC8N,EAAS/E,cAAgB,QAAQ,OAAAlH,QAAAC,QAC/CtB,MAAMR,IAAvB+N,KAAAA,SAAAA,0BACaA,EAASnI,QAAMnF,KAAA,SAA5BoC,GAEN,SAAYmL,WARO,GAQmB,IACvC,CAAA,MAAA7M,GAAA,OAAAU,QAAAmB,OAAA7B,EAAA,CAAA,EAEY8M,WAAYlK,OAChBgC,EAAAhC,EAAPgC,QACQ,OAAAlE,QAAAC,QAKW+L,IALnBC,WAK2CrN,KAAA,SAArCyN,GAEN,cAAcnI,GAAWmI,CAAK,EAChC,6EAE4BC,OACpBhL,EAAAgL,EAANhL,8BAMmB0K,EALnBC,EAAAA,WAK2CrN,KAAA,SAArCyN,GAEN,YAAY7K,MAAMqJ,OAAOvJ,GAAU+K,EAAM,EAC3C,iCAEkCE,OAEhCN,IAAAA,SACAO,EAAAA,EAAAA,OAQC,OAFIA,IACHA,EAAS,MACVxM,QAAAC,QACuBmM,EAAa,CAAElI,QAXhCqI,EAAPrI,QAWgD+H,SAAAA,KAA1CQ,KAAAA,SAAAA,GACN,OAAOA,EAAUC,eAAeF,EAAQ,CACtCG,MAAO,WACPV,SAAAA,GACC,EACL"}
1
+ {"version":3,"file":"index.cjs","sources":["../src/utils/storage.ts","../src/l402/index.ts","../src/l402/parse.js","../src/podcasting2/boostagrams.ts","../src/utils/keysend.ts","../src/utils/lnurl.ts","../src/invoice.ts","../src/utils/invoice.ts","../src/utils/nostr.ts","../src/lightning-address.ts","../src/utils/fiat.ts"],"sourcesContent":["export class MemoryStorage {\n storage;\n\n constructor(initial?: Record<string, unknown>) {\n this.storage = initial || {};\n }\n\n getItem(key: string) {\n return this.storage[key];\n }\n\n setItem(key: string, value: unknown) {\n this.storage[key] = value;\n }\n}\n\nexport class NoStorage {\n constructor(initial?: unknown) {}\n\n getItem(key: string) {\n return null;\n }\n\n setItem(key: string, value: unknown) {}\n}\n\nexport default MemoryStorage;\n","import MemoryStorage from \"../utils/storage\";\nimport { WebLNProvider } from \"@webbtc/webln-types\";\nimport { parseL402 } from \"./parse\";\n\nexport * as storage from \"../utils/storage\";\nconst memoryStorage = new MemoryStorage();\n\nconst HEADER_KEY = \"L402\"; // we have to update this to L402 at some point\n\nexport const fetchWithL402 = async (\n url: string,\n fetchArgs: RequestInit,\n options: {\n headerKey?: string;\n webln?: WebLNProvider;\n store?: Storage;\n },\n) => {\n if (!options) {\n options = {};\n }\n const headerKey = options.headerKey || HEADER_KEY;\n const webln: WebLNProvider = options.webln || globalThis.webln;\n if (!webln) {\n throw new Error(\"WebLN is missing\");\n }\n const store = options.store || memoryStorage;\n if (!fetchArgs) {\n fetchArgs = {};\n }\n fetchArgs.cache = \"no-store\";\n fetchArgs.mode = \"cors\";\n if (!fetchArgs.headers) {\n fetchArgs.headers = {};\n }\n const cachedL402Data = store.getItem(url);\n if (cachedL402Data) {\n const data = JSON.parse(cachedL402Data);\n fetchArgs.headers[\n \"Authorization\"\n ] = `${headerKey} ${data.token}:${data.preimage}`;\n return await fetch(url, fetchArgs);\n }\n\n fetchArgs.headers[\"Accept-Authenticate\"] = headerKey;\n const initResp = await fetch(url, fetchArgs);\n const header = initResp.headers.get(\"www-authenticate\");\n if (!header) {\n return initResp;\n }\n\n const details = parseL402(header);\n const token = details.token || details.macaroon;\n const inv = details.invoice;\n\n await webln.enable();\n const invResp = await webln.sendPayment(inv);\n\n store.setItem(\n url,\n JSON.stringify({\n token: token,\n preimage: invResp.preimage,\n }),\n );\n\n fetchArgs.headers[\n \"Authorization\"\n ] = `${headerKey} ${token}:${invResp.preimage}`;\n return await fetch(url, fetchArgs);\n};\n\nexport default fetchWithL402;\n","export const parseL402 = (string) => {\n string = string.replace(\"L402\", \"\");\n string = string.replace(\"LSAT\", \"\");\n // Split the string into key-value pairs\n const pairs = string.split(\",\");\n\n // Split each pair into key and value\n const keyValuePairArray = pairs.map((pair) => {\n const [key, valuePotentiallyQuoted] = pair.split(\"=\").map((e) => e.trim());\n const valueMatch = valuePotentiallyQuoted.match(/\"?([^\"]*)\"?/);\n const value = valueMatch[1];\n return [key, value];\n });\n\n return Object.fromEntries(keyValuePairArray);\n};\n","import { WebLNProvider } from \"@webbtc/webln-types\";\n\ntype BoostOptions = {\n webln?: unknown;\n};\n\ntype BoostArguments = {\n destination: string;\n customKey?: string;\n customValue?: string;\n amount?: number;\n boost: Boost;\n};\n\ntype WeblnBoostParams = {\n destination: string;\n amount: number;\n customRecords: Record<string, string>;\n};\n\nexport type Boost = {\n action: string;\n value_msat: number;\n value_msat_total: number;\n app_name: string;\n app_version: string;\n feedId: string;\n podcast: string;\n episode: string;\n ts: number;\n name: string;\n sender_name: string;\n};\n\nexport const boost = async (args: BoostArguments, options?: BoostOptions) => {\n const { boost } = args;\n if (!options) {\n options = {};\n }\n const webln: WebLNProvider = options.webln || globalThis.webln;\n\n if (!webln) {\n throw new Error(\"WebLN not available\");\n }\n if (!webln.keysend) {\n throw new Error(\"Keysend not available in current WebLN provider\");\n }\n\n const amount = args.amount || Math.floor(boost.value_msat / 1000);\n\n const weblnParams: WeblnBoostParams = {\n destination: args.destination,\n amount: amount,\n customRecords: {\n \"7629169\": JSON.stringify(boost),\n },\n };\n if (args.customKey && args.customValue) {\n weblnParams.customRecords[args.customKey] = args.customValue;\n }\n await webln.enable();\n const response = await webln.keysend(weblnParams);\n return response;\n};\n\nexport default boost;\n","import type { KeysendResponse } from \"../types\";\n\nconst TAG_KEYSEND = \"keysend\";\n\nexport type KeySendRawData = {\n tag: string;\n status: string;\n customData: { customKey: string; customValue: string }[];\n pubkey: string;\n};\n\nexport const parseKeysendResponse = (data: KeySendRawData): KeysendResponse => {\n if (data.tag !== TAG_KEYSEND) throw new Error(\"Invalid keysend params\");\n if (data.status !== \"OK\") throw new Error(\"Keysend status not OK\");\n\n if (\n !(\"customKey\" in data.customData[0]) ||\n data.customData[0][\"customKey\"] != \"696969\"\n )\n throw new Error(\"Unable to find customKey\");\n\n if (\n !(\"customValue\" in data.customData[0]) ||\n !data.customData[0][\"customValue\"]\n )\n throw new Error(\"Unable to find customValue\");\n\n if (!data.pubkey) throw new Error(\"Pubkey does not exist\");\n\n const destination = data.pubkey;\n const customKey = data.customData[0][\"customKey\"];\n const customValue = data.customData[0][\"customValue\"];\n\n return {\n destination,\n customKey,\n customValue,\n };\n};\n","import Hex from \"crypto-js/enc-hex.js\";\nimport sha256 from \"crypto-js/sha256.js\";\n\nimport type {\n LUD18ServicePayerData,\n LnUrlPayResponse,\n LnUrlRawData,\n} from \"../types\";\n\nconst URL_REGEX =\n /((([A-Za-z]{3,9}:(?:\\/\\/)?)(?:[-;:&=+$,\\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=+$,\\w]+@)[A-Za-z0-9.-]+)((?:\\/[+~%/.\\w-_]*)?\\??(?:[-+=&;%@.\\w_]*)#?(?:[\\w]*))?)/;\n\nexport const isUrl = (url: string | null): url is string => {\n if (!url) return false;\n return URL_REGEX.test(url);\n};\n\nexport const isValidAmount = ({\n amount,\n min,\n max,\n}: {\n amount: number;\n min: number;\n max: number;\n}): boolean => {\n return amount > 0 && amount >= min && amount <= max;\n};\n\nconst TAG_PAY_REQUEST = \"payRequest\";\n\n// From: https://github.com/dolcalmi/lnurl-pay/blob/main/src/request-pay-service-params.ts\nexport const parseLnUrlPayResponse = (data: LnUrlRawData): LnUrlPayResponse => {\n if (data.tag !== TAG_PAY_REQUEST)\n throw new Error(\"Invalid pay service params\");\n\n const callback = (data.callback + \"\").trim();\n if (!isUrl(callback)) throw new Error(\"Callback must be a valid url\");\n\n const min = Math.ceil(Number(data.minSendable || 0));\n const max = Math.floor(Number(data.maxSendable));\n if (!(min && max) || min > max) throw new Error(\"Invalid pay service params\");\n\n let metadata: Array<Array<string>>;\n let metadataHash: string;\n try {\n metadata = JSON.parse(data.metadata + \"\");\n metadataHash = sha256(data.metadata + \"\").toString(Hex);\n } catch {\n metadata = [];\n metadataHash = sha256(\"[]\").toString(Hex);\n }\n\n let image = \"\";\n let description = \"\";\n let identifier = \"\";\n for (let i = 0; i < metadata.length; i++) {\n const [k, v] = metadata[i];\n switch (k) {\n case \"text/plain\":\n description = v;\n break;\n case \"text/identifier\":\n identifier = v;\n break;\n case \"image/png;base64\":\n case \"image/jpeg;base64\":\n image = \"data:\" + k + \",\" + v;\n break;\n }\n }\n const payerData = data.payerData as LUD18ServicePayerData | undefined;\n\n let domain: string | undefined;\n try {\n domain = new URL(callback).hostname;\n } catch {\n // fail silently and let domain remain undefined if callback is not a valid URL\n }\n\n return {\n callback,\n fixed: min === max,\n min,\n max,\n domain,\n metadata,\n metadataHash,\n identifier,\n description,\n image,\n payerData,\n commentAllowed: Number(data.commentAllowed) || 0,\n rawData: data,\n allowsNostr: data.allowsNostr || false,\n };\n};\n","import { decodeInvoice } from \"./utils/invoice\";\nimport Hex from \"crypto-js/enc-hex.js\";\nimport sha256 from \"crypto-js/sha256.js\";\nimport { InvoiceArgs } from \"./types\";\n\nexport default class Invoice {\n paymentRequest: string;\n paymentHash: string;\n preimage: string | null;\n verify: string | null;\n satoshi: number;\n expiry: number; // expiry in seconds (not a timestamp)\n timestamp: number; // created date in seconds\n createdDate: Date;\n expiryDate: Date;\n description: string | null;\n\n constructor(args: InvoiceArgs) {\n this.paymentRequest = args.pr;\n if (!this.paymentRequest) {\n throw new Error(\"Invalid payment request\");\n }\n const decodedInvoice = decodeInvoice(this.paymentRequest);\n if (!decodedInvoice) {\n throw new Error(\"Failed to decode payment request\");\n }\n this.paymentHash = decodedInvoice.paymentHash;\n this.satoshi = decodedInvoice.satoshi;\n this.timestamp = decodedInvoice.timestamp;\n this.expiry = decodedInvoice.expiry;\n this.createdDate = new Date(this.timestamp * 1000);\n this.expiryDate = new Date((this.timestamp + this.expiry) * 1000);\n this.description = decodedInvoice.description ?? null;\n this.verify = args.verify ?? null;\n this.preimage = args.preimage ?? null;\n }\n\n async isPaid(): Promise<boolean> {\n if (this.preimage) return this.validatePreimage(this.preimage);\n else if (this.verify) {\n return await this.verifyPayment();\n } else {\n throw new Error(\"Could not verify payment\");\n }\n }\n\n validatePreimage(preimage: string): boolean {\n if (!preimage || !this.paymentHash) return false;\n\n try {\n const preimageHash = sha256(Hex.parse(preimage)).toString(Hex);\n return this.paymentHash === preimageHash;\n } catch {\n return false;\n }\n }\n\n async verifyPayment(): Promise<boolean> {\n if (!this.verify) throw new Error(\"LNURL verify not available\");\n const result = await fetch(this.verify);\n const json = await result.json();\n if (json.preimage) {\n this.preimage = json.preimage;\n }\n\n return json.settled;\n }\n}\n","import { decode } from \"light-bolt11-decoder\";\n\ntype DecodedInvoice = {\n paymentHash: string;\n satoshi: number;\n timestamp: number;\n expiry: number;\n description: string | undefined;\n};\n\nexport const decodeInvoice = (\n paymentRequest: string,\n): DecodedInvoice | null => {\n if (!paymentRequest) return null;\n\n try {\n const decoded = decode(paymentRequest);\n if (!decoded || !decoded.sections) return null;\n\n const hashTag = decoded.sections.find(\n (value) => value.name === \"payment_hash\",\n );\n\n if (hashTag?.name !== \"payment_hash\" || !hashTag.value) return null;\n\n const paymentHash = hashTag.value;\n\n const amountTag = decoded.sections.find((value) => value.name === \"amount\");\n\n if (amountTag?.name !== \"amount\" || amountTag.value === undefined)\n return null;\n\n const satoshi = parseInt(amountTag.value) / 1000; // millisats\n\n const expiryTag = decoded.sections.find((value) => value.name === \"expiry\");\n\n const timestampTag = decoded.sections.find(\n (value) => value.name === \"timestamp\",\n );\n\n if (timestampTag?.name !== \"timestamp\" || !timestampTag.value) return null;\n\n const timestamp = timestampTag.value;\n\n if (expiryTag?.name !== \"expiry\" || expiryTag.value === undefined)\n return null;\n\n const expiry = expiryTag.value;\n\n const descriptionTag = decoded.sections.find(\n (value) => value.name === \"description\",\n );\n\n const description =\n descriptionTag?.name === \"description\"\n ? descriptionTag?.value\n : undefined;\n\n return {\n paymentHash,\n satoshi,\n timestamp,\n expiry,\n description,\n };\n } catch {\n return null;\n }\n};\n","import Hex from \"crypto-js/enc-hex.js\";\nimport sha256 from \"crypto-js/sha256.js\";\nimport { Event, NostrResponse, ZapArgs, ZapOptions } from \"../types\";\n\nexport async function generateZapEvent(\n { satoshi, comment, p, e, relays }: ZapArgs,\n options: ZapOptions = {},\n): Promise<Event> {\n const nostr = options.nostr || globalThis.nostr;\n if (!nostr) {\n throw new Error(\"nostr option or window.nostr is not available\");\n }\n\n const nostrTags = [\n [\"relays\", ...relays],\n [\"amount\", satoshi.toString()],\n ];\n if (p) {\n nostrTags.push([\"p\", p]);\n }\n if (e) {\n nostrTags.push([\"e\", e]);\n }\n\n const pubkey = await nostr.getPublicKey();\n\n const nostrEvent: Event = {\n pubkey,\n created_at: Math.floor(Date.now() / 1000),\n kind: 9734,\n tags: nostrTags,\n content: comment ?? \"\",\n };\n\n nostrEvent.id = getEventHash(nostrEvent);\n return await nostr.signEvent(nostrEvent);\n}\n\nexport function validateEvent(event: Event): boolean {\n if (typeof event.content !== \"string\") return false;\n if (typeof event.created_at !== \"number\") return false;\n // ignore these checks because if the pubkey is not set we add it to the event. same for the ID.\n // if (typeof event.pubkey !== \"string\") return false;\n // if (!event.pubkey.match(/^[a-f0-9]{64}$/)) return false;\n\n if (!Array.isArray(event.tags)) return false;\n for (let i = 0; i < event.tags.length; i++) {\n const tag = event.tags[i];\n if (!Array.isArray(tag)) return false;\n for (let j = 0; j < tag.length; j++) {\n if (typeof tag[j] === \"object\") return false;\n }\n }\n\n return true;\n}\n\nexport function serializeEvent(evt: Event): string {\n if (!validateEvent(evt))\n throw new Error(\"can't serialize event with wrong or missing properties\");\n\n return JSON.stringify([\n 0,\n evt.pubkey,\n evt.created_at,\n evt.kind,\n evt.tags,\n evt.content,\n ]);\n}\n\nexport function getEventHash(event: Event): string {\n return sha256(serializeEvent(event)).toString(Hex);\n}\n\nexport function parseNostrResponse(\n nostrData: NostrResponse,\n username: string | undefined,\n) {\n let nostrPubkey: string | undefined;\n let nostrRelays: string[] | undefined;\n if (username && nostrData) {\n nostrPubkey = nostrData.names?.[username];\n nostrRelays = nostrPubkey ? nostrData.relays?.[nostrPubkey] : undefined;\n }\n\n return [nostrData, nostrPubkey, nostrRelays] as const;\n}\n","import { KeySendRawData, parseKeysendResponse } from \"./utils/keysend\";\nimport { isUrl, isValidAmount, parseLnUrlPayResponse } from \"./utils/lnurl\";\nimport Invoice from \"./invoice\";\nimport {\n InvoiceArgs,\n LnUrlPayResponse,\n LnUrlRawData,\n NostrResponse,\n RequestInvoiceArgs,\n ZapArgs,\n ZapOptions,\n} from \"./types\";\nimport { generateZapEvent, parseNostrResponse } from \"./utils/nostr\";\nimport type { Boost } from \"./podcasting2/boostagrams\";\nimport { boost as booster } from \"./podcasting2/boostagrams\";\nimport { WebLNProvider, SendPaymentResponse } from \"@webbtc/webln-types\";\nimport { KeysendResponse } from \"./types\";\n\nconst LN_ADDRESS_REGEX =\n /^((?:[^<>()[\\]\\\\.,;:\\s@\"]+(?:\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(?:\".+\"))@((?:\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(?:(?:[a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\n\nexport const DEFAULT_PROXY = \"https://api.getalby.com/lnurl\";\n\ntype LightningAddressOptions = {\n proxy?: string | false;\n webln?: WebLNProvider;\n};\n\nexport default class LightningAddress {\n address: string;\n options: LightningAddressOptions;\n username: string | undefined;\n domain: string | undefined;\n pubkey: string | undefined;\n lnurlpData: LnUrlPayResponse | undefined;\n keysendData: KeysendResponse | undefined;\n nostrData: NostrResponse | undefined;\n nostrPubkey: string | undefined;\n nostrRelays: string[] | undefined;\n webln: WebLNProvider | undefined;\n\n constructor(address: string, options?: LightningAddressOptions) {\n this.address = address;\n this.options = { proxy: DEFAULT_PROXY };\n this.options = Object.assign(this.options, options);\n this.parse();\n this.webln = this.options.webln;\n }\n\n parse() {\n const result = LN_ADDRESS_REGEX.exec(this.address.toLowerCase());\n if (result) {\n this.username = result[1];\n this.domain = result[2];\n }\n }\n\n getWebLN() {\n return this.webln || globalThis.webln;\n }\n\n async fetch() {\n if (this.options.proxy) {\n return this.fetchWithProxy();\n } else {\n return this.fetchWithoutProxy();\n }\n }\n\n async fetchWithProxy() {\n const result = await fetch(\n `${this.options.proxy}/lightning-address-details?${new URLSearchParams({\n ln: this.address,\n }).toString()}`,\n );\n const json = await result.json();\n\n this.parseResponse(json.lnurlp, json.keysend, json.nostr);\n }\n\n async fetchWithoutProxy() {\n if (!this.domain || !this.username) {\n return;\n }\n const lnurlResult = await fetch(this.lnurlpUrl());\n const keysendResult = await fetch(this.keysendUrl());\n const nostrResult = await fetch(this.nostrUrl());\n\n let lnurlData: LnUrlRawData | undefined;\n if (lnurlResult.ok) {\n lnurlData = await lnurlResult.json();\n }\n let keysendData: KeySendRawData | undefined;\n if (keysendResult.ok) {\n keysendData = await keysendResult.json();\n }\n let nostrData: NostrResponse | undefined;\n if (nostrResult.ok) {\n nostrData = await nostrResult.json();\n }\n\n this.parseResponse(lnurlData, keysendData, nostrData);\n }\n\n lnurlpUrl() {\n return `https://${this.domain}/.well-known/lnurlp/${this.username}`;\n }\n\n keysendUrl() {\n return `https://${this.domain}/.well-known/keysend/${this.username}`;\n }\n\n nostrUrl() {\n return `https://${this.domain}/.well-known/nostr.json?name=${this.username}`;\n }\n\n async generateInvoice(params: Record<string, string>): Promise<Invoice> {\n let data;\n if (this.options.proxy) {\n const invoiceResult = await fetch(\n `${this.options.proxy}/generate-invoice?${new URLSearchParams({\n ln: this.address,\n ...params,\n }).toString()}`,\n );\n const json = await invoiceResult.json();\n data = json.invoice;\n } else {\n if (!this.lnurlpData) {\n throw new Error(\"No lnurlpData available. Please call fetch() first.\");\n }\n if (!this.lnurlpData.callback || !isUrl(this.lnurlpData.callback))\n throw new Error(\"Valid callback does not exist in lnurlpData\");\n const callbackUrl = new URL(this.lnurlpData.callback);\n callbackUrl.search = new URLSearchParams(params).toString();\n const invoiceResult = await fetch(callbackUrl);\n data = await invoiceResult.json();\n }\n\n const paymentRequest = data && data.pr && data.pr.toString();\n if (!paymentRequest) throw new Error(\"Invalid pay service invoice\");\n\n const invoiceArgs: InvoiceArgs = { pr: paymentRequest };\n if (data && data.verify) invoiceArgs.verify = data.verify.toString();\n\n return new Invoice(invoiceArgs);\n }\n\n async requestInvoice(args: RequestInvoiceArgs): Promise<Invoice> {\n if (!this.lnurlpData) {\n throw new Error(\"No lnurlpData available. Please call fetch() first.\");\n }\n const msat = args.satoshi * 1000;\n const { commentAllowed, min, max } = this.lnurlpData;\n\n if (!isValidAmount({ amount: msat, min, max }))\n throw new Error(\"Invalid amount\");\n if (\n args.comment &&\n commentAllowed &&\n commentAllowed > 0 &&\n args.comment.length > commentAllowed\n )\n throw new Error(\n `The comment length must be ${commentAllowed} characters or fewer`,\n );\n\n const invoiceParams: {\n amount: string;\n comment?: string;\n payerdata?: string;\n } = { amount: msat.toString() };\n if (args.comment) invoiceParams.comment = args.comment;\n if (args.payerdata)\n invoiceParams.payerdata = JSON.stringify(args.payerdata);\n\n return this.generateInvoice(invoiceParams);\n }\n\n async boost(boost: Boost, amount: number = 0) {\n if (!this.keysendData) {\n throw new Error(\"No keysendData available. Please call fetch() first.\");\n }\n const { destination, customKey, customValue } = this.keysendData;\n const webln = this.getWebLN();\n if (!webln) {\n throw new Error(\"WebLN not available\");\n }\n return booster(\n {\n destination,\n customKey,\n customValue,\n amount,\n boost,\n },\n { webln },\n );\n }\n\n async zapInvoice(\n { satoshi, comment, relays, e }: ZapArgs,\n options: ZapOptions = {},\n ): Promise<Invoice> {\n if (!this.lnurlpData) {\n throw new Error(\"No lnurlpData available. Please call fetch() first.\");\n }\n if (!this.nostrPubkey) {\n throw new Error(\"Nostr Pubkey is missing\");\n }\n const p = this.nostrPubkey;\n const msat = satoshi * 1000;\n const { allowsNostr, min, max } = this.lnurlpData;\n\n if (!isValidAmount({ amount: msat, min, max }))\n throw new Error(\"Invalid amount\");\n if (!allowsNostr) throw new Error(\"Your provider does not support zaps\");\n\n const event = await generateZapEvent(\n {\n satoshi: msat,\n comment,\n p,\n e,\n relays,\n },\n options,\n );\n const zapParams: { amount: string; nostr: string } = {\n amount: msat.toString(),\n nostr: JSON.stringify(event),\n };\n\n const invoice = await this.generateInvoice(zapParams);\n return invoice;\n }\n\n async zap(\n args: ZapArgs,\n options: ZapOptions = {},\n ): Promise<SendPaymentResponse> {\n const invoice = this.zapInvoice(args, options);\n const webln = this.getWebLN();\n if (!webln) {\n throw new Error(\"WebLN not available\");\n }\n await webln.enable();\n const response = webln.sendPayment((await invoice).paymentRequest);\n return response;\n }\n\n private parseResponse(\n lnurlpData: LnUrlRawData | undefined,\n keysendData: KeySendRawData | undefined,\n nostrData: NostrResponse | undefined,\n ) {\n if (lnurlpData) {\n this.lnurlpData = parseLnUrlPayResponse(lnurlpData);\n }\n if (keysendData) {\n this.keysendData = parseKeysendResponse(keysendData);\n }\n if (nostrData) {\n [this.nostrData, this.nostrPubkey, this.nostrRelays] = parseNostrResponse(\n nostrData,\n this.username,\n );\n }\n }\n}\n","const numSatsInBtc = 100_000_000;\n\nexport const getFiatBtcRate = async (currency: string): Promise<number> => {\n const url =\n \"https://getalby.com/api/rates/\" + currency.toLowerCase() + \".json\";\n const response = await fetch(url);\n const data = await response.json();\n\n return data.rate_float / numSatsInBtc;\n};\n\nexport const getFiatValue = async ({\n satoshi,\n currency,\n}: {\n satoshi: number | string;\n currency: string;\n}) => {\n const rate = await getFiatBtcRate(currency);\n\n return Number(satoshi) * rate;\n};\n\nexport const getSatoshiValue = async ({\n amount,\n currency,\n}: {\n amount: number | string;\n currency: string;\n}) => {\n const rate = await getFiatBtcRate(currency);\n\n return Math.floor(Number(amount) / rate);\n};\n\nexport const getFormattedFiatValue = async ({\n satoshi,\n currency,\n locale,\n}: {\n satoshi: number | string;\n currency: string;\n locale: string;\n}) => {\n if (!locale) {\n locale = \"en\";\n }\n const fiatValue = await getFiatValue({ satoshi, currency });\n return fiatValue.toLocaleString(locale, {\n style: \"currency\",\n currency,\n });\n};\n"],"names":["MemoryStorage","initial","storage","this","getItem","key","setItem","value","NoStorage","memoryStorage","fetchWithL402","url","fetchArgs","options","_exit2","_temp3","_result","headers","headerKey","fetch","then","initResp","header","get","keyValuePairArray","details","replace","split","map","pair","e","trim","_pair$split$map","match","Object","fromEntries","token","macaroon","inv","invoice","Promise","resolve","webln","enable","sendPayment","invResp","store","JSON","stringify","preimage","globalThis","Error","cache","mode","_temp4","cachedL402Data","data","parse","_await$fetch","reject","boost","args","keysend","amount","Math","floor","value_msat","weblnParams","destination","customRecords","customKey","customValue","URL_REGEX","test","_ref","min","max","Invoice","paymentRequest","paymentHash","verify","satoshi","expiry","timestamp","createdDate","expiryDate","description","pr","decodedInvoice","decoded","decode","sections","hashTag","find","name","amountTag","undefined","parseInt","timestampTag","expiryTag","descriptionTag","_unused","decodeInvoice","Date","_decodedInvoice$descr","_args$verify","_args$preimage","isPaid","_this2","validatePreimage","verifyPayment","_proto","sha256","Hex","toString","preimageHash","_this4","result","json","settled","generateZapEvent","comment","p","relays","nostr","nostrTags","concat","push","getPublicKey","pubkey","nostrEvent","created_at","now","kind","tags","content","id","getEventHash","signEvent","event","Array","isArray","i","length","tag","j","serializeEvent","evt","validateEvent","parseNostrResponse","nostrData","username","nostrPubkey","nostrRelays","_nostrData$names","names","_nostrData$relays","LN_ADDRESS_REGEX","LightningAddress","address","domain","lnurlpData","keysendData","proxy","assign","exec","toLowerCase","getWebLN","fetchWithProxy","fetchWithoutProxy","URLSearchParams","ln","parseResponse","lnurlp","_this6","lnurlpUrl","lnurlResult","keysendUrl","keysendResult","nostrUrl","nostrResult","_temp6","_temp2","lnurlData","_temp","ok","_nostrResult$json","_keysendResult$json","_lnurlResult$json","_temp5","generateInvoice","params","_temp9","invoiceArgs","_this8","_extends","invoiceResult","callback","isUrl","callbackUrl","URL","search","_invoiceResult$json","requestInvoice","_this10","msat","_this10$lnurlpData","commentAllowed","isValidAmount","invoiceParams","payerdata","_this12","_this12$keysendData","booster","zapInvoice","_this14","_this14$lnurlpData","allowsNostr","zapParams","zap","_sendPayment","_invoice","metadata","metadataHash","ceil","Number","minSendable","maxSendable","_metadata$i","k","v","identifier","image","payerData","hostname","_unused2","fixed","rawData","parseLnUrlPayResponse","status","customData","parseKeysendResponse","_parseNostrResponse","getFiatBtcRate","currency","response","rate_float","getFiatValue","rate","_ref2","_ref3","locale","fiatValue","toLocaleString","style"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import t from"crypto-js/enc-hex.js";import e from"crypto-js/sha256.js";import{decode as a}from"light-bolt11-decoder";class r{constructor(t){this.storage=void 0,this.storage=t||{}}getItem(t){return this.storage[t]}setItem(t,e){this.storage[t]=e}}var n={__proto__:null,MemoryStorage:r,NoStorage:class{constructor(t){}getItem(t){return null}setItem(t,e){}},default:r};const s=new r,o=async(t,e,a)=>{a||(a={});const r=a.headerKey||"L402",n=a.webln||globalThis.webln;if(!n)throw new Error("WebLN is missing");let o=a.store||s;e||(e={}),e.cache="no-store",e.mode="cors",e.headers||(e.headers={});const i=o.getItem(t);if(i){const a=JSON.parse(i);return e.headers.Authorization=`${r} ${a.token}:${a.preimage}`,await fetch(t,e)}e.headers["Accept-Authenticate"]=r;const l=await fetch(t,e),c=l.headers.get("www-authenticate");if(!c)return l;const h=(t=>{const e=(t=(t=t.replace("L402","")).replace("LSAT","")).split(",").map(t=>{const[e,a]=t.split("=").map(t=>t.trim());return[e,a.match(/"?([^"]*)"?/)[1]]});return Object.fromEntries(e)})(c),u=h.token||h.macaroon,m=h.invoice;await n.enable();const p=await n.sendPayment(m);return o.setItem(t,JSON.stringify({token:u,preimage:p.preimage})),e.headers.Authorization=`${r} ${u}:${p.preimage}`,await fetch(t,e)};var i={__proto__:null,storage:n,fetchWithL402:o,default:o};const l=async(t,e)=>{let{boost:a,amount:r}=t;e||(e={});const n=e.webln||globalThis.webln;r||(r=Math.floor(a.value_msat/1e3));let s={destination:t.destination,amount:r,customRecords:{7629169:JSON.stringify(a)}};return t.customKey&&t.customValue&&(s.customRecords[t.customKey]=t.customValue),await n.enable(),await n.keysend(s)};var c={__proto__:null,boost:l,default:l};function h(){return h=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var a=arguments[e];for(var r in a)Object.prototype.hasOwnProperty.call(a,r)&&(t[r]=a[r])}return t},h.apply(this,arguments)}const u=/((([A-Za-z]{3,9}:(?:\/\/)?)(?:[-;:&=\+\$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=\+\$,\w]+@)[A-Za-z0-9.-]+)((?:\/[\+~%\/.\w-_]*)?\??(?:[-\+=&;%@.\w_]*)#?(?:[\w]*))?)/,m=t=>!!t&&u.test(t),p=({amount:t,min:e,max:a})=>t>0&&t>=e&&t<=a;class w{constructor(t){var e,r;this.paymentRequest=void 0,this.paymentHash=void 0,this.preimage=void 0,this.verify=void 0,this.paymentRequest=t.pr,this.paymentHash=(t=>{if(!t)return null;try{const e=a(t);if(!e||!e.sections)return null;const r=e.sections.find(t=>"payment_hash"===t.name);return r&&r.value?r.value.toString():null}catch(t){return null}})(this.paymentRequest),this.verify=null!=(e=t.verify)?e:null,this.preimage=null!=(r=t.preimage)?r:null}async isPaid(){if(this.preimage)return this.validatePreimage(this.preimage);if(this.verify)return await this.verifyPayment();throw new Error("Could not verify payment")}validatePreimage(a){if(!a||!this.paymentHash)return!1;try{const r=e(t.parse(a)).toString(t);return this.paymentHash===r}catch(t){return!1}}async verifyPayment(){if(!this.verify)throw new Error("LNURL verify not available");const t=await fetch(this.verify),e=await t.json();return e.preimage&&(this.preimage=e.preimage),e.settled}}async function y({satoshi:t,comment:e,p:a,e:r,relays:n},s={}){const o=s.nostr||globalThis.nostr;if(!o)throw new Error("nostr option or window.nostr is not available");const i=[["relays",...n],["amount",t.toString()]];a&&i.push(["p",a]),r&&i.push(["e",r]);const l={pubkey:await o.getPublicKey(),created_at:Math.floor(Date.now()/1e3),kind:9734,tags:i,content:null!=e?e:""};return l.id=g(l),await o.signEvent(l)}function d(t){if("string"!=typeof t.content)return!1;if("number"!=typeof t.created_at)return!1;if(!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){const a=t.tags[e];if(!Array.isArray(a))return!1;for(let t=0;t<a.length;t++)if("object"==typeof a[t])return!1}return!0}function f(t){if(!d(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function g(a){return e(f(a)).toString(t)}function v(t,e){let a,r;var n,s;return e&&t&&(a=null==(n=t.names)?void 0:n[e],r=a?null==(s=t.relays)?void 0:s[a]:void 0),[t,a,r]}var b={__proto__:null,generateZapEvent:y,validateEvent:d,serializeEvent:f,getEventHash:g,parseNostrResponse:v};const k=/^((?:[^<>()\[\]\\.,;:\s@"]+(?:\.[^<>()\[\]\\.,;:\s@"]+)*)|(?:".+"))@((?:\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(?:(?:[a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;class E{constructor(t,e){this.address=void 0,this.options=void 0,this.username=void 0,this.domain=void 0,this.pubkey=void 0,this.lnurlpData=void 0,this.keysendData=void 0,this.nostrData=void 0,this.nostrPubkey=void 0,this.nostrRelays=void 0,this.webln=void 0,this.address=t,this.options={proxy:"https://api.getalby.com/lnurl"},this.options=Object.assign(this.options,e),this.parse(),this.webln=this.options.webln}parse(){const t=k.exec(this.address.toLowerCase());t&&(this.username=t[1],this.domain=t[2])}getWebLN(){return this.webln||globalThis.webln}async fetch(){return this.options.proxy?this.fetchWithProxy():this.fetchWithoutProxy()}async fetchWithProxy(){const t=await fetch(`${this.options.proxy}/lightning-address-details?${new URLSearchParams({ln:this.address}).toString()}`),e=await t.json();this.parseResponse(e.lnurlp,e.keysend,e.nostr)}async fetchWithoutProxy(){if(!this.domain||!this.username)return;const t=await fetch(this.lnurlpUrl()),e=await fetch(this.keysendUrl()),a=await fetch(this.nostrUrl());let r,n,s;t.ok&&(r=await t.json()),e.ok&&(n=await e.json()),a.ok&&(s=await a.json()),this.parseResponse(r,n,s)}lnurlpUrl(){return`https://${this.domain}/.well-known/lnurlp/${this.username}`}keysendUrl(){return`https://${this.domain}/.well-known/keysend/${this.username}`}nostrUrl(){return`https://${this.domain}/.well-known/nostr.json?name=${this.username}`}async generateInvoice(t){let e;if(this.options.proxy){const a=await fetch(`${this.options.proxy}/generate-invoice?${new URLSearchParams(h({ln:this.address},t)).toString()}`);e=(await a.json()).invoice}else{if(!this.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!this.lnurlpData.callback||!m(this.lnurlpData.callback))throw new Error("Valid callback does not exist in lnurlpData");const a=new URL(this.lnurlpData.callback);a.search=new URLSearchParams(t).toString();const r=await fetch(a);e=await r.json()}const a=e&&e.pr&&e.pr.toString();if(!a)throw new Error("Invalid pay service invoice");const r={pr:a};return e&&e.verify&&(r.verify=e.verify.toString()),new w(r)}async requestInvoice(t){if(!this.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");const e=1e3*t.satoshi,{commentAllowed:a,min:r,max:n}=this.lnurlpData;if(!p({amount:e,min:r,max:n}))throw new Error("Invalid amount");if(t.comment&&a&&a>0&&t.comment.length>a)throw new Error(`The comment length must be ${a} characters or fewer`);const s={amount:e.toString()};return t.comment&&(s.comment=t.comment),t.payerdata&&(s.payerdata=JSON.stringify(t.payerdata)),this.generateInvoice(s)}async boost(t,e=0){if(!this.keysendData)throw new Error("No keysendData available. Please call fetch() first.");const{destination:a,customKey:r,customValue:n}=this.keysendData,s=this.getWebLN();if(!s)throw new Error("WebLN not available");return l({destination:a,customKey:r,customValue:n,amount:e,boost:t},{webln:s})}async zapInvoice({satoshi:t,comment:e,relays:a,e:r},n={}){if(!this.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!this.nostrPubkey)throw new Error("Nostr Pubkey is missing");const s=this.nostrPubkey,o=1e3*t,{allowsNostr:i,min:l,max:c}=this.lnurlpData;if(!p({amount:o,min:l,max:c}))throw new Error("Invalid amount");if(!i)throw new Error("Your provider does not support zaps");const h=await y({satoshi:o,comment:e,p:s,e:r,relays:a},n),u={amount:o.toString(),nostr:JSON.stringify(h)};return await this.generateInvoice(u)}async zap(t,e={}){const a=this.zapInvoice(t,e),r=this.getWebLN();if(!r)throw new Error("WebLN not available");return await r.enable(),r.sendPayment((await a).paymentRequest)}parseResponse(a,r,n){a&&(this.lnurlpData=(a=>{if("payRequest"!==a.tag)throw new Error("Invalid pay service params");const r=(a.callback+"").trim();if(!m(r))throw new Error("Callback must be a valid url");const n=Math.ceil(Number(a.minSendable||0)),s=Math.floor(Number(a.maxSendable));if(!n||!s||n>s)throw new Error("Invalid pay service params");let o,i;try{o=JSON.parse(a.metadata+""),i=e(a.metadata+"").toString(t)}catch(a){o=[],i=e("[]").toString(t)}let l="",c="",h="";for(let t=0;t<o.length;t++){const[e,a]=o[t];switch(e){case"text/plain":c=a;break;case"text/identifier":h=a;break;case"image/png;base64":case"image/jpeg;base64":l="data:"+e+","+a}}let u,p=a.payerData;try{u=new URL(r).hostname}catch(t){}return{callback:r,fixed:n===s,min:n,max:s,domain:u,metadata:o,metadataHash:i,identifier:h,description:c,image:l,payerData:p,commentAllowed:Number(a.commentAllowed)||0,rawData:a,allowsNostr:a.allowsNostr||!1}})(a)),r&&(this.keysendData=(t=>{if("keysend"!==t.tag)throw new Error("Invalid keysend params");if("OK"!==t.status)throw new Error("Keysend status not OK");if(!("customKey"in t.customData[0])||"696969"!=t.customData[0].customKey)throw new Error("Unable to find customKey");if(!("customValue"in t.customData[0])||!t.customData[0].customValue)throw new Error("Unable to find customValue");if(!t.pubkey)throw new Error("Pubkey does not exist");return{destination:t.pubkey,customKey:t.customData[0].customKey,customValue:t.customData[0].customValue}})(r)),n&&([this.nostrData,this.nostrPubkey,this.nostrRelays]=v(n,this.username))}}const D=async t=>{const e="https://getalby.com/api/rates/"+t.toLowerCase()+".json",a=await fetch(e);return(await a.json()).rate_float/1e8},S=async({satoshi:t,currency:e})=>{const a=await D(e);return Number(t)*a};var N={__proto__:null,getFiatBtcRate:D,getFiatValue:S,getSatoshiValue:async({amount:t,currency:e})=>{const a=await D(e);return Math.floor(Number(t)/a)},getFormattedFiatValue:async({satoshi:t,currency:e,locale:a})=>(a||(a="en"),(await S({satoshi:t,currency:e})).toLocaleString(a,{style:"currency",currency:e}))};export{w as Invoice,E as LightningAddress,c as boostagrams,o as fetchWithL402,N as fiat,i as l402,b as nostr,l as sendBoostagram};
1
+ import t from"crypto-js/enc-hex.js";import e from"crypto-js/sha256.js";import{decode as a}from"light-bolt11-decoder";class r{constructor(t){this.storage=void 0,this.storage=t||{}}getItem(t){return this.storage[t]}setItem(t,e){this.storage[t]=e}}var n={__proto__:null,MemoryStorage:r,NoStorage:class{constructor(t){}getItem(t){return null}setItem(t,e){}},default:r};const s=new r,i=async(t,e,a)=>{a||(a={});const r=a.headerKey||"L402",n=a.webln||globalThis.webln;if(!n)throw new Error("WebLN is missing");const i=a.store||s;e||(e={}),e.cache="no-store",e.mode="cors",e.headers||(e.headers={});const o=i.getItem(t);if(o){const a=JSON.parse(o);return e.headers.Authorization=`${r} ${a.token}:${a.preimage}`,await fetch(t,e)}e.headers["Accept-Authenticate"]=r;const l=await fetch(t,e),c=l.headers.get("www-authenticate");if(!c)return l;const h=(t=>{const e=(t=(t=t.replace("L402","")).replace("LSAT","")).split(",").map(t=>{const[e,a]=t.split("=").map(t=>t.trim());return[e,a.match(/"?([^"]*)"?/)[1]]});return Object.fromEntries(e)})(c),u=h.token||h.macaroon,m=h.invoice;await n.enable();const p=await n.sendPayment(m);return i.setItem(t,JSON.stringify({token:u,preimage:p.preimage})),e.headers.Authorization=`${r} ${u}:${p.preimage}`,await fetch(t,e)};var o={__proto__:null,storage:n,fetchWithL402:i,default:i};const l=async(t,e)=>{const{boost:a}=t;e||(e={});const r=e.webln||globalThis.webln;if(!r)throw new Error("WebLN not available");if(!r.keysend)throw new Error("Keysend not available in current WebLN provider");const n=t.amount||Math.floor(a.value_msat/1e3),s={destination:t.destination,amount:n,customRecords:{7629169:JSON.stringify(a)}};return t.customKey&&t.customValue&&(s.customRecords[t.customKey]=t.customValue),await r.enable(),await r.keysend(s)};var c={__proto__:null,boost:l,default:l};function h(){return h=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var a=arguments[e];for(var r in a)Object.prototype.hasOwnProperty.call(a,r)&&(t[r]=a[r])}return t},h.apply(this,arguments)}const u=/((([A-Za-z]{3,9}:(?:\/\/)?)(?:[-;:&=+$,\w]+@)?[A-Za-z0-9.-]+|(?:www.|[-;:&=+$,\w]+@)[A-Za-z0-9.-]+)((?:\/[+~%/.\w-_]*)?\??(?:[-+=&;%@.\w_]*)#?(?:[\w]*))?)/,m=t=>!!t&&u.test(t),p=({amount:t,min:e,max:a})=>t>0&&t>=e&&t<=a;class d{constructor(t){var e,r,n;if(this.paymentRequest=void 0,this.paymentHash=void 0,this.preimage=void 0,this.verify=void 0,this.satoshi=void 0,this.expiry=void 0,this.timestamp=void 0,this.createdDate=void 0,this.expiryDate=void 0,this.description=void 0,this.paymentRequest=t.pr,!this.paymentRequest)throw new Error("Invalid payment request");const s=(t=>{if(!t)return null;try{const e=a(t);if(!e||!e.sections)return null;const r=e.sections.find(t=>"payment_hash"===t.name);if("payment_hash"!==(null==r?void 0:r.name)||!r.value)return null;const n=r.value,s=e.sections.find(t=>"amount"===t.name);if("amount"!==(null==s?void 0:s.name)||void 0===s.value)return null;const i=parseInt(s.value)/1e3,o=e.sections.find(t=>"expiry"===t.name),l=e.sections.find(t=>"timestamp"===t.name);if("timestamp"!==(null==l?void 0:l.name)||!l.value)return null;const c=l.value;if("expiry"!==(null==o?void 0:o.name)||void 0===o.value)return null;const h=o.value,u=e.sections.find(t=>"description"===t.name);return{paymentHash:n,satoshi:i,timestamp:c,expiry:h,description:"description"===(null==u?void 0:u.name)?null==u?void 0:u.value:void 0}}catch(t){return null}})(this.paymentRequest);if(!s)throw new Error("Failed to decode payment request");this.paymentHash=s.paymentHash,this.satoshi=s.satoshi,this.timestamp=s.timestamp,this.expiry=s.expiry,this.createdDate=new Date(1e3*this.timestamp),this.expiryDate=new Date(1e3*(this.timestamp+this.expiry)),this.description=null!=(e=s.description)?e:null,this.verify=null!=(r=t.verify)?r:null,this.preimage=null!=(n=t.preimage)?n:null}async isPaid(){if(this.preimage)return this.validatePreimage(this.preimage);if(this.verify)return await this.verifyPayment();throw new Error("Could not verify payment")}validatePreimage(a){if(!a||!this.paymentHash)return!1;try{const r=e(t.parse(a)).toString(t);return this.paymentHash===r}catch(t){return!1}}async verifyPayment(){if(!this.verify)throw new Error("LNURL verify not available");const t=await fetch(this.verify),e=await t.json();return e.preimage&&(this.preimage=e.preimage),e.settled}}async function y({satoshi:t,comment:e,p:a,e:r,relays:n},s={}){const i=s.nostr||globalThis.nostr;if(!i)throw new Error("nostr option or window.nostr is not available");const o=[["relays",...n],["amount",t.toString()]];a&&o.push(["p",a]),r&&o.push(["e",r]);const l={pubkey:await i.getPublicKey(),created_at:Math.floor(Date.now()/1e3),kind:9734,tags:o,content:null!=e?e:""};return l.id=v(l),await i.signEvent(l)}function w(t){if("string"!=typeof t.content)return!1;if("number"!=typeof t.created_at)return!1;if(!Array.isArray(t.tags))return!1;for(let e=0;e<t.tags.length;e++){const a=t.tags[e];if(!Array.isArray(a))return!1;for(let t=0;t<a.length;t++)if("object"==typeof a[t])return!1}return!0}function f(t){if(!w(t))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,t.pubkey,t.created_at,t.kind,t.tags,t.content])}function v(a){return e(f(a)).toString(t)}function g(t,e){let a,r;var n,s;return e&&t&&(a=null==(n=t.names)?void 0:n[e],r=a?null==(s=t.relays)?void 0:s[a]:void 0),[t,a,r]}var b={__proto__:null,generateZapEvent:y,validateEvent:w,serializeEvent:f,getEventHash:v,parseNostrResponse:g};const k=/^((?:[^<>()[\]\\.,;:\s@"]+(?:\.[^<>()[\]\\.,;:\s@"]+)*)|(?:".+"))@((?:\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(?:(?:[a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;class D{constructor(t,e){this.address=void 0,this.options=void 0,this.username=void 0,this.domain=void 0,this.pubkey=void 0,this.lnurlpData=void 0,this.keysendData=void 0,this.nostrData=void 0,this.nostrPubkey=void 0,this.nostrRelays=void 0,this.webln=void 0,this.address=t,this.options={proxy:"https://api.getalby.com/lnurl"},this.options=Object.assign(this.options,e),this.parse(),this.webln=this.options.webln}parse(){const t=k.exec(this.address.toLowerCase());t&&(this.username=t[1],this.domain=t[2])}getWebLN(){return this.webln||globalThis.webln}async fetch(){return this.options.proxy?this.fetchWithProxy():this.fetchWithoutProxy()}async fetchWithProxy(){const t=await fetch(`${this.options.proxy}/lightning-address-details?${new URLSearchParams({ln:this.address}).toString()}`),e=await t.json();this.parseResponse(e.lnurlp,e.keysend,e.nostr)}async fetchWithoutProxy(){if(!this.domain||!this.username)return;const t=await fetch(this.lnurlpUrl()),e=await fetch(this.keysendUrl()),a=await fetch(this.nostrUrl());let r,n,s;t.ok&&(r=await t.json()),e.ok&&(n=await e.json()),a.ok&&(s=await a.json()),this.parseResponse(r,n,s)}lnurlpUrl(){return`https://${this.domain}/.well-known/lnurlp/${this.username}`}keysendUrl(){return`https://${this.domain}/.well-known/keysend/${this.username}`}nostrUrl(){return`https://${this.domain}/.well-known/nostr.json?name=${this.username}`}async generateInvoice(t){let e;if(this.options.proxy){const a=await fetch(`${this.options.proxy}/generate-invoice?${new URLSearchParams(h({ln:this.address},t)).toString()}`);e=(await a.json()).invoice}else{if(!this.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!this.lnurlpData.callback||!m(this.lnurlpData.callback))throw new Error("Valid callback does not exist in lnurlpData");const a=new URL(this.lnurlpData.callback);a.search=new URLSearchParams(t).toString();const r=await fetch(a);e=await r.json()}const a=e&&e.pr&&e.pr.toString();if(!a)throw new Error("Invalid pay service invoice");const r={pr:a};return e&&e.verify&&(r.verify=e.verify.toString()),new d(r)}async requestInvoice(t){if(!this.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");const e=1e3*t.satoshi,{commentAllowed:a,min:r,max:n}=this.lnurlpData;if(!p({amount:e,min:r,max:n}))throw new Error("Invalid amount");if(t.comment&&a&&a>0&&t.comment.length>a)throw new Error(`The comment length must be ${a} characters or fewer`);const s={amount:e.toString()};return t.comment&&(s.comment=t.comment),t.payerdata&&(s.payerdata=JSON.stringify(t.payerdata)),this.generateInvoice(s)}async boost(t,e=0){if(!this.keysendData)throw new Error("No keysendData available. Please call fetch() first.");const{destination:a,customKey:r,customValue:n}=this.keysendData,s=this.getWebLN();if(!s)throw new Error("WebLN not available");return l({destination:a,customKey:r,customValue:n,amount:e,boost:t},{webln:s})}async zapInvoice({satoshi:t,comment:e,relays:a,e:r},n={}){if(!this.lnurlpData)throw new Error("No lnurlpData available. Please call fetch() first.");if(!this.nostrPubkey)throw new Error("Nostr Pubkey is missing");const s=this.nostrPubkey,i=1e3*t,{allowsNostr:o,min:l,max:c}=this.lnurlpData;if(!p({amount:i,min:l,max:c}))throw new Error("Invalid amount");if(!o)throw new Error("Your provider does not support zaps");const h=await y({satoshi:i,comment:e,p:s,e:r,relays:a},n),u={amount:i.toString(),nostr:JSON.stringify(h)};return await this.generateInvoice(u)}async zap(t,e={}){const a=this.zapInvoice(t,e),r=this.getWebLN();if(!r)throw new Error("WebLN not available");return await r.enable(),r.sendPayment((await a).paymentRequest)}parseResponse(a,r,n){a&&(this.lnurlpData=(a=>{if("payRequest"!==a.tag)throw new Error("Invalid pay service params");const r=(a.callback+"").trim();if(!m(r))throw new Error("Callback must be a valid url");const n=Math.ceil(Number(a.minSendable||0)),s=Math.floor(Number(a.maxSendable));if(!n||!s||n>s)throw new Error("Invalid pay service params");let i,o;try{i=JSON.parse(a.metadata+""),o=e(a.metadata+"").toString(t)}catch(a){i=[],o=e("[]").toString(t)}let l="",c="",h="";for(let t=0;t<i.length;t++){const[e,a]=i[t];switch(e){case"text/plain":c=a;break;case"text/identifier":h=a;break;case"image/png;base64":case"image/jpeg;base64":l="data:"+e+","+a}}const u=a.payerData;let p;try{p=new URL(r).hostname}catch(t){}return{callback:r,fixed:n===s,min:n,max:s,domain:p,metadata:i,metadataHash:o,identifier:h,description:c,image:l,payerData:u,commentAllowed:Number(a.commentAllowed)||0,rawData:a,allowsNostr:a.allowsNostr||!1}})(a)),r&&(this.keysendData=(t=>{if("keysend"!==t.tag)throw new Error("Invalid keysend params");if("OK"!==t.status)throw new Error("Keysend status not OK");if(!("customKey"in t.customData[0])||"696969"!=t.customData[0].customKey)throw new Error("Unable to find customKey");if(!("customValue"in t.customData[0])||!t.customData[0].customValue)throw new Error("Unable to find customValue");if(!t.pubkey)throw new Error("Pubkey does not exist");return{destination:t.pubkey,customKey:t.customData[0].customKey,customValue:t.customData[0].customValue}})(r)),n&&([this.nostrData,this.nostrPubkey,this.nostrRelays]=g(n,this.username))}}const E=async t=>{const e="https://getalby.com/api/rates/"+t.toLowerCase()+".json",a=await fetch(e);return(await a.json()).rate_float/1e8},x=async({satoshi:t,currency:e})=>{const a=await E(e);return Number(t)*a};var N={__proto__:null,getFiatBtcRate:E,getFiatValue:x,getSatoshiValue:async({amount:t,currency:e})=>{const a=await E(e);return Math.floor(Number(t)/a)},getFormattedFiatValue:async({satoshi:t,currency:e,locale:a})=>(a||(a="en"),(await x({satoshi:t,currency:e})).toLocaleString(a,{style:"currency",currency:e}))};export{d as Invoice,D as LightningAddress,c as boostagrams,i as fetchWithL402,N as fiat,o as l402,b as nostr,l as sendBoostagram};
2
2
  //# sourceMappingURL=index.modern.js.map