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/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 `