github.com/aigarnetwork/aigar@v0.0.0-20191115204914-d59a6eb70f8e/graphql/graphiql.go (about)

     1  //  Copyright 2018 The go-ethereum Authors
     2  //  Copyright 2019 The go-aigar Authors
     3  //  This file is part of the go-aigar library.
     4  //
     5  //  The go-aigar library is free software: you can redistribute it and/or modify
     6  //  it under the terms of the GNU Lesser General Public License as published by
     7  //  the Free Software Foundation, either version 3 of the License, or
     8  //  (at your option) any later version.
     9  //
    10  //  The go-aigar library is distributed in the hope that it will be useful,
    11  //  but WITHOUT ANY WARRANTY; without even the implied warranty of
    12  //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
    13  //  GNU Lesser General Public License for more details.
    14  //
    15  //  You should have received a copy of the GNU Lesser General Public License
    16  //  along with the go-aigar library. If not, see <http://www.gnu.org/licenses/>.
    17  
    18  package graphql
    19  
    20  import (
    21  	"bytes"
    22  	"fmt"
    23  	"net/http"
    24  )
    25  
    26  // GraphiQL is an in-browser IDE for exploring GraphiQL APIs.
    27  // This handler returns GraphiQL when requested.
    28  //
    29  // For more information, see https://github.com/graphql/graphiql.
    30  type GraphiQL struct{}
    31  
    32  func respond(w http.ResponseWriter, body []byte, code int) {
    33  	w.Header().Set("Content-Type", "application/json; charset=utf-8")
    34  	w.Header().Set("X-Content-Type-Options", "nosniff")
    35  	w.WriteHeader(code)
    36  	_, _ = w.Write(body)
    37  }
    38  
    39  func errorJSON(msg string) []byte {
    40  	buf := bytes.Buffer{}
    41  	fmt.Fprintf(&buf, `{"error": "%s"}`, msg)
    42  	return buf.Bytes()
    43  }
    44  
    45  func (h GraphiQL) ServeHTTP(w http.ResponseWriter, r *http.Request) {
    46  	if r.Method != "GET" {
    47  		respond(w, errorJSON("only GET requests are supported"), http.StatusMethodNotAllowed)
    48  		return
    49  	}
    50  	w.Header().Set("Content-Type", "text/html")
    51  	w.Write(graphiql)
    52  }
    53  
    54  var graphiql = []byte(`
    55  <!DOCTYPE html>
    56  <html>
    57  	<head>
    58  		<link
    59                  rel="icon"
    60                  type="image/png"
    61                  href=""
    62          />
    63          <link
    64                  rel="stylesheet"
    65                  href="https://cdnjs.cloudflare.com/ajax/libs/graphiql/0.13.0/graphiql.css"
    66                  integrity="sha384-Qua2xoKBxcHOg1ivsKWo98zSI5KD/UuBpzMIg8coBd4/jGYoxeozCYFI9fesatT0"
    67                  crossorigin="anonymous"
    68          />
    69          <script
    70                  src="https://cdnjs.cloudflare.com/ajax/libs/fetch/3.0.0/fetch.min.js"
    71                  integrity="sha384-5B8/4F9AQqp/HCHReGLSOWbyAOwnJsPrvx6C0+VPUr44Olzi99zYT1xbVh+ZanQJ"
    72                  crossorigin="anonymous"
    73          ></script>
    74          <script
    75                  src="https://cdnjs.cloudflare.com/ajax/libs/react/16.8.5/umd/react.production.min.js"
    76                  integrity="sha384-dOCiLz3nZfHiJj//EWxjwSKSC6Z1IJtyIEK/b/xlHVNdVLXDYSesoxiZb94bbuGE"
    77                  crossorigin="anonymous"
    78          ></script>
    79          <script
    80                  src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.8.5/umd/react-dom.production.min.js"
    81                  integrity="sha384-QI+ql5f+khgo3mMdCktQ3E7wUKbIpuQo8S5rA/3i1jg2rMsloCNyiZclI7sFQUGN"
    82                  crossorigin="anonymous"
    83          ></script>
    84          <script
    85                  src="https://cdnjs.cloudflare.com/ajax/libs/graphiql/0.13.0/graphiql.min.js"
    86                  integrity="sha384-roSmzNmO4zJK9X4lwggDi4/oVy+9V4nlS1+MN8Taj7tftJy1GvMWyAhTNXdC/fFR"
    87                  crossorigin="anonymous"
    88          ></script>
    89  	</head>
    90  	<body style="width: 100%; height: 100%; margin: 0; overflow: hidden;">
    91  		<div id="graphiql" style="height: 100vh;">Loading...</div>
    92  		<script>
    93  			function fetchGQL(params) {
    94  				return fetch("/graphql", {
    95  					method: "post",
    96  					body: JSON.stringify(params),
    97  					credentials: "include",
    98  				}).then(function (resp) {
    99  					return resp.text();
   100  				}).then(function (body) {
   101  					try {
   102  						return JSON.parse(body);
   103  					} catch (error) {
   104  						return body;
   105  					}
   106  				});
   107  			}
   108  			ReactDOM.render(
   109  				React.createElement(GraphiQL, {fetcher: fetchGQL}),
   110  				document.getElementById("graphiql")
   111  			)
   112  		</script>
   113  	</body>
   114  </html>
   115  `)