better identification of lightning outputs. (#320)
* better identification of lightning outputs. * identify liquid pegouts and emergency pegouts. fixes #324
This commit is contained in:
		
							parent
							
								
									448cb8e264
								
							
						
					
					
						commit
						276117fba9
					
				@ -1,2 +1,18 @@
 | 
			
		||||
<span *ngIf="multisig" class="badge badge-pill badge-warning" i18n="address-labels.multisig">multisig {{ multisigM }} of {{ multisigN }}</span>
 | 
			
		||||
<span *ngIf="secondLayerClose" class="badge badge-pill badge-warning" i18n="address-labels.upper-layer-peg-out">Layer{{ network === 'liquid' ? '3' : '2' }} Peg-out</span>
 | 
			
		||||
<span
 | 
			
		||||
  *ngIf="multisig"
 | 
			
		||||
  class="badge badge-pill badge-warning"
 | 
			
		||||
  i18n="address-labels.multisig"
 | 
			
		||||
  >multisig {{ multisigM }} of {{ multisigN }}</span
 | 
			
		||||
>
 | 
			
		||||
<span
 | 
			
		||||
  *ngIf="lightning"
 | 
			
		||||
  class="badge badge-pill badge-warning"
 | 
			
		||||
  i18n="address-labels.upper-layer-peg-out"
 | 
			
		||||
  >Lightning {{ lightning }}</span
 | 
			
		||||
>
 | 
			
		||||
<span
 | 
			
		||||
  *ngIf="liquid"
 | 
			
		||||
  class="badge badge-pill badge-warning"
 | 
			
		||||
  i18n="address-labels.upper-layer-peg-out"
 | 
			
		||||
  >Liquid {{ liquid }}</span
 | 
			
		||||
>
 | 
			
		||||
 | 
			
		||||
@ -18,7 +18,8 @@ export class AddressLabelsComponent implements OnInit {
 | 
			
		||||
  multisigM: number;
 | 
			
		||||
  multisigN: number;
 | 
			
		||||
 | 
			
		||||
  secondLayerClose = false;
 | 
			
		||||
  lightning = null;
 | 
			
		||||
  liquid = null;
 | 
			
		||||
 | 
			
		||||
  constructor(
 | 
			
		||||
    stateService: StateService,
 | 
			
		||||
@ -36,6 +37,26 @@ export class AddressLabelsComponent implements OnInit {
 | 
			
		||||
 | 
			
		||||
  handleVin() {
 | 
			
		||||
    if (this.vin.inner_witnessscript_asm) {
 | 
			
		||||
      if (this.vin.inner_witnessscript_asm.indexOf('OP_DEPTH OP_PUSHNUM_12 OP_EQUAL OP_IF OP_PUSHNUM_11') === 0) {
 | 
			
		||||
        if (this.vin.witness.length > 11) {
 | 
			
		||||
          this.liquid = 'Peg Out';
 | 
			
		||||
        } else {
 | 
			
		||||
          this.liquid = 'Emergency Peg Out';
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      [
 | 
			
		||||
        [/^OP_DUP OP_HASH160/, 'HTLC'],
 | 
			
		||||
        [/^OP_IF OP_PUSHBYTES_33 \w{33} OP_ELSE OP_PUSHBYTES_2 \w{2} OP_CSV OP_DROP/, 'Force Close']
 | 
			
		||||
      ].forEach(
 | 
			
		||||
        ([re, label]) => {
 | 
			
		||||
          if (re.test(this.vin.inner_witnessscript_asm)) {
 | 
			
		||||
            this.lightning = label;
 | 
			
		||||
            return;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      );
 | 
			
		||||
 | 
			
		||||
      if (this.vin.inner_witnessscript_asm.indexOf('OP_CHECKMULTISIG') > -1) {
 | 
			
		||||
        const matches = this.getMatches(this.vin.inner_witnessscript_asm, /OP_PUSHNUM_([0-9])/g, 1);
 | 
			
		||||
        this.multisig = true;
 | 
			
		||||
@ -46,10 +67,6 @@ export class AddressLabelsComponent implements OnInit {
 | 
			
		||||
          this.multisig = false;
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      if (/OP_IF (.+) OP_ELSE (.+) OP_CSV OP_DROP/.test(this.vin.inner_witnessscript_asm)) {
 | 
			
		||||
        this.secondLayerClose = true;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    if (this.vin.inner_redeemscript_asm && this.vin.inner_redeemscript_asm.indexOf('OP_CHECKMULTISIG') > -1) {
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user