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