Official Go implementation of the Ethereum protocol
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
go-ethereum/swarm/api/http/templates.go

298 lines
99 KiB

// Copyright 2017 The go-ethereum Authors
// This file is part of the go-ethereum library.
//
// The go-ethereum library is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// The go-ethereum library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
package http
import (
"encoding/hex"
"html/template"
"path"
"github.com/ethereum/go-ethereum/swarm/api"
)
type htmlListData struct {
URI *api.URI
List *api.ManifestList
}
var TemplatesMap = make(map[string]*template.Template)
var faviconBytes []byte
func init() {
for _, v := range []struct {
templateName string
partial string
funcs template.FuncMap
}{
{
templateName: "error",
partial: errorResponse,
},
{
templateName: "bzz-list",
partial: bzzList,
funcs: template.FuncMap{"basename": path.Base},
},
{
templateName: "landing-page",
partial: landing,
},
} {
TemplatesMap[v.templateName] = template.Must(template.New(v.templateName).Funcs(v.funcs).Parse(baseTemplate + css + v.partial + logo))
}
bytes, err := hex.DecodeString(favicon)
if err != nil {
panic(err)
}
faviconBytes = bytes
}
const bzzList = `{{ define "content" }}
<h3 class="top-space">Swarm index of {{ .URI }}</h3>
<hr>
<table>
<thead>
<tr>
<th>Path</th>
<th>Type</th>
<th>Size</th>
</tr>
</thead>
<tbody>
{{ range .List.CommonPrefixes }}
<tr>
<td>
<a class="normal-link" href="{{ basename . }}/">{{ basename . }}/</a>
</td>
<td>DIR</td>
<td>-</td>
</tr>
{{ end }} {{ range .List.Entries }}
<tr>
<td>
<a class="normal-link" href="{{ basename .Path }}">{{ basename .Path }}</a>
</td>
<td>{{ .ContentType }}</td>
<td>{{ .Size }}</td>
</tr>
{{ end }}
</table>
<hr>
{{ end }}`
const errorResponse = `{{ define "content" }}
<div class="container">
<div class="logo">
{{ template "logo" . }}
</div>
<div class="separate-block">
<h3>{{.Msg}}</h3>
</div>
<div>
<h5>Error code: {{.Code}}</h5>
</div>
<div class="footer">
<p>{{.Timestamp}}</p>
<p>Swarm: Serverless Hosting Incentivised Peer-To-Peer Storage And Content Distribution</p>
</div>
</div>
{{ end }}`
const landing = `{{ define "content" }}
<script type="text/javascript">
function goToPage() {
var page = document.getElementById('page').value;
if (page == "") {
var page = "theswarm.eth"
}
var address = "/bzz:/" + page;
location.href = address;
console.log(address)
}
</script>
<div class="container">
<div class="logo">
{{ template "logo" . }}
</div>
<div class="searchbar">
<form class="separate-block" action="javascript:goToPage();">
<input type="text" id="page" autofocus name="search" placeholder="Please enter an ENS name or swarm hash to retrieve ..">
<button class="button" type="submit" value="submit" onclick="goToPage();">Go!</button>
</form>
</div>
<div class="footer">
<p>{{.Timestamp}}</p>
<p>Swarm: Serverless Hosting Incentivised Peer-To-Peer Storage And Content Distribution</p>
</div>
</div>
{{ end }}`
const baseTemplate = `<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0"/>
<meta http-equiv="X-UA-Compatible" ww="chrome=1"/>
<link rel="icon" type="image/x-icon" href="favicon.ico"/>
<style>
{{ template "css" . }}
</style>
</head>
<body>
{{ template "content" . }}
</body>
</html>
`
const css = `{{ define "css" }}
html {
font-size: 18px;
font-size: 1.13rem;
-webkit-text-size-adjust: 100%;
-ms-text-size-adjust: 100%;
font-family: Helvetica, Arial, sans-serif;
}
body {
background: #f6f6f6;
color: #333;
}
a, a:visited, a:active {
color: darkorange;
}
a.normal-link, a.normal-link:active { color: #0000EE; }
a.normal-link:visited { color: #551A8B; }
table {
border-collapse: separate;
}
td {
padding: 3px 10px;
}
.container {
max-width: 600px;
margin: 40px auto 40px;
text-align: center;
}
.separate-block {
margin: 40px 0;
word-wrap: break-word;
}
.footer {
font-size: 12px;
font-size: 0.75rem;
text-align: center;
}
.orange {
color: #ffa500;
}
.top-space {
margin-top: 20px;
margin-bottom: 20px;
}
/* SVG Logos, editable */
.searchbar {
padding: 20px 20px 0;
}
.logo {
margin: 100px 80px 0;
}
.logo a img {
max-width: 140px;
}
/* Tablet < 600p*/
@media only screen and (max-width: 600px) {}
/* Mobile phone < 360p*/
@media only screen and (max-width: 360px) {
h1 {
font-size: 20px;
font-size: 1.5rem;
}
h2 {
font-size: 0.88rem;
margin: 0;
}
.logo {
margin: 50px 40px 0;
}
.footer {
font-size: 0.63rem;
text-align: center;
}
}
input[type=text] {
width: 100%;
box-sizing: border-box;
border: 2px solid #777;
border-radius: 2px;
font-size: 16px;
padding: 12px 20px 12px 20px;
transition: border 250ms ease-in-out;
}
input[type=text]:focus {
border: 2px solid #ffce73;
}
.button {
background-color: #ffa500;
margin: 20px 0;
border: none;
border-radius: 2px;
color: #222;
padding: 15px 32px;
text-align: center;
text-decoration: none;
display: inline-block;
font-size: 16px;
}
{{ end }}`
const logo = `{{ define "logo" }}
<a href="/bzz:/theswarm.eth"><img src="
{{ end }}`
const favicon = `000001000400101000000000200068040000460000002020000000002000a8100000ae0400003030000000002000a825000056150000404000000000200028420000fe3a000028000000100000002000000001002000000000004004000000000000000000000000000000000000ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff017e7e7e0362626263545454c548484849ffffff01ffffff01ffffff01ffffff01646464375b5b5bbf4545457758585809ffffff01ffffff01ffffff0164646443626262cf626262ff535353ff454545ff454545b74949492b6868681d626262a5626262fd5c5c5cff464646ff454545dd47474755ffffff01ffffff013f3f3feb565656ff636363ff535353ff464646ff3f3f3fff373737ab393939894d4d4dff626262ff5c5c5cff464646ff424242ff3a3a3af7ffffff01ffffff01383838e9353535ff424242ff474747ff383838ff353535ff363636ab35353587363636ff3a3a3aff4a4a4aff3b3b3bff353535ff363636f5ffffff01ffffff01383838e9303030ff181818ff131313ff232323ff343434ff363636ab35353587343434ff202020ff101010ff1d1d1dff303030ff373737f5ffffff01ffffff01232323c50c0c0cff0d0d0dff131313ff171717ff171717ff2929298b2727276b0f0f0ffd0d0d0dff101010ff171717ff161616ff232323d9ffffff01ffffff014d4d4d030f0f0f650c0c0ce7131313ff161616d51d1d1d4b63636363464646691717173b0d0d0dc50f0f0fff161616ef171717752e2e2e07ffffff01ffffff01ffffff01ffffff011d1d1d0f1515155360606045626262cf636363ff464646ff454545d3484848491414144d24242417ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff013c3c3c374f4f4fff636363ff636363ff464646ff464646ff3f3f3fff3c3c3c41ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff013636363d353535ff3c3c3cff575757ff363636ff181818ff282828ff37373747ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff013636363d363636ff303030ff181818ff292929ff131313ef17171771696969136565653bffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01323232371e1e1eff0d0d0dff0c0c0cff363636ff363636a3ffffff0185858515606060ff4747476bffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01111111450d0d0dd10c0c0cff1b1b1bff2a2a2a993e3e3e0b30303085292929ff37373787ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01363636030e0e0e671616166b45454505323232432e2e2ed9151515c31d1d1d2dffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff014e4e4e05ffffff01ffffff01ffffff01ffffff010000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff0000ffff28000000200000004000000001002000000000008010000000000000000000000000000000000000ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff017272721b646464a54646466f72727205ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff0168686845575757b74f4f4f39ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff017e7e7e0b6262627d616161f3636363ff424242ff444444d74f4f4f49ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff016c6c6c27636363b5616161ff555555ff434343ff464646a35858581dffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff01ffffff016666665d616161e3626262ff636363ff636363ff444444ff464646ff434343ff454545b95252522bffffff01ffffff01ffffff01ffffff016c6c6c1363636393616161fb636363ff636363ff555555ff464646ff464646ff444444f5464646836666660bffffff01ffffff01ffffff01ffffff01ffffff016a6a6a3f626262c9616161ff636363ff636363ff636363ff636363ff444444ff464646ff464646ff464646ff434343fb48484897545454135b5b5b036868686f616161ef626262ff636363ff636363ff636363ff555555ff464646ff464646ff464646ff454545ff444444e54a4a4a5fffffff01ffffff01ffffff01ffffff013b3b3bd7505050ff646464ff636363ff636363ff636363ff63