@getalby/lightning-tools 4.0.2 → 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
@@ -11,11 +11,15 @@ An npm package that provides useful and common tools and helpers to build lightn
11
11
  ```
12
12
  npm install @getalby/lightning-tools
13
13
  ```
14
+
14
15
  or
16
+
15
17
  ```
16
18
  yarn add @getalby/lightning-tools
17
19
  ```
20
+
18
21
  or for use without any build tools:
22
+
19
23
  ```
20
24
  // lightning-tools now available at window.lightningTools
21
25
  <script src="https://cdn.jsdelivr.net/npm/@getalby/lightning-tools@latest/dist/index.browser.js"></script>
@@ -41,7 +45,6 @@ await ln.fetch();
41
45
  console.log(ln.lnurlpData); // returns a [LNURLPayResponse](https://github.com/getAlby/js-lightning-tools/blob/master/src/types.ts#L1-L15)
42
46
  // get the keysend data:
43
47
  console.log(ln.keysendData);
44
-
45
48
  ```
46
49
 
47
50
  #### Get an invoice:
@@ -54,7 +57,7 @@ const ln = new LightningAddress("hello@getalby.com");
54
57
  await ln.fetch();
55
58
  // request an invoice for 1000 satoshis
56
59
  // this returns a new `Invoice` class that can also be used to validate the payment
57
- const invoice = await ln.requestInvoice({satoshi: 1000});
60
+ const invoice = await ln.requestInvoice({ satoshi: 1000 });
58
61
 
59
62
  console.log(invoice.paymentRequest); // print the payment request
60
63
  console.log(invoice.paymentHash); // print the payment hash
@@ -67,7 +70,7 @@ import { LightningAddress } from "@getalby/lightning-tools";
67
70
  const ln = new LightningAddress("hello@getalby.com");
68
71
  await ln.fetch();
69
72
 
70
- const invoice = await ln.requestInvoice({satoshi: 1000});
73
+ const invoice = await ln.requestInvoice({ satoshi: 1000 });
71
74
 
72
75
  // if the LNURL providers supports LNURL-verify:
73
76
  const paid = await invoice.verifyPayment(); // returns true of false
@@ -80,12 +83,11 @@ await window.webln.enable();
80
83
  const response = await window.webln.sendPayment(invoice.paymentRequest);
81
84
  const paid = invoice.validatePreimage(response.preimage); // returns true or false
82
85
  if (paid) {
83
- console.log('paid');
86
+ console.log("paid");
84
87
  }
85
88
 
86
89
  // or use the convenenice method:
87
90
  await invoice.isPaid();
88
-
89
91
  ```
90
92
 
91
93
  It is also possible to manually initialize the `Invoice`
@@ -93,7 +95,7 @@ It is also possible to manually initialize the `Invoice`
93
95
  ```js
94
96
  const { Invoice } = require("alby-tools");
95
97
 
96
- const invoice = new Invoice({paymentRequest: pr, preimage: preimage});
98
+ const invoice = new Invoice({ pr: pr, preimage: preimage });
97
99
  await invoice.isPaid();
98
100
  ```
99
101
 
@@ -118,7 +120,7 @@ const boost = {
118
120
  ts: 2121,
119
121
  name: "Satoshi",
120
122
  sender_name: "Alby",
121
- }
123
+ };
122
124
  await ln.boost(boost);
123
125
  ```
124
126
 
@@ -137,7 +139,7 @@ const response = await ln.zap({
137
139
  satoshi: 1000,
138
140
  comment: "Awesome post",
139
141
  relays: ["wss://relay.damus.io"],
140
- e: "44e1827635450ebb3c5a7d12c1f8e7b2b514439ac10a67eef3d9fd9c5c68e245"
142
+ e: "44e1827635450ebb3c5a7d12c1f8e7b2b514439ac10a67eef3d9fd9c5c68e245",
141
143
  });
142
144
  console.log(response.preimage); // print the preimage
143
145
  ```
@@ -160,12 +162,12 @@ This library includes a `fetchWithL402` function to consume L402 protected resou
160
162
 
161
163
  #### fetchWithL402(url: string, fetchArgs, options)
162
164
 
163
- + url: the L402 protected URL
164
- + fetchArgs: arguments are passed to the underlaying `fetch()` function used to do the HTTP request
165
- + options:
166
- + webln: the webln object used to call `sendPayment()` defaults to globalThis.webln
167
- + store: a key/value store object to persiste the l402 for each URL. The store must implement a `getItem()`/`setItem()` function as the browser's localStorage. By default a memory storage is used.
168
- + headerKey: defaults to L402 but if you need to consume an old LSAT API set this to LSAT
165
+ - url: the L402 protected URL
166
+ - fetchArgs: arguments are passed to the underlaying `fetch()` function used to do the HTTP request
167
+ - options:
168
+ - webln: the webln object used to call `sendPayment()` defaults to globalThis.webln
169
+ - store: a key/value store object to persiste the l402 for each URL. The store must implement a `getItem()`/`setItem()` function as the browser's localStorage. By default a memory storage is used.
170
+ - headerKey: defaults to L402 but if you need to consume an old LSAT API set this to LSAT
169
171
 
170
172
  ##### Examples
171
173
 
@@ -174,7 +176,13 @@ import { fetchWithL402 } from "@getalby/lightning-tools";
174
176
 
175
177
  // this will fetch the resouce and pay the invoice with window.webln.
176
178
  // the tokens/preimage data will be stored in the browser's localStorage and used for any following request
177
- await fetchWithL402('https://lsat-weather-api.getalby.repl.co/kigali', {}, { store: window.localStorage }).then(res => res.json()).then(console.log)
179
+ await fetchWithL402(
180
+ "https://lsat-weather-api.getalby.repl.co/kigali",
181
+ {},
182
+ { store: window.localStorage },
183
+ )
184
+ .then((res) => res.json())
185
+ .then(console.log);
178
186
  ```
179
187
 
180
188
  ```js
@@ -182,29 +190,59 @@ import { fetchWithL402 } from "@getalby/lightning-tools";
182
190
  import { webln } from "alby-js-sdk";
183
191
 
184
192
  // use a NWC WebLN provide to do the payments
185
- const nwc = new webln.NostrWebLNProvider({ nostrWalletConnectUrl: loadNWCUrl() });
193
+ const nwc = new webln.NostrWebLNProvider({
194
+ nostrWalletConnectUrl: loadNWCUrl(),
195
+ });
186
196
 
187
197
  // this will fetch the resouce and pay the invoice with a NWC webln object
188
- await fetchWithL402('https://lsat-weather-api.getalby.repl.co/kigali', {}, { webln: nwc }).then(res => res.json()).then(console.log)
198
+ await fetchWithL402(
199
+ "https://lsat-weather-api.getalby.repl.co/kigali",
200
+ {},
201
+ { webln: nwc },
202
+ )
203
+ .then((res) => res.json())
204
+ .then(console.log);
189
205
  ```
190
206
 
191
207
  ```js
192
208
  import { l402 } from "@getalby/lightning-tools";
193
209
 
194
210
  // do not store the tokens
195
- await l402.fetchWithL402('https://lsat-weather-api.getalby.repl.co/kigali', {}, { store: new l402.storage.NoStorage() })
211
+ await l402.fetchWithL402(
212
+ "https://lsat-weather-api.getalby.repl.co/kigali",
213
+ {},
214
+ { store: new l402.storage.NoStorage() },
215
+ );
216
+ ```
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;
196
228
  ```
197
229
 
230
+ > If you need more details about the invoice, use a dedicated BOLT11 decoding library.
231
+
198
232
  ### 💵 Fiat conversions
233
+
199
234
  Helpers to convert sats values to fiat and fiat values to sats.
200
235
 
201
236
  ##### getFiatValue(satoshi: number, currency: string): number
237
+
202
238
  Returns the fiat value for a specified currrency of a satoshi amount
203
239
 
204
240
  ##### getSatoshiValue(amount: number, currency: string): number
241
+
205
242
  Returns the satoshi value for a specified amount (in the smallest denomination) and currency
206
243
 
207
244
  ##### getFormattedFiatValue(satoshi: number, currency: string, locale: string): string
245
+
208
246
  Like `getFiatValue` but returns a formatted string for a given locale using JavaScript's `toLocaleString`
209
247
 
210
248
  #### Examples
@@ -212,10 +250,11 @@ Like `getFiatValue` but returns a formatted string for a given locale using Java
212
250
  ```js
213
251
  await getFiatValue(satoshi: 2100, currency: 'eur');
214
252
  await getSatoshiValue(amount: 100, currency: 'eur'); // for 1 EUR
215
- await getFormattedFiatValue(stoshi: 2100, currency: 'usd', locale: 'en')
253
+ await getFormattedFiatValue(satoshi: 2100, currency: 'usd', locale: 'en')
216
254
  ```
217
255
 
218
256
  ### 🤖 Lightning Address Proxy
257
+
219
258
  This library uses a [proxy](https://github.com/getAlby/lightning-address-details-proxy) to simplify requests to lightning providers.
220
259
 
221
260
  - Many ln addresses don't support CORS, which means fetching the data directly in a browser environment will not always work.
@@ -228,15 +267,17 @@ const lightningAddress = new LightningAddress("hello@getalby.com", {proxy: false
228
267
  ```
229
268
 
230
269
  ## fetch() dependency
270
+
231
271
  This library relies on a global fetch object which will work in browsers and node v18.x or newer. In old version yoi can manually install a global fetch option or polyfill if needed.
232
272
 
233
273
  For example:
274
+
234
275
  ```js
235
276
  import fetch from "cross-fetch"; // or "@inrupt/universal-fetch"
236
277
  globalThis.fetch = fetch;
237
278
 
238
279
  // or as a polyfill:
239
- import 'cross-fetch/polyfill';
280
+ import "cross-fetch/polyfill";
240
281
  ```
241
282
 
242
283
  ## 🛠 Development
@@ -250,11 +291,11 @@ yarn run build
250
291
 
251
292
  We are happy to help, please contact us or create an issue.
252
293
 
253
- * [Twitter: @getAlby](https://twitter.com/getAlby)
254
- * [Telegram group](https://t.me/getAlby)
255
- * support at getalby.com
256
- * [bitcoin.design](https://bitcoin.design/) Discord community (find us on the #alby channel)
257
- * Read the [Alby developer guide](https://guides.getalby.com/overall-guide/alby-for-developers/getting-started) to better understand how Alby packages and APIs can be used to power your app.
294
+ - [Twitter: @getAlby](https://twitter.com/getAlby)
295
+ - [Telegram group](https://t.me/getAlby)
296
+ - support at getalby.com
297
+ - [bitcoin.design](https://bitcoin.design/) Discord community (find us on the #alby channel)
298
+ - Read the [Alby developer guide](https://guides.getalby.com/overall-guide/alby-for-developers/getting-started) to better understand how Alby packages and APIs can be used to power your app.
258
299
 
259
300
  ## License
260
301
 
@@ -1,11 +1,12 @@
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,r=e.min,n=e.max,o=t>0&&t>=r&&t<=n;return o&&r===n?t===r:o},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},x=/^((?:[^<>()\[\]\\.,;:\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,}))$/,D=/*#__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://lnaddressproxy.getalby.com",webln:globalThis.webln},this.options=Object.assign(this.options,t),this.parse(),this.webln=this.options.webln}var t=e.prototype;return t.parse=function(){var e=x.exec(this.address.toLowerCase());e&&(this.username=e[1],this.domain=e[2])},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;return Promise.resolve(h({destination:n.destination,customKey:n.customKey,customValue:n.customValue,amount:t,boost:e},{webln:r.webln}))}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,n=r.zapInvoice(e,t);if(!r.webln)throw new Error("WebLN not available");return Promise.resolve(r.webln.enable()).then(function(){var e=r.webln,t=e.sendPayment;return Promise.resolve(n).then(function(r){return t.call(e,r.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}(),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)}},S=function(e){var t=e.satoshi;return Promise.resolve(E(e.currency)).then(function(e){return Number(t)*e})},_={__proto__:null,getFiatBtcRate:E,getFiatValue:S,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(S({satoshi:e.satoshi,currency:t})).then(function(e){return e.toLocaleString(r,{style:"currency",currency:t})})}};exports.Invoice=y,exports.LightningAddress=D,exports.boostagrams=m,exports.fetchWithL402=c,exports.fiat=_,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
8
- window["lightningTools"] = require('./index.cjs');
7
+ // @ts-ignore this file is created at build time
8
+ window["lightningTools"] = require("./index.cjs");
9
+
9
10
  },{"./index.cjs":1}],3:[function(require,module,exports){
10
11
  "use strict";
11
12
  /*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */
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,r=e.min,n=e.max,o=t>0&&t>=r&&t<=n;return o&&r===n?t===r:o},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},x=/^((?:[^<>()\[\]\\.,;:\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,}))$/,D=/*#__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://lnaddressproxy.getalby.com",webln:globalThis.webln},this.options=Object.assign(this.options,t),this.parse(),this.webln=this.options.webln}var t=e.prototype;return t.parse=function(){var e=x.exec(this.address.toLowerCase());e&&(this.username=e[1],this.domain=e[2])},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;return Promise.resolve(h({destination:n.destination,customKey:n.customKey,customValue:n.customValue,amount:t,boost:e},{webln:r.webln}))}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,n=r.zapInvoice(e,t);if(!r.webln)throw new Error("WebLN not available");return Promise.resolve(r.webln.enable()).then(function(){var e=r.webln,t=e.sendPayment;return Promise.resolve(n).then(function(r){return t.call(e,r.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}(),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)}},S=function(e){var t=e.satoshi;return Promise.resolve(E(e.currency)).then(function(e){return Number(t)*e})},_={__proto__:null,getFiatBtcRate:E,getFiatValue:S,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(S({satoshi:e.satoshi,currency:t})).then(function(e){return e.toLocaleString(r,{style:"currency",currency:t})})}};exports.Invoice=y,exports.LightningAddress=D,exports.boostagrams=m,exports.fetchWithL402=c,exports.fiat=_,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\n getItem(key) {\n return null;\n }\n\n setItem(key, value) {\n }\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 (url: string, fetchArgs: Record<string, any>, options: Record<string, any>) => {\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[\"Authorization\"] = `${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(url, JSON.stringify({\n 'token': token,\n 'preimage': invResp.preimage\n }));\n\n fetchArgs.headers[\"Authorization\"] = `${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 (!('customKey' in data.customData[0]) || data.customData[0]['customKey'] != '696969')\n throw new Error('Unable to find customKey');\n\n if (!('customValue' in data.customData[0]) || !data.customData[0]['customValue'])\n throw new Error('Unable to find customValue');\n\n if (!data.pubkey)\n 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}","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 = /((([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 const isValid = amount > 0 && amount >= min && amount <= max\n const isFixed = min === max\n return isValid && isFixed ? amount === min : isValid\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) 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)\n 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}","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}","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\n}: ZapArgs, options: ZapOptions = {}): 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(nostrData: NostrResponse, username: string | undefined) {\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}","import { parseKeysendResponse } from './utils/keysend';\nimport { isUrl, isValidAmount, parseLnUrlPayResponse } from './utils/lnurl';\nimport Invoice from './invoice';\nimport { InvoiceArgs, LnUrlPayResponse, NostrResponse, RequestInvoiceArgs, ZapArgs, ZapOptions } 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://lnaddressproxy.getalby.com\";\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, webln: globalThis.webln };\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 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(`${this.options.proxy}/lightning-address-details?${new URLSearchParams({ ln: this.address }).toString()}`);\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(`${this.options.proxy}/generate-invoice?${new URLSearchParams({ ln: this.address, ...params }).toString()}`);\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)) 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 (args.comment && commentAllowed && commentAllowed > 0 && args.comment.length > commentAllowed)\n throw new Error(\n `The comment length must be ${commentAllowed} characters or fewer`\n )\n\n const invoiceParams: { amount: string, comment?: string, payerdata?: string } = { amount: msat.toString() };\n if (args.comment) invoiceParams.comment = args.comment\n if (args.payerdata) 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 return booster({\n destination,\n customKey,\n customValue,\n amount,\n boost,\n }, {\n webln: this.webln,\n })\n }\n\n async zapInvoice({\n satoshi, comment, relays, e\n }: ZapArgs, options: ZapOptions = {}): 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 satoshi: msat, comment, p, e, relays\n }, options);\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(args: ZapArgs, options: ZapOptions = {}): Promise<SendPaymentResponse> {\n const invoice = this.zapInvoice(args, options);\n if (!this.webln) {\n // mainly for TS\n throw new Error(\"WebLN not available\");\n }\n await this.webln.enable();\n const response = this.webln.sendPayment((await invoice).paymentRequest);\n return response;\n }\n\n private parseResponse(lnurlpData: Record<string, string> | undefined, keysendData: Record<string, string> | undefined, nostrData: NostrResponse | undefined) {\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(nostrData, this.username);\n }\n }\n}\n","const numSatsInBtc = 100_000_000;\n\nexport const getFiatBtcRate = async (currency: string): Promise<number> => {\n const url = \"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 ({ satoshi, currency }: { satoshi: number | string; currency: string; }) => {\n const rate = await getFiatBtcRate(currency);\n\n return Number(satoshi) * rate;\n};\n\nexport const getSatoshiValue = async ({ amount, currency }: { amount: number | string; currency: string; }) => {\n const rate = await getFiatBtcRate(currency);\n\n return Math.floor(Number(amount) / rate);\n}\n\nexport const getFormattedFiatValue = async ({ satoshi, currency, locale }: { satoshi: number | string; currency: string; locale: string }) => {\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}"],"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","isUrl","test","isValidAmount","_ref","min","max","isValid","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","fetchWithProxy","fetchWithoutProxy","URLSearchParams","ln","parseResponse","lnurlp","_this6","lnurlpUrl","lnurlResult","keysendUrl","keysendResult","nostrUrl","nostrResult","lnurlData","ok","_nostrResult$json","_temp","_temp2","_keysendResult$json","_lnurlResult$json","_temp5","_temp6","generateInvoice","params","invoiceArgs","_this8","_temp10","_extends","invoiceResult","callback","callbackUrl","URL","search","_invoiceResult$json","requestInvoice","_this10","msat","_this10$lnurlpData","commentAllowed","invoiceParams","payerdata","_this12","_this12$keysendData","booster","zapInvoice","_this14","_this14$lnurlpData","allowsNostr","zapParams","zap","_this16","_this15$webln","_invoice","_sendPayment","call","metadataHash","ceil","Number","minSendable","maxSendable","metadata","image","description","identifier","_metadata$i","k","v","payerData","hostname","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
+ {"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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"}
package/dist/index.d.ts CHANGED
@@ -7,5 +7,5 @@ export * as boostagrams from "./podcasting2/boostagrams";
7
7
  export * as fiat from "./utils/fiat";
8
8
  export * as nostr from "./utils/nostr";
9
9
  export { fetchWithL402, sendBoostagram, LightningAddress, Invoice };
10
- export * from './types';
10
+ export * from "./types";
11
11
  //# sourceMappingURL=index.d.ts.map