Merge branch 'master' into fix-resources-access
This commit is contained in:
		
						commit
						73b2be0a97
					
				| @ -4,7 +4,7 @@ import logger from '../logger'; | ||||
| import { Common } from './common'; | ||||
| 
 | ||||
| class DatabaseMigration { | ||||
|   private static currentVersion = 27; | ||||
|   private static currentVersion = 28; | ||||
|   private queryTimeout = 120000; | ||||
|   private statisticsAddedIndexed = false; | ||||
|   private uniqueLogs: string[] = []; | ||||
| @ -274,6 +274,12 @@ class DatabaseMigration { | ||||
|         await this.$executeQuery('ALTER TABLE `lightning_stats` ADD med_base_fee_mtokens bigint(20) unsigned NOT NULL DEFAULT "0"'); | ||||
|       } | ||||
| 
 | ||||
|       if (databaseSchemaVersion < 28 && isBitcoin === true) { | ||||
|         await this.$executeQuery(`TRUNCATE lightning_stats`); | ||||
|         await this.$executeQuery(`TRUNCATE node_stats`); | ||||
|         await this.$executeQuery(`ALTER TABLE lightning_stats MODIFY added DATE`); | ||||
|       } | ||||
| 
 | ||||
|     } catch (e) { | ||||
|       throw e; | ||||
|     } | ||||
|  | ||||
| @ -44,7 +44,9 @@ class NodeSyncService { | ||||
|       await this.$lookUpCreationDateFromChain(); | ||||
|       await this.$updateNodeFirstSeen(); | ||||
|       await this.$scanForClosedChannels(); | ||||
|       await this.$runClosedChannelsForensics(); | ||||
|       if (config.MEMPOOL.BACKEND === 'esplora') { | ||||
|         await this.$runClosedChannelsForensics(); | ||||
|       } | ||||
| 
 | ||||
|     } catch (e) { | ||||
|       logger.err('$updateNodes() error: ' + (e instanceof Error ? e.message : e)); | ||||
|  | ||||
| @ -6,7 +6,7 @@ import channelsApi from '../../api/explorer/channels.api'; | ||||
| import * as net from 'net'; | ||||
| 
 | ||||
| class LightningStatsUpdater { | ||||
|   constructor() {} | ||||
|   hardCodedStartTime = '2018-01-12'; | ||||
| 
 | ||||
|   public async $startService() { | ||||
|     logger.info('Starting Lightning Stats service'); | ||||
| @ -28,17 +28,26 @@ class LightningStatsUpdater { | ||||
|       return; | ||||
|     } | ||||
| 
 | ||||
|     const now = new Date(); | ||||
|     const nextHourInterval = new Date(now.getFullYear(), now.getMonth(), now.getDate(), Math.floor(now.getHours() / 1) + 1, 0, 0, 0); | ||||
|     const difference = nextHourInterval.getTime() - now.getTime(); | ||||
|     await this.$populateHistoricalStatistics(); | ||||
|     await this.$populateHistoricalNodeStatistics(); | ||||
| 
 | ||||
|     setTimeout(() => { | ||||
|       setInterval(async () => { | ||||
|         await this.$runTasks(); | ||||
|       }, 1000 * 60 * 60); | ||||
|     }, difference); | ||||
|       this.$runTasks(); | ||||
|     }, this.timeUntilMidnight()); | ||||
|   } | ||||
| 
 | ||||
|     await this.$runTasks(); | ||||
|   private timeUntilMidnight(): number { | ||||
|     const date = new Date(); | ||||
|     this.setDateMidnight(date); | ||||
|     date.setUTCHours(24); | ||||
|     return date.getTime() - new Date().getTime(); | ||||
|   } | ||||
| 
 | ||||
|   private setDateMidnight(date: Date): void { | ||||
|     date.setUTCHours(0); | ||||
|     date.setUTCMinutes(0); | ||||
|     date.setUTCSeconds(0); | ||||
|     date.setUTCMilliseconds(0); | ||||
|   } | ||||
| 
 | ||||
|   private async $lightningIsSynced(): Promise<boolean> { | ||||
| @ -46,161 +55,17 @@ class LightningStatsUpdater { | ||||
|     return nodeInfo.is_synced_to_chain && nodeInfo.is_synced_to_graph; | ||||
|   } | ||||
| 
 | ||||
|   private async $runTasks() { | ||||
|     await this.$populateHistoricalData(); | ||||
|   private async $runTasks(): Promise<void> { | ||||
|     await this.$logLightningStatsDaily(); | ||||
|     await this.$logNodeStatsDaily(); | ||||
|   } | ||||
| 
 | ||||
|   private async $logNodeStatsDaily() { | ||||
|     const currentDate = new Date().toISOString().split('T')[0]; | ||||
|     try { | ||||
|       const [state]: any = await DB.query(`SELECT string FROM state WHERE name = 'last_node_stats'`); | ||||
|       // Only store once per day
 | ||||
|       if (state[0].string === currentDate) { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       logger.info(`Running daily node stats update...`); | ||||
| 
 | ||||
|       const query = `SELECT nodes.public_key, c1.channels_count_left, c2.channels_count_right, c1.channels_capacity_left, c2.channels_capacity_right FROM nodes LEFT JOIN (SELECT node1_public_key, COUNT(id) AS channels_count_left, SUM(capacity) AS channels_capacity_left FROM channels WHERE channels.status < 2 GROUP BY node1_public_key) c1 ON c1.node1_public_key = nodes.public_key LEFT JOIN (SELECT node2_public_key, COUNT(id) AS channels_count_right, SUM(capacity) AS channels_capacity_right FROM channels WHERE channels.status < 2 GROUP BY node2_public_key) c2 ON c2.node2_public_key = nodes.public_key`; | ||||
|       const [nodes]: any = await DB.query(query); | ||||
| 
 | ||||
|       // First run we won't have any nodes yet
 | ||||
|       if (nodes.length < 10) { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       for (const node of nodes) { | ||||
|         await DB.query( | ||||
|           `INSERT INTO node_stats(public_key, added, capacity, channels) VALUES (?, NOW(), ?, ?)`, | ||||
|           [node.public_key, (parseInt(node.channels_capacity_left || 0, 10)) + (parseInt(node.channels_capacity_right || 0, 10)), | ||||
|             node.channels_count_left + node.channels_count_right]); | ||||
|       } | ||||
|       await DB.query(`UPDATE state SET string = ? WHERE name = 'last_node_stats'`, [currentDate]); | ||||
|       logger.info('Daily node stats has updated.'); | ||||
|     } catch (e) { | ||||
|       logger.err('$logNodeStatsDaily() error: ' + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // We only run this on first launch
 | ||||
|   private async $populateHistoricalData() { | ||||
|     const startTime = '2018-01-13'; | ||||
|     try { | ||||
|       const [rows]: any = await DB.query(`SELECT COUNT(*) FROM lightning_stats`); | ||||
|       // Only store once per day
 | ||||
|       if (rows[0]['COUNT(*)'] > 0) { | ||||
|         return; | ||||
|       } | ||||
|       logger.info(`Running historical stats population...`); | ||||
| 
 | ||||
|       const [channels]: any = await DB.query(`SELECT capacity, created, closing_date FROM channels ORDER BY created ASC`); | ||||
| 
 | ||||
|       let date: Date = new Date(startTime); | ||||
|       const currentDate = new Date(); | ||||
| 
 | ||||
|       while (date < currentDate) { | ||||
|         let totalCapacity = 0; | ||||
|         let channelsCount = 0; | ||||
|         for (const channel of channels) { | ||||
|           if (new Date(channel.created) > date) { | ||||
|             break; | ||||
|           } | ||||
|           if (channel.closing_date !== null && new Date(channel.closing_date) < date) { | ||||
|             continue; | ||||
|           } | ||||
|           totalCapacity += channel.capacity; | ||||
|           channelsCount++; | ||||
|         } | ||||
| 
 | ||||
|         const query = `INSERT INTO lightning_stats(
 | ||||
|           added, | ||||
|           channel_count, | ||||
|           node_count, | ||||
|           total_capacity, | ||||
|           tor_nodes, | ||||
|           clearnet_nodes, | ||||
|           unannounced_nodes | ||||
|         ) | ||||
|         VALUES (FROM_UNIXTIME(?), ?, ?, ?, ?, ?, ?)`;
 | ||||
| 
 | ||||
|         await DB.query(query, [ | ||||
|           date.getTime() / 1000, | ||||
|           channelsCount, | ||||
|           0, | ||||
|           totalCapacity, | ||||
|           0, | ||||
|           0, | ||||
|           0 | ||||
|         ]); | ||||
| 
 | ||||
|         // Add one day and continue
 | ||||
|         date.setDate(date.getDate() + 1); | ||||
|       } | ||||
| 
 | ||||
|       const [nodes]: any = await DB.query(`SELECT first_seen, sockets FROM nodes ORDER BY first_seen ASC`); | ||||
|       date = new Date(startTime); | ||||
| 
 | ||||
|       while (date < currentDate) { | ||||
|         let nodeCount = 0; | ||||
|         let clearnetNodes = 0; | ||||
|         let torNodes = 0; | ||||
|         let unannouncedNodes = 0; | ||||
|         for (const node of nodes) { | ||||
|           if (new Date(node.first_seen) > date) { | ||||
|             break; | ||||
|           } | ||||
|           nodeCount++; | ||||
| 
 | ||||
|           const sockets = node.sockets.split(','); | ||||
|           let isUnnanounced = true; | ||||
|           for (const socket of sockets) { | ||||
|             const hasOnion = socket.indexOf('.onion') !== -1; | ||||
|             if (hasOnion) { | ||||
|               torNodes++; | ||||
|               isUnnanounced = false; | ||||
|             } | ||||
|             const hasClearnet = [4, 6].includes(net.isIP(socket.split(':')[0])); | ||||
|             if (hasClearnet) { | ||||
|               clearnetNodes++; | ||||
|               isUnnanounced = false; | ||||
|             } | ||||
|           } | ||||
|           if (isUnnanounced) { | ||||
|             unannouncedNodes++; | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         const query = `UPDATE lightning_stats SET node_count = ?, tor_nodes = ?, clearnet_nodes = ?, unannounced_nodes = ? WHERE added = FROM_UNIXTIME(?)`; | ||||
| 
 | ||||
|         await DB.query(query, [ | ||||
|           nodeCount, | ||||
|           torNodes, | ||||
|           clearnetNodes, | ||||
|           unannouncedNodes, | ||||
|           date.getTime() / 1000, | ||||
|         ]); | ||||
| 
 | ||||
|         // Add one day and continue
 | ||||
|         date.setDate(date.getDate() + 1); | ||||
|       } | ||||
| 
 | ||||
|       logger.info('Historical stats populated.'); | ||||
|     } catch (e) { | ||||
|       logger.err('$populateHistoricalData() error: ' + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|     setTimeout(() => { | ||||
|       this.$runTasks(); | ||||
|     }, this.timeUntilMidnight()); | ||||
|   } | ||||
| 
 | ||||
|   private async $logLightningStatsDaily() { | ||||
|     const currentDate = new Date().toISOString().split('T')[0]; | ||||
|     try { | ||||
|       const [state]: any = await DB.query(`SELECT string FROM state WHERE name = 'last_node_stats'`); | ||||
|       // Only store once per day
 | ||||
|       if (state[0].string === currentDate) { | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       logger.info(`Running lightning daily stats log...`);   | ||||
| 
 | ||||
|       const networkGraph = await lightningApi.$getNetworkGraph(); | ||||
| @ -250,7 +115,7 @@ class LightningStatsUpdater { | ||||
|           med_fee_rate, | ||||
|           med_base_fee_mtokens | ||||
|         ) | ||||
|         VALUES (NOW(), ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`;
 | ||||
|         VALUES (NOW() - INTERVAL 1 DAY, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`;
 | ||||
| 
 | ||||
|       await DB.query(query, [ | ||||
|         networkGraph.channels.length, | ||||
| @ -271,6 +136,184 @@ class LightningStatsUpdater { | ||||
|       logger.err('$logLightningStatsDaily() error: ' + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   private async $logNodeStatsDaily() { | ||||
|     try { | ||||
|       logger.info(`Running daily node stats update...`); | ||||
| 
 | ||||
|       const query = `SELECT nodes.public_key, c1.channels_count_left, c2.channels_count_right, c1.channels_capacity_left, c2.channels_capacity_right FROM nodes LEFT JOIN (SELECT node1_public_key, COUNT(id) AS channels_count_left, SUM(capacity) AS channels_capacity_left FROM channels WHERE channels.status < 2 GROUP BY node1_public_key) c1 ON c1.node1_public_key = nodes.public_key LEFT JOIN (SELECT node2_public_key, COUNT(id) AS channels_count_right, SUM(capacity) AS channels_capacity_right FROM channels WHERE channels.status < 2 GROUP BY node2_public_key) c2 ON c2.node2_public_key = nodes.public_key`; | ||||
|       const [nodes]: any = await DB.query(query); | ||||
| 
 | ||||
|       for (const node of nodes) { | ||||
|         await DB.query( | ||||
|           `INSERT INTO node_stats(public_key, added, capacity, channels) VALUES (?, NOW() - INTERVAL 1 DAY, ?, ?)`, | ||||
|           [node.public_key, (parseInt(node.channels_capacity_left || 0, 10)) + (parseInt(node.channels_capacity_right || 0, 10)), | ||||
|             node.channels_count_left + node.channels_count_right]); | ||||
|       } | ||||
|       logger.info('Daily node stats has updated.'); | ||||
|     } catch (e) { | ||||
|       logger.err('$logNodeStatsDaily() error: ' + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   // We only run this on first launch
 | ||||
|   private async $populateHistoricalStatistics() { | ||||
|     try { | ||||
|       const [rows]: any = await DB.query(`SELECT COUNT(*) FROM lightning_stats`); | ||||
|       // Only run if table is empty
 | ||||
|       if (rows[0]['COUNT(*)'] > 0) { | ||||
|         return; | ||||
|       } | ||||
|       logger.info(`Running historical stats population...`); | ||||
| 
 | ||||
|       const [channels]: any = await DB.query(`SELECT capacity, created, closing_date FROM channels ORDER BY created ASC`); | ||||
|       const [nodes]: any = await DB.query(`SELECT first_seen, sockets FROM nodes ORDER BY first_seen ASC`); | ||||
| 
 | ||||
|       const date: Date = new Date(this.hardCodedStartTime); | ||||
|       const currentDate = new Date(); | ||||
|       this.setDateMidnight(currentDate); | ||||
| 
 | ||||
|       while (date < currentDate) { | ||||
|         let totalCapacity = 0; | ||||
|         let channelsCount = 0; | ||||
| 
 | ||||
|         for (const channel of channels) { | ||||
|           if (new Date(channel.created) > date) { | ||||
|             break; | ||||
|           } | ||||
|           if (channel.closing_date === null || new Date(channel.closing_date) > date) { | ||||
|             totalCapacity += channel.capacity; | ||||
|             channelsCount++; | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         let nodeCount = 0; | ||||
|         let clearnetNodes = 0; | ||||
|         let torNodes = 0; | ||||
|         let unannouncedNodes = 0; | ||||
| 
 | ||||
|         for (const node of nodes) { | ||||
|           if (new Date(node.first_seen) > date) { | ||||
|             break; | ||||
|           } | ||||
|           nodeCount++; | ||||
| 
 | ||||
|           const sockets = node.sockets.split(','); | ||||
|           let isUnnanounced = true; | ||||
|           for (const socket of sockets) { | ||||
|             const hasOnion = socket.indexOf('.onion') !== -1; | ||||
|             if (hasOnion) { | ||||
|               torNodes++; | ||||
|               isUnnanounced = false; | ||||
|             } | ||||
|             const hasClearnet = [4, 6].includes(net.isIP(socket.split(':')[0])); | ||||
|             if (hasClearnet) { | ||||
|               clearnetNodes++; | ||||
|               isUnnanounced = false; | ||||
|             } | ||||
|           } | ||||
|           if (isUnnanounced) { | ||||
|             unannouncedNodes++; | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         const query = `INSERT INTO lightning_stats(
 | ||||
|           added, | ||||
|           channel_count, | ||||
|           node_count, | ||||
|           total_capacity, | ||||
|           tor_nodes, | ||||
|           clearnet_nodes, | ||||
|           unannounced_nodes | ||||
|         ) | ||||
|         VALUES (FROM_UNIXTIME(?), ?, ?, ?, ?, ?, ?)`;
 | ||||
| 
 | ||||
|         await DB.query(query, [ | ||||
|           date.getTime() / 1000, | ||||
|           channelsCount, | ||||
|           nodeCount, | ||||
|           totalCapacity, | ||||
|           torNodes, | ||||
|           clearnetNodes, | ||||
|           unannouncedNodes, | ||||
|         ]); | ||||
| 
 | ||||
|         date.setUTCDate(date.getUTCDate() + 1); | ||||
|       } | ||||
| 
 | ||||
|       logger.info('Historical stats populated.'); | ||||
|     } catch (e) { | ||||
|       logger.err('$populateHistoricalData() error: ' + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   private async $populateHistoricalNodeStatistics() { | ||||
|     try { | ||||
|       const [rows]: any = await DB.query(`SELECT COUNT(*) FROM node_stats`); | ||||
|       // Only run if table is empty
 | ||||
|       if (rows[0]['COUNT(*)'] > 0) { | ||||
|         return; | ||||
|       } | ||||
|       logger.info(`Running historical node stats population...`); | ||||
| 
 | ||||
|       const [nodes]: any = await DB.query(`SELECT public_key, first_seen, alias FROM nodes ORDER BY first_seen ASC`); | ||||
| 
 | ||||
|       for (const node of nodes) { | ||||
|         const [channels]: any = await DB.query(`SELECT capacity, created, closing_date FROM channels WHERE node1_public_key = ? OR node2_public_key = ? ORDER BY created ASC`, [node.public_key, node.public_key]); | ||||
|          | ||||
|         const date: Date = new Date(this.hardCodedStartTime); | ||||
|         const currentDate = new Date(); | ||||
|         this.setDateMidnight(currentDate); | ||||
| 
 | ||||
|         let lastTotalCapacity = 0; | ||||
|         let lastChannelsCount = 0; | ||||
| 
 | ||||
|         while (date < currentDate) { | ||||
|           let totalCapacity = 0; | ||||
|           let channelsCount = 0; | ||||
|           for (const channel of channels) { | ||||
|             if (new Date(channel.created) > date) { | ||||
|               break; | ||||
|             } | ||||
|             if (channel.closing_date !== null && new Date(channel.closing_date) < date) { | ||||
|               date.setUTCDate(date.getUTCDate() + 1); | ||||
|               continue; | ||||
|             } | ||||
|             totalCapacity += channel.capacity; | ||||
|             channelsCount++; | ||||
|           } | ||||
| 
 | ||||
|           if (lastTotalCapacity === totalCapacity && lastChannelsCount === channelsCount) { | ||||
|             date.setUTCDate(date.getUTCDate() + 1); | ||||
|             continue; | ||||
|           } | ||||
| 
 | ||||
|           lastTotalCapacity = totalCapacity; | ||||
|           lastChannelsCount = channelsCount; | ||||
|    | ||||
|           const query = `INSERT INTO node_stats(
 | ||||
|             public_key, | ||||
|             added, | ||||
|             capacity, | ||||
|             channels | ||||
|           ) | ||||
|           VALUES (?, FROM_UNIXTIME(?), ?, ?)`;
 | ||||
| 
 | ||||
|           await DB.query(query, [ | ||||
|             node.public_key, | ||||
|             date.getTime() / 1000, | ||||
|             totalCapacity, | ||||
|             channelsCount, | ||||
|           ]); | ||||
|           date.setUTCDate(date.getUTCDate() + 1); | ||||
|         } | ||||
|         logger.debug('Updated node_stats for: ' + node.alias); | ||||
|       } | ||||
|       logger.info('Historical stats populated.'); | ||||
|     } catch (e) { | ||||
|       logger.err('$populateHistoricalNodeData() error: ' + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| export default new LightningStatsUpdater(); | ||||
|  | ||||
| @ -334,6 +334,7 @@ DEBIAN_PKG+=(autotools-dev autoconf automake pkg-config bsdmainutils) | ||||
| DEBIAN_PKG+=(libevent-dev libdb-dev libssl-dev libtool autotools-dev) | ||||
| DEBIAN_PKG+=(libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-test-dev libboost-thread-dev) | ||||
| DEBIAN_PKG+=(nodejs npm mariadb-server nginx-core python3-certbot-nginx rsync ufw) | ||||
| DEBIAN_PKG+=(geoipupdate) | ||||
| 
 | ||||
| # packages needed for mempool ecosystem | ||||
| FREEBSD_PKG=() | ||||
| @ -341,6 +342,7 @@ FREEBSD_PKG+=(zsh sudo git screen curl wget calc neovim) | ||||
| FREEBSD_PKG+=(openssh-portable py39-pip rust llvm90 jq base64 libzmq4) | ||||
| FREEBSD_PKG+=(boost-libs autoconf automake gmake gcc libevent libtool pkgconf) | ||||
| FREEBSD_PKG+=(nginx rsync py39-certbot-nginx mariadb105-server keybase) | ||||
| FREEBSD_PKG+=(geoipupdate) | ||||
| 
 | ||||
| ############################# | ||||
| ##### utility functions ##### | ||||
|  | ||||
| @ -5,7 +5,7 @@ location /api/v1/lightning { | ||||
| location @mempool-api-v1-lightning { | ||||
| 	proxy_pass $mempoolMainnetLightning; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -48,7 +48,7 @@ location @mempool-api-v1-websocket { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 	proxy_http_version 1.1; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header Upgrade $http_upgrade; | ||||
| @ -59,7 +59,7 @@ location @mempool-api-v1-websocket { | ||||
| location @mempool-api-v1-cache-forever { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -76,7 +76,7 @@ location @mempool-api-v1-cache-forever { | ||||
| location @mempool-api-v1-cache-warm { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -91,7 +91,7 @@ location @mempool-api-v1-cache-warm { | ||||
| location @mempool-api-v1-cache-normal { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -106,7 +106,7 @@ location @mempool-api-v1-cache-normal { | ||||
| location @mempool-api-v1-cache-disabled { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -120,7 +120,7 @@ location @mempool-api-v1-cache-disabled { | ||||
| location @esplora-api-cache-disabled { | ||||
| 	proxy_pass $esploraMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -134,7 +134,7 @@ location @esplora-api-cache-disabled { | ||||
| location @esplora-api-cache-forever { | ||||
| 	proxy_pass $esploraMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -49,7 +49,7 @@ location @mempool-liquid-api-v1-websocket { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 	proxy_http_version 1.1; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header Upgrade $http_upgrade; | ||||
| @ -60,7 +60,7 @@ location @mempool-liquid-api-v1-websocket { | ||||
| location @mempool-liquid-api-v1-cache-forever { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -77,7 +77,7 @@ location @mempool-liquid-api-v1-cache-forever { | ||||
| location @mempool-liquid-api-v1-cache-warm { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -92,7 +92,7 @@ location @mempool-liquid-api-v1-cache-warm { | ||||
| location @mempool-liquid-api-v1-cache-normal { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -107,7 +107,7 @@ location @mempool-liquid-api-v1-cache-normal { | ||||
| location @mempool-liquid-api-v1-cache-disabled { | ||||
| 	proxy_pass $mempoolMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -121,7 +121,7 @@ location @mempool-liquid-api-v1-cache-disabled { | ||||
| location @esplora-liquid-api-cache-disabled { | ||||
| 	proxy_pass $esploraMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -135,7 +135,7 @@ location @esplora-liquid-api-cache-disabled { | ||||
| location @esplora-liquid-api-cache-forever { | ||||
| 	proxy_pass $esploraMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -53,7 +53,7 @@ location @mempool-liquidtestnet-api-v1-websocket { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 	proxy_http_version 1.1; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header Upgrade $http_upgrade; | ||||
| @ -64,7 +64,7 @@ location @mempool-liquidtestnet-api-v1-websocket { | ||||
| location @mempool-liquidtestnet-api-v1-cache-forever { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -81,7 +81,7 @@ location @mempool-liquidtestnet-api-v1-cache-forever { | ||||
| location @mempool-liquidtestnet-api-v1-cache-warm { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -96,7 +96,7 @@ location @mempool-liquidtestnet-api-v1-cache-warm { | ||||
| location @mempool-liquidtestnet-api-v1-cache-normal { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -111,7 +111,7 @@ location @mempool-liquidtestnet-api-v1-cache-normal { | ||||
| location @mempool-liquidtestnet-api-v1-cache-disabled { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -125,7 +125,7 @@ location @mempool-liquidtestnet-api-v1-cache-disabled { | ||||
| location @esplora-liquidtestnet-api-cache-disabled { | ||||
| 	proxy_pass $esploraTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -139,7 +139,7 @@ location @esplora-liquidtestnet-api-cache-disabled { | ||||
| location @esplora-liquidtestnet-api-cache-forever { | ||||
| 	proxy_pass $esploraTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -6,7 +6,7 @@ location /signet/api/v1/lightning { | ||||
| location @mempool-signet-api-v1-lightning { | ||||
| 	proxy_pass $mempoolSignetLightning; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -53,7 +53,7 @@ location @mempool-signet-api-v1-websocket { | ||||
| 	proxy_pass $mempoolSignet; | ||||
| 	proxy_http_version 1.1; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header Upgrade $http_upgrade; | ||||
| @ -64,7 +64,7 @@ location @mempool-signet-api-v1-websocket { | ||||
| location @mempool-signet-api-v1-cache-forever { | ||||
| 	proxy_pass $mempoolSignet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -81,7 +81,7 @@ location @mempool-signet-api-v1-cache-forever { | ||||
| location @mempool-signet-api-v1-cache-warm { | ||||
| 	proxy_pass $mempoolSignet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -96,7 +96,7 @@ location @mempool-signet-api-v1-cache-warm { | ||||
| location @mempool-signet-api-v1-cache-normal { | ||||
| 	proxy_pass $mempoolSignet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -111,7 +111,7 @@ location @mempool-signet-api-v1-cache-normal { | ||||
| location @mempool-signet-api-v1-cache-disabled { | ||||
| 	proxy_pass $mempoolSignet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -125,7 +125,7 @@ location @mempool-signet-api-v1-cache-disabled { | ||||
| location @esplora-signet-api-cache-disabled { | ||||
| 	proxy_pass $esploraSignet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -139,7 +139,7 @@ location @esplora-signet-api-cache-disabled { | ||||
| location @esplora-signet-api-cache-forever { | ||||
| 	proxy_pass $esploraSignet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -6,7 +6,7 @@ location /testnet/api/v1/lightning { | ||||
| location @mempool-testnet-api-v1-lightning { | ||||
| 	proxy_pass $mempoolSignetLightning; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -53,7 +53,7 @@ location @mempool-testnet-api-v1-websocket { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 	proxy_http_version 1.1; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header Upgrade $http_upgrade; | ||||
| @ -64,7 +64,7 @@ location @mempool-testnet-api-v1-websocket { | ||||
| location @mempool-testnet-api-v1-cache-forever { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -81,7 +81,7 @@ location @mempool-testnet-api-v1-cache-forever { | ||||
| location @mempool-testnet-api-v1-cache-warm { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -96,7 +96,7 @@ location @mempool-testnet-api-v1-cache-warm { | ||||
| location @mempool-testnet-api-v1-cache-normal { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -111,7 +111,7 @@ location @mempool-testnet-api-v1-cache-normal { | ||||
| location @mempool-testnet-api-v1-cache-disabled { | ||||
| 	proxy_pass $mempoolTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -125,7 +125,7 @@ location @mempool-testnet-api-v1-cache-disabled { | ||||
| location @esplora-testnet-api-cache-disabled { | ||||
| 	proxy_pass $esploraTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -139,7 +139,7 @@ location @esplora-testnet-api-cache-disabled { | ||||
| location @esplora-testnet-api-cache-forever { | ||||
| 	proxy_pass $esploraTestnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -78,7 +78,7 @@ location @mempool-bisq-websocket { | ||||
| location @mempool-bisq { | ||||
| 	proxy_pass $mempoolBisq; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
| @ -89,7 +89,7 @@ location @mempool-bisq { | ||||
| location @esplora-api-cache-disabled { | ||||
| 	proxy_pass $esploraMainnet; | ||||
| 
 | ||||
| 	proxy_set_header Host $http_host; | ||||
| 	proxy_set_header Host $host; | ||||
| 	proxy_set_header X-Real-IP $remote_addr; | ||||
| 	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; | ||||
| 	proxy_set_header X-Forwarded-Proto $scheme; | ||||
|  | ||||
| @ -49,7 +49,7 @@ add_header Vary Cookie; | ||||
| # cache redirect for 10 minutes | ||||
| location = / { | ||||
| 	if ($lang != '') { | ||||
| 		return 302 $scheme://$host/$lang$uri; | ||||
| 		return 302 $scheme://$host/$lang/; | ||||
| 	} | ||||
| 	try_files /en-US/index.html =404; | ||||
| 	expires 10m; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user