Merge branch 'master' into simon/lightning-indexing-status
This commit is contained in:
		
						commit
						80a7b6d8d5
					
				| @ -4,21 +4,29 @@ import * as fs from 'fs'; | ||||
| import { AbstractLightningApi } from '../lightning-api-abstract-factory'; | ||||
| import { ILightningApi } from '../lightning-api.interface'; | ||||
| import config from '../../../config'; | ||||
| import logger from '../../../logger'; | ||||
| 
 | ||||
| class LndApi implements AbstractLightningApi { | ||||
|   axiosConfig: AxiosRequestConfig = {}; | ||||
| 
 | ||||
|   constructor() { | ||||
|     if (config.LIGHTNING.ENABLED) { | ||||
|     if (!config.LIGHTNING.ENABLED) { | ||||
|       return; | ||||
|     } | ||||
|     try { | ||||
|       this.axiosConfig = { | ||||
|         headers: { | ||||
|           'Grpc-Metadata-macaroon': fs.readFileSync(config.LND.MACAROON_PATH).toString('hex') | ||||
|           'Grpc-Metadata-macaroon': fs.readFileSync(config.LND.MACAROON_PATH).toString('hex'), | ||||
|         }, | ||||
|         httpsAgent: new Agent({ | ||||
|           ca: fs.readFileSync(config.LND.TLS_CERT_PATH) | ||||
|         }), | ||||
|         timeout: config.LND.TIMEOUT | ||||
|       }; | ||||
|     } catch (e) { | ||||
|       config.LIGHTNING.ENABLED = false; | ||||
|       logger.updateNetwork(); | ||||
|       logger.err(`Could not initialize LND Macaroon/TLS Cert. Disabling LIGHTNING. ` + (e instanceof Error ? e.message : e)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  | ||||
| @ -69,6 +69,10 @@ class Logger { | ||||
|     this.network = this.getNetwork(); | ||||
|   } | ||||
| 
 | ||||
|   public updateNetwork(): void { | ||||
|     this.network = this.getNetwork(); | ||||
|   } | ||||
| 
 | ||||
|   private addprio(prio): void { | ||||
|     this[prio] = (function(_this) { | ||||
|       return function(msg, tag?: string) { | ||||
|  | ||||
| @ -10,6 +10,8 @@ cp /etc/nginx/nginx.conf /patch/nginx.conf | ||||
| sed -i "s/__MEMPOOL_FRONTEND_HTTP_PORT__/${__MEMPOOL_FRONTEND_HTTP_PORT__}/g" /patch/nginx.conf | ||||
| cat /patch/nginx.conf > /etc/nginx/nginx.conf | ||||
| 
 | ||||
| [ "${APP_LIGHTNING_NODE_PORT}" = "9735" ] && LIGHTNING=true | ||||
| 
 | ||||
| # Runtime overrides - read env vars defined in docker compose | ||||
| 
 | ||||
| __TESTNET_ENABLED__=${TESTNET_ENABLED:=false} | ||||
|  | ||||
| @ -32,7 +32,7 @@ | ||||
|   </div> | ||||
| 
 | ||||
|   <div class="card-header" *ngIf="!widget"> | ||||
|     <div class="d-flex d-md-block align-items-baseline"> | ||||
|     <div class="d-flex d-md-table-cell align-items-baseline"> | ||||
|       <span i18n="mining.pools">Pools Ranking</span> | ||||
|       <button class="btn p-0 pl-2" style="margin: 0 0 4px 0px" (click)="onSaveChart()"> | ||||
|         <fa-icon [icon]="['fas', 'download']" [fixedWidth]="true"></fa-icon> | ||||
| @ -87,19 +87,19 @@ | ||||
|     <table *ngIf="widget === false" class="table table-borderless text-center pools-table"> | ||||
|       <thead> | ||||
|         <tr> | ||||
|           <th class="d-none d-md-block" i18n="mining.rank">Rank</th> | ||||
|           <th class="d-none d-md-table-cell" i18n="mining.rank">Rank</th> | ||||
|           <th class=""></th> | ||||
|           <th class="" i18n="mining.pool-name">Pool</th> | ||||
|           <th class="" *ngIf="this.miningWindowPreference === '24h'" i18n="mining.hashrate">Hashrate</th> | ||||
|           <th class="" i18n="master-page.blocks">Blocks</th> | ||||
|           <th *ngIf="auditAvailable" class="health text-right widget" i18n="latest-blocks.avg_health" | ||||
|             i18n-ngbTooltip="latest-blocks.avg_health" ngbTooltip="Avg Health" placement="bottom" #health [disableTooltip]="!isEllipsisActive(health)">Avg Health</th> | ||||
|           <th class="d-none d-md-block" i18n="mining.empty-blocks">Empty blocks</th> | ||||
|           <th class="d-none d-md-table-cell" i18n="mining.empty-blocks">Empty blocks</th> | ||||
|         </tr> | ||||
|       </thead> | ||||
|       <tbody [attr.data-cy]="'pools-table'" *ngIf="(miningStatsObservable$ | async) as miningStats"> | ||||
|         <tr *ngFor="let pool of miningStats.pools"> | ||||
|           <td class="d-none d-md-block">{{ pool.rank }}</td> | ||||
|           <td class="d-none d-md-table-cell">{{ pool.rank }}</td> | ||||
|           <td class="text-right"> | ||||
|             <img width="25" height="25" src="{{ pool.logo }}" [alt]="pool.name + ' mining pool logo'" onError="this.src = '/resources/mining-pools/default.svg'"> | ||||
|           </td> | ||||
| @ -107,7 +107,7 @@ | ||||
|           <td class="" *ngIf="this.miningWindowPreference === '24h'">{{ pool.lastEstimatedHashrate }} {{ | ||||
|             miningStats.miningUnits.hashrateUnit }}</td> | ||||
|           <td class="d-flex justify-content-center"> | ||||
|             {{ pool.blockCount }}<span class="d-none d-md-block"> ({{ pool.share }}%)</span> | ||||
|             {{ pool.blockCount }}<span class="d-none d-md-table-cell"> ({{ pool.share }}%)</span> | ||||
|           </td> | ||||
|           <td *ngIf="auditAvailable" class="health text-right" [ngClass]="{'widget': widget, 'legacy': !indexingAvailable}"> | ||||
|             <a | ||||
| @ -121,16 +121,16 @@ | ||||
|               <span class="health-badge badge badge-secondary" i18n="unknown">Unknown</span> | ||||
|             </ng-template> | ||||
|           </td> | ||||
|           <td class="d-none d-md-block">{{ pool.emptyBlocks }} ({{ pool.emptyBlockRatio }}%)</td> | ||||
|           <td class="d-none d-md-table-cell">{{ pool.emptyBlocks }} ({{ pool.emptyBlockRatio }}%)</td> | ||||
|         </tr> | ||||
|         <tr style="border-top: 1px solid #555"> | ||||
|           <td class="d-none d-md-block"></td> | ||||
|           <td class="d-none d-md-table-cell"></td> | ||||
|           <td class="text-right"></td> | ||||
|           <td class=""><b i18n="mining.all-miners">All miners</b></td> | ||||
|           <td class="" *ngIf="this.miningWindowPreference === '24h'"><b>{{ miningStats.lastEstimatedHashrate}} {{ | ||||
|               miningStats.miningUnits.hashrateUnit }}</b></td> | ||||
|           <td class=""><b>{{ miningStats.blockCount }}</b></td> | ||||
|           <td class="d-none d-md-block"><b>{{ miningStats.totalEmptyBlock }} ({{ miningStats.totalEmptyBlockRatio | ||||
|           <td class="d-none d-md-table-cell"><b>{{ miningStats.totalEmptyBlock }} ({{ miningStats.totalEmptyBlockRatio | ||||
|               }}%)</b></td> | ||||
|         </tr> | ||||
|       </tbody> | ||||
|  | ||||
| @ -94,13 +94,13 @@ | ||||
|                       <tr> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.reward">Reward</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.hashrate">Hashrate (24h)</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="latest-blocks.avg_health">Avg Health</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="latest-blocks.avg_health" *ngIf="auditAvailable">Avg Health</th> | ||||
|                       </tr> | ||||
|                     </thead> | ||||
|                     <tbody> | ||||
|                       <td class="text-center"><app-amount [satoshis]="poolStats.totalReward" digitsInfo="1.0-0" [noFiat]="true"></app-amount></td> | ||||
|                       <td class="text-center">{{ poolStats.estimatedHashrate | amountShortener : 1 : 'H/s' }}</td> | ||||
|                       <td class="text-center"><span class="health-badge badge" [class.badge-success]="poolStats.avgBlockHealth >= 99" | ||||
|                       <td class="text-center" *ngIf="auditAvailable; else emptyTd"><span class="health-badge badge" [class.badge-success]="poolStats.avgBlockHealth >= 99" | ||||
|                           [class.badge-warning]="poolStats.avgBlockHealth >= 75 && poolStats.avgBlockHealth < 99" [class.badge-danger]="poolStats.avgBlockHealth < 75" | ||||
|                           *ngIf="poolStats.avgBlockHealth != null; else nullHealth">{{ poolStats.avgBlockHealth }}%</span> | ||||
|                           <ng-template #nullHealth> | ||||
| @ -119,13 +119,13 @@ | ||||
|                       <tr> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.reward">Reward</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.hashrate">Hashrate (24h)</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="latest-blocks.avg_health">Avg Health</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="latest-blocks.avg_health" *ngIf="auditAvailable">Avg Health</th> | ||||
|                       </tr> | ||||
|                     </thead> | ||||
|                     <tbody> | ||||
|                       <td class="text-center"><app-amount [satoshis]="poolStats.totalReward" digitsInfo="1.0-0" [noFiat]="true"></app-amount></td> | ||||
|                       <td class="text-center">{{ poolStats.estimatedHashrate | amountShortener : 1 : 'H/s' }}</td> | ||||
|                       <td class="text-center"><span class="health-badge badge" [class.badge-success]="poolStats.avgBlockHealth >= 99" | ||||
|                       <td *ngIf="auditAvailable; else emptyTd" class="text-center"><span class="health-badge badge" [class.badge-success]="poolStats.avgBlockHealth >= 99" | ||||
|                           [class.badge-warning]="poolStats.avgBlockHealth >= 75 && poolStats.avgBlockHealth < 99" [class.badge-danger]="poolStats.avgBlockHealth < 75" | ||||
|                           *ngIf="poolStats.avgBlockHealth != null; else nullHealth">{{ poolStats.avgBlockHealth }}%</span> | ||||
|                           <ng-template #nullHealth> | ||||
| @ -384,7 +384,7 @@ | ||||
|                       <tr> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.total-reward">Reward</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.estimated">Hashrate (24h)</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.luck">Avg Health</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.luck" *ngIf="auditAvailable">Avg Health</th> | ||||
|                       </tr> | ||||
|                     </thead> | ||||
|                     <tbody> | ||||
| @ -394,7 +394,7 @@ | ||||
|                       <td class="text-center"> | ||||
|                         <div class="skeleton-loader data"></div> | ||||
|                       </td> | ||||
|                       <td class="text-center"> | ||||
|                       <td class="text-center" *ngIf="auditAvailable"> | ||||
|                         <div class="skeleton-loader data"></div> | ||||
|                       </td> | ||||
|                     </tbody> | ||||
| @ -409,7 +409,7 @@ | ||||
|                       <tr> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.total-reward">Reward</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.estimated">Hashrate (24h)</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.luck">Avg Health</th> | ||||
|                         <th scope="col" class="block-count-title text-center" style="width: 33%" i18n="mining.luck" *ngIf="auditAvailable">Avg Health</th> | ||||
|                       </tr> | ||||
|                     </thead> | ||||
|                     <tbody> | ||||
| @ -419,7 +419,7 @@ | ||||
|                       <td class="text-center"> | ||||
|                         <div class="skeleton-loader data"></div> | ||||
|                       </td> | ||||
|                       <td class="text-center"> | ||||
|                       <td class="text-center" *ngIf="auditAvailable"> | ||||
|                         <div class="skeleton-loader data"></div> | ||||
|                       </td> | ||||
|                     </tbody> | ||||
| @ -485,4 +485,8 @@ | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| </ng-template> | ||||
| 
 | ||||
| <ng-template #emptyTd> | ||||
|   <td class="text-center"></td> | ||||
| </ng-template> | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user