github.com/deroproject/derosuite@v2.1.6-1.0.20200307070847-0f2e589c7a2b+incompatible/cmd/explorer/templates.go (about)

     1  // Copyright 2017-2018 DERO Project. All rights reserved.
     2  // Use of this source code in any form is governed by RESEARCH license.
     3  // license can be found in the LICENSE file.
     4  // GPG: 0F39 E425 8C65 3947 702A  8234 08B2 0360 A03A 9DE8
     5  //
     6  //
     7  // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
     8  // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
     9  // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
    10  // THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
    11  // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
    12  // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
    13  // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
    14  // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
    15  // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
    16  
    17  package main
    18  
    19  // this files defines all the templates
    20  
    21  var header_template string = `
    22  {{define "header"}}
    23  <!DOCTYPE html>
    24  <html lang="en">
    25  <head>
    26      <meta charset="UTF-8">
    27      <META HTTP-EQUIV="CACHE-CONTROL" CONTENT="NO-CACHE">
    28      <title>{{ .title }}</title>
    29      <!--<link rel="stylesheet" type="text/css" href="/css/style.css">-->
    30      <style type="text/css">
    31  body {
    32      margin: 0;
    33      padding: 0;
    34      color: green;
    35      background-color: white;
    36  }
    37  
    38  h1, h2, h3, h4, h5, h6 {
    39      text-align: center;
    40  }
    41  
    42  .center {
    43      margin: auto;
    44      width: 96%;
    45      /*border: 1px solid #73AD21;
    46      padding: 10px;*/
    47  }
    48  
    49  tr, li, #pages, .info {
    50      font-family: "Lucida Console", Monaco, monospace;
    51      font-size  : 12px;
    52      height: 22px;
    53  }
    54  
    55  #pages
    56  {
    57      margin-top: 15px;
    58  }
    59  
    60  td {
    61      text-align: center;
    62  }
    63  
    64  a:link {
    65      text-decoration: none;
    66      color: blue;
    67  }
    68  
    69  a:visited {
    70      text-decoration: none;
    71      color: blue;
    72  }
    73  
    74  a:hover {
    75      text-decoration: underline;
    76      color: blue;
    77  }
    78  
    79  a:active {
    80      text-decoration: none;
    81      color: blue;
    82  }
    83  
    84  form {
    85      display: inline-block;
    86      text-align: center;
    87  }
    88  
    89  .style-1 input[type="text"] {
    90      padding: 2px;
    91      border: solid 1px #dcdcdc;
    92      transition: box-shadow 0.3s, border 0.3s;
    93  }
    94  .style-1 input[type="text"]:focus,
    95  .style-1 input[type="text"].focus {
    96      border: solid 1px #707070;
    97      box-shadow: 0 0 5px 1px #969696;
    98  }
    99  
   100  
   101  .tabs {
   102      position: relative;
   103      min-height: 220px; /* This part sucks */
   104      clear: both;
   105      margin: 25px 0;
   106  }
   107  
   108  .tab {
   109      float: left;
   110  }
   111  
   112  .tab label {
   113      background: white;
   114      padding: 10px;
   115      border: 1px solid #ccc;
   116      margin-left: -1px;
   117      position: relative;
   118      left: 1px;
   119  }
   120  
   121  .tab [type=radio] {
   122      display: none;
   123  }
   124  
   125  .content {
   126      position: absolute;
   127      top: 28px;
   128      left: 0;
   129      background: white;
   130      right: 0;
   131      bottom: 0;
   132      padding: 20px;
   133      border: 1px solid #ccc;
   134  }
   135  
   136  [type=radio]:checked ~ label {
   137      background: #505050 ;
   138      border-bottom: 1px solid green;
   139      z-index: 2;
   140  }
   141  
   142  [type=radio]:checked ~ label ~ .content {
   143      z-index: 1;
   144  }
   145  
   146  input#toggle-1[type=checkbox] {
   147      position: absolute;
   148      /*top: -9999px;*/
   149      left: -9999px;
   150  
   151  }
   152  label#show-decoded-inputs {
   153      /*-webkit-appearance: push-button;*/
   154      /*-moz-appearance: button;*/
   155      display: inline-block;
   156      /*margin: 60px 0 10px 0;*/
   157      cursor: pointer;
   158      background-color: white;;
   159      color: green;
   160      width: 100%;
   161      text-align: center;
   162  }
   163  
   164  div#decoded-inputs{
   165      display: none;
   166  }
   167  
   168  /* Toggled State */
   169  input#toggle-1[type=checkbox]:checked ~ div#decoded-inputs {
   170      display: block;
   171  }
   172      </style>
   173  
   174  </head>
   175  <body>
   176  <div>
   177  
   178      <div class="center">
   179          <h1 class="center"> 
   180          <img alt="logo" style="vertical-align:middle" height="64" width="64" src="" />
   181  
   182          
   183          <a href="/">{{ .title }} {{if .testnet}} TestNet  {{end}}</a></h1>
   184  <!--        <h4 style="font-size: 15px; margin: 0px">(no javascript - no cookies - no web analytics trackers - no images - open sourced)</h4> -->
   185      </div>
   186  
   187  
   188      <div class="center">
   189          <form action="/search" method="get" style="width:100%; margin-top:15px" class="style-1">
   190              <input type="text" name="value" size="120"
   191                     placeholder="block height, block hash, transaction hash">
   192              <input type="submit" value="Search">
   193          </form>
   194      </div>
   195  
   196  </div>
   197  
   198  {{if .Network_Difficulty}}
   199  <div class="center">
   200       <h3 style="font-size: 12px; margin-top: 20px">
   201          Server time: {{ .servertime }}  | <a href="/txpool">Transaction pool</a>
   202          </h3>
   203  
   204  
   205          <h3 style="font-size: 12px; margin-top: 5px; margin-bottom: 3">
   206              Network difficulty: {{ .Network_Difficulty }}
   207              | Hash rate: {{ .hash_rate }} KH&#x2F;s
   208              | Average Block Time(50)  {{.averageblocktime50}} sec
   209              | Total supply : {{ .total_supply }}
   210              | Mempool size : {{ .txpool_size }}
   211              | Fee per kb: {{.fee_per_kb}}
   212              | Median block size limit: {{.median_block_size}} kB
   213  
   214          </h3>
   215  
   216  </div>
   217  {{end}}
   218  {{end}}
   219  `
   220  
   221  var block_template string = `{{define "block"}}
   222  {{ template "header" . }}
   223  <div>
   224  
   225      <H4>Block Topo height (unique): {{.block.TopoHeight}}  Block height: ({{.block.Height}})</H4>
   226      <H4>Block hash: {{.block.Hash}}</H4>
   227  
   228  {{range $i, $a := .block.Tips}}
   229    <H5>Previous blocks: <a href="/block/{{$a}}">{{$a}}</a></H5>
   230  {{end}}
   231  
   232  <!--    
   233      <H5>Next block: <a href="/block/a8ade20d5cad5e23105cfc25687beb2498844a984b1450330c67705b6c720596">a8ade20d5cad5e23105cfc25687beb2498844a984b1450330c67705b6c720596</a></H5>
   234      -->
   235      <table class="center">
   236          <tr>
   237              <td>Timestamp [UCT] (epoch):</td><td>{{.block.Block_time}} ({{.block.Epoch}})</td>
   238              <td>Age [h:m:s]:</td><td>{{.block.Age}}</td>
   239              <td>Δ [h:m:s]:</td><td></td>
   240          </tr>
   241          <tr>
   242              <td>Major.minor version:</td><td>{{.block.Major_Version}}.{{.block.Minor_Version}}</td>
   243              <td>Block reward:</td><td>{{.block.Reward}}</td>
   244              <td>Block size [kB]:</td><td>{{.block.Size}}</td>
   245          </tr>
   246          <tr>
   247              <td>nonce:</td><td>{{.block.Nonce}}</td>
   248              <td>Total fees:</td><td>{{.block.Fees}}</td>
   249              <td>No of txs:</td><td>{{.block.Tx_Count}}</td>
   250          </tr>
   251      </table>
   252  
   253      <h3>Miner reward transaction</h3>
   254      <table class="center">
   255          <tr>
   256              <td>hash</td>
   257              <td>outputs</td>
   258              <td>size [kB]</td>
   259              <td>version</td>
   260          </tr>
   261              <tr>
   262                  <td><a href="/tx/{{.block.Mtx.Hash}}">{{.block.Mtx.Hash}}</a>
   263                  <td>{{.block.Mtx.Amount}}</td>
   264                  <td>{{.block.Mtx.Size}}</td>
   265                  <td>{{.block.Mtx.Version}}</td>
   266              </tr>
   267  
   268      </table>
   269  
   270      <h3>Transactions ({{.block.Tx_Count}})</h3>
   271          <table class="center" style="width:80%">
   272              <tr>
   273                  <td>hash</td>
   274                  <td>outputs</td>
   275                  <td>fee</td>
   276                  <td>ring size</td>
   277                  <td>in/out</td>
   278                  
   279                  <td>version</td>
   280                  <td>size [kB]</td>
   281              </tr>
   282              {{range .block.Txs}}
   283                  <tr>
   284                     
   285                      {{if .Skipped }}<td><a href="/tx/{{.Hash}}"><font color="indianred">{{.Hash}}</font>  </a></td>
   286                      {{else}}
   287                      <td><a href="/tx/{{.Hash}}">{{.Hash}}</a></td>
   288                      {{end}}
   289  
   290                      <td>?</td>
   291                      <td>{{.Fee}}</td>
   292                      <td>{{.Ring_size}}</td>
   293                      <td>{{.In}}/{{.Out}}</td>                    
   294                      <td>{{.Version}}</td>
   295                      <td>{{.Size}}</td>
   296                  </tr>
   297                  {{end}}
   298          </table>
   299  
   300  </div>
   301  
   302  {{ template "footer" . }} 
   303  {{end}}
   304  `
   305  
   306  var tx_template string = `{{define "tx"}}
   307  {{ template "header" . }}
   308              <div>
   309                  <H4 style="margin:5px">Tx hash: {{.info.Hash}}</H4>
   310                  <H5 style="margin:5px">Tx prefix hash: {{.info.PrefixHash}}</H5>
   311  
   312                  <H5>Block: <a href="/block/{{.info.ValidBlock}}">{{.info.ValidBlock}}</a> (VALID) </H5>
   313  
   314                  {{range $i, $e := .info.InvalidBlock}} 
   315                   <H5>Block: <a href="/block/{{$e}}">{{$e}}</a></H5>
   316                  {{end}}
   317  
   318  
   319                  <H5 style="margin:5px">Tx public key: {{.info.TXpublickey}}</H5>
   320  
   321                  {{if .info.PayID32}} 
   322                   <H5 style="margin:5px">PaymentID: {{.info.PayID32}}</H5>
   323                  {{end}}
   324                  {{if .info.PayID8}} 
   325                   <H5 style="margin:5px">Encrypted PaymentID: {{.info.PayID8}}</H5>
   326                  {{end}}
   327    
   328                  <table class="center" style="width: 80%; margin-top:10px">
   329                      <tr>
   330                          <td>Timestamp: {{.info.Timestamp}} </td>
   331                          <td>Timestamp [UTC]: {{.info.Block_time}}</td>
   332                          <td>Age [y:d:h:m:s]: {{.info.Age}} </td>
   333                      </tr>
   334                      <tr>
   335                          <td>Block: <a href="/block/{{.info.Height}}">{{.info.Height}}</a></td>
   336                          <td>Fee: {{.info.Fee}}</td>
   337                          <td>Tx size: {{.info.Size}} kB</td>
   338                      </tr>
   339                      <tr>
   340                          <td>Tx version: {{.info.Version}}</td>
   341                          <td>No of confirmations: {{.info.Depth}}</td>
   342                          <td>Signature type:  {{.info.Type}}</td>
   343                      </tr>
   344                      <tr>
   345                          <td colspan="3">Extra: {{.info.Extra}}</td>
   346                      </tr>
   347                  </table>
   348                <h3>{{.info.Out}} output(s) for total of {{.info.Amount}} dero</h3>
   349                <div class="center">
   350                    <table class="center">
   351                        <tr>
   352                            <td>stealth address</td>
   353                            <td>amount</td>
   354                            <td>amount idx</td>
   355                        </tr>
   356                        
   357                        {{range $i, $e := .info.OutAddress}} 
   358                        <tr>
   359                            <td>{{ $e }}</td>
   360                            <td>{{$.info.Amount}}</td>
   361                            <td>{{index $.info.OutOffset $i}}</td>
   362                        </tr>
   363                        {{end}}
   364                    </table>
   365                </div>
   366                
   367  <!-- TODO currently we donot enable user to prove or decode something -->
   368  <br/>
   369  <br/>
   370  <div class="center" style="border: 1px">
   371                    <table class="center" border="1">
   372                        <tr>
   373                            <td> <h3>Prove to someone that you have sent them DERO in this transaction</h3>
   374                            </td>
   375                        </tr>
   376                        <tr>
   377                        <td>
   378                        Tx private key can be obtained using <i>get_tx_key</i>
   379                                      command in  <i>dero-wallet-cli</i>
   380                                      <br>
   381                                          Note: address and tx private key are sent to the server, as the calculations are done on the server side
   382                                  
   383                        </td>
   384                        </tr>
   385                        <tr>
   386                        <td>
   387  
   388  
   389  
   390                                  <form  method="post" style="width:100%;margin-top:2px" class="style-1">
   391                                     <input name="txprvkey" size="120" placeholder="Tx private key" type="text"><br>
   392                                      <input name="raw_tx_data" value="" type="hidden">
   393                                      <!--above raw_tx_data field only used when checking raw tx data through tx pusher-->
   394                                     <input name="deroaddress" size="120" placeholder="Recipient's dero address" style="margin-top:5px" type="text"><br>
   395              
   396                                         <input value="Prove sending" style="margin-top:5px" type="submit">
   397              
   398                                  </form>
   399                          </td>
   400                          </tr>
   401  
   402                          {{if .info.Proof_amount }}
   403                          <tr>
   404                          <td><h2><font color="blue">{{.info.Proof_address}} Received {{.info.Proof_amount}} DERO
   405  
   406                          {{if .info.Proof_PayID8}}
   407                             <br/> Decrypted Payment ID {{ .info.Proof_PayID8}}
   408                          {{end}}
   409                       </font>  </h2> 
   410     </td>
   411                          </tr>
   412                          {{end}} 
   413  
   414                          {{if .info.Proof_error }}
   415                          <tr>
   416                          <td>   <font color="red">{{.info.Proof_error}}</font>
   417     </td>
   418                          </tr>
   419                          {{end}}
   420  
   421  
   422                          </table>
   423  
   424                       </div>
   425  
   426  {{if eq .info.CoinBase false}}
   427  
   428                      <h3>{{.info.In}} input(s) for total of ? dero</h3>
   429                  <div class="center">
   430                     <table class="center">
   431                     <tr>
   432                     <td>
   433  
   434                  
   435  
   436                     {{range $i,$e :=  $.info.Ring  }} 
   437                    <tr>
   438                    </tr>
   439                     <tr>
   440                        <td style="text-align: center;">
   441                         {{$i}}    key image  {{ index $.info.Keyimages $i }}
   442                        </td>
   443                        <td>amount: ?</td>
   444                     </tr>
   445                  <tr>
   446                   <td>
   447                     <table class="center">
   448                     <tr>
   449                     <td style="text-align: center;">
   450                            Ring Member
   451                      </td>
   452                      <td style="text-align: center;">
   453                            Global Index
   454                      </td>
   455                      <td style="text-align: center;">
   456                            Height
   457                      </td>
   458                      <td style="text-align: center;">
   459                            TopoHeight
   460                      </td>
   461                     </tr>
   462                    
   463                     {{range $j :=  .  }} 
   464                      <tr>
   465                        <td style="text-align: center;">
   466                            {{ .InKey.Destination }}<br/>{{ .InKey.Mask }}<br/>
   467                        </td>
   468                        <td style="text-align: center;">{{ .Index_Global }}</td>
   469                        <td style="text-align: center;">{{ .Height }}</td>
   470                        <td style="text-align: center;">{{ .TopoHeight }}</td>
   471                       </tr>
   472                     {{end}}
   473                    
   474  
   475                     </table>
   476                     </tr>
   477  
   478  
   479  
   480                     {{end}}
   481  
   482  
   483                    </table>
   484                </div>
   485              {{end}}
   486             </div>
   487  {{ template "footer" . }} 
   488                
   489  {{end}}`
   490  
   491  var txpool_template string = `{{define "txpool"}}
   492  <h2 style="margin-bottom: 0px">
   493     Transaction pool
   494  </h2>
   495  <h4 style="font-size: 12px; margin-top: 0px">(no of txs: {{ .txpool_size }}, size: 0.00 kB, updated every 5 seconds)</h4>
   496  <div class="center">
   497      
   498        <table class="center" style="width:80%">
   499              <tr>
   500                  <td>age [h:m:s]</td>
   501                  <td>transaction hash</td>
   502                  <td>fee</td>
   503                  <td>outputs</td>
   504                  <td>in(nonrct)/out</td>
   505                  <td>ring size</td>
   506                  <td>tx size [kB]</td>
   507              </tr>
   508              
   509             
   510              {{range .mempool}}
   511              <tr>
   512                      <td></td>
   513                      <td><a href="/tx/{{.Hash}}">{{.Hash}}</a></td>
   514                      <td>{{.Fee}}</td>
   515                      <td>N/A</td>
   516                      <td>{{.In}}/{{.Out}}</td>
   517                      <td>{{.Ring_size}}</td>
   518                      <td>{{.Size}}</td>
   519  
   520              </tr>
   521              
   522              {{end}}
   523          </table>
   524  
   525  
   526  
   527  </div>
   528  {{end}}`
   529  
   530  // full page txpool_template
   531  var txpool_page_template string = `{{define "txpool_page"}}
   532  {{ template "header" . }}
   533  {{ template "txpool" . }}
   534  {{ template "footer" . }}  
   535  {{end}}`
   536  
   537  // not found page txpool_template
   538  var notfound_page_template string = `{{define "notfound_page"}}
   539  {{ template "header" . }}
   540  
   541  <h2 style="margin-bottom: 0px"><font color="red">No details found in database</font></h2>
   542  {{ template "footer" . }}  
   543  {{end}}`
   544  
   545  var main_template string = `
   546  {{define "main"}}
   547  {{ template "header" . }}
   548  {{ template "txpool" . }}
   549  
   550        <h2 style="margin-bottom: 0px">Transactions in the last 11 blocks</h2>
   551  
   552      <h4 style="font-size: 14px; margin-top: 0px">(Median size of these blocks: 0.09 kB)</h4>
   553  
   554      <div class="center">
   555  
   556              <table class="center">
   557                  <tr>
   558                      <td>height</td>
   559                      <td>topo height</td>
   560                      <td>age [h:m:s]<!--(Δm)--></td>
   561                      <td>size [kB]<!--(Δm)--></td>
   562                      <td>tx hash</td>
   563                      <td>fees</td>
   564                      <td>outputs</td>
   565                      <td>in(nonrct)/out</td>
   566                      <td>ring size</td>
   567                      <td>tx size [kB]</td>
   568                  </tr>
   569                  
   570                  
   571                  {{range .block_array}}
   572                  <tr>
   573                      <td>  {{if .SyncBlock }} <strong>{{.Height}}</strong> {{else}} <font color="purple">{{.Height}}</font>
   574     {{end}} </td>
   575                      <td><a href="/block/{{.TopoHeight}}">{{.TopoHeight}}</a></td>
   576                      
   577                         <td>{{.Age}}</td>
   578                      <td>{{.Size}}</td>
   579                      <td><a href="/tx/{{.Mtx.Hash}}">{{.Mtx.Hash}}  </a></td>
   580                      <td>N/A</td>
   581                      <td>{{.Mtx.Amount}}</td>
   582                      <td>{{.Mtx.In}}/{{.Mtx.Out}}</td>
   583                      <td>0</td>
   584                      <td>{{.Mtx.Size}}</td>
   585  
   586                  </tr>
   587                  
   588                  {{range .Txs}}
   589                  <tr>
   590                      <td></td>
   591                      <td></td>
   592                         <td></td>
   593                      <td></td>
   594                      
   595                      {{if .Skipped }}<td><a href="/tx/{{.Hash}}"><font color="indianred">{{.Hash}}</font>  </a></td>
   596                      {{else}}
   597                      <td><a href="/tx/{{.Hash}}">{{.Hash}}</a></td>
   598                      {{end}}
   599                      
   600                      
   601                      
   602                      <td>{{.Fee}}</td>
   603                      <td>N/A</td>
   604                      <td>{{.In}}/{{.Out}}</td>
   605                      <td>{{.Ring_size}}</td>
   606                      <td>{{.Size}}</td>
   607  
   608                  </tr>
   609                  {{end}}
   610                  
   611                  {{end}}
   612                </table>  
   613          {{ template "paging" . }}
   614          
   615          </div>
   616         {{ template "footer" . }}         
   617  {{end}}`
   618  
   619  var paging_template string = `{{ define "paging"}}
   620  
   621  <div id="pages" class="center" style="text-align: center;">
   622                 <a href="/page/{{.previous_page}}">previous page</a> |
   623                 <a href="/">first page</a> |
   624                  current page: {{.current_page}}/<a href="/page/{{.total_page}}">{{.total_page}}</a>
   625                  | <a href="/page/{{.next_page}}">next page</a>
   626              </div>
   627  
   628  {{end}}`
   629  
   630  var footer_template string = ` {{define "footer"}}
   631  <div class="center">
   632      <h6 style="margin-top:10px">
   633          <a href="https://github.com/deroproject/">DERO explorer source code</a>
   634          | explorer version (api): under development (1.0)
   635          | dero version: golang pre-alpha
   636          | Copyright 2017-2018  Dero Project
   637      </h6>
   638  </div>
   639  </body>
   640  </html>
   641  {{end}}
   642  `