github.com/SwingbyProtocol/go-ethereum@v1.9.7/graphql/graphiql.go (about) 1 // The MIT License (MIT) 2 // 3 // Copyright (c) 2016 Muhammed Thanish 4 // 5 // Permission is hereby granted, free of charge, to any person obtaining a copy 6 // of this software and associated documentation files (the "Software"), to deal 7 // in the Software without restriction, including without limitation the rights 8 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 // copies of the Software, and to permit persons to whom the Software is 10 // furnished to do so, subject to the following conditions: 11 // 12 // The above copyright notice and this permission notice shall be included in all 13 // copies or substantial portions of the Software. 14 // 15 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 // SOFTWARE. 22 23 package graphql 24 25 import ( 26 "bytes" 27 "fmt" 28 "net/http" 29 ) 30 31 // GraphiQL is an in-browser IDE for exploring GraphiQL APIs. 32 // This handler returns GraphiQL when requested. 33 // 34 // For more information, see https://github.com/graphql/graphiql. 35 type GraphiQL struct{} 36 37 func respond(w http.ResponseWriter, body []byte, code int) { 38 w.Header().Set("Content-Type", "application/json; charset=utf-8") 39 w.Header().Set("X-Content-Type-Options", "nosniff") 40 w.WriteHeader(code) 41 _, _ = w.Write(body) 42 } 43 44 func errorJSON(msg string) []byte { 45 buf := bytes.Buffer{} 46 fmt.Fprintf(&buf, `{"error": "%s"}`, msg) 47 return buf.Bytes() 48 } 49 50 func (h GraphiQL) ServeHTTP(w http.ResponseWriter, r *http.Request) { 51 if r.Method != "GET" { 52 respond(w, errorJSON("only GET requests are supported"), http.StatusMethodNotAllowed) 53 return 54 } 55 w.Header().Set("Content-Type", "text/html") 56 w.Write(graphiql) 57 } 58 59 var graphiql = []byte(` 60 <!DOCTYPE html> 61 <html> 62 <head> 63 <link 64 rel="icon" 65 type="image/png" 66 href="" 67 /> 68 <link 69 rel="stylesheet" 70 href="https://cdnjs.cloudflare.com/ajax/libs/graphiql/0.13.0/graphiql.css" 71 integrity="sha384-Qua2xoKBxcHOg1ivsKWo98zSI5KD/UuBpzMIg8coBd4/jGYoxeozCYFI9fesatT0" 72 crossorigin="anonymous" 73 /> 74 <script 75 src="https://cdnjs.cloudflare.com/ajax/libs/fetch/3.0.0/fetch.min.js" 76 integrity="sha384-5B8/4F9AQqp/HCHReGLSOWbyAOwnJsPrvx6C0+VPUr44Olzi99zYT1xbVh+ZanQJ" 77 crossorigin="anonymous" 78 ></script> 79 <script 80 src="https://cdnjs.cloudflare.com/ajax/libs/react/16.8.5/umd/react.production.min.js" 81 integrity="sha384-dOCiLz3nZfHiJj//EWxjwSKSC6Z1IJtyIEK/b/xlHVNdVLXDYSesoxiZb94bbuGE" 82 crossorigin="anonymous" 83 ></script> 84 <script 85 src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.8.5/umd/react-dom.production.min.js" 86 integrity="sha384-QI+ql5f+khgo3mMdCktQ3E7wUKbIpuQo8S5rA/3i1jg2rMsloCNyiZclI7sFQUGN" 87 crossorigin="anonymous" 88 ></script> 89 <script 90 src="https://cdnjs.cloudflare.com/ajax/libs/graphiql/0.13.0/graphiql.min.js" 91 integrity="sha384-roSmzNmO4zJK9X4lwggDi4/oVy+9V4nlS1+MN8Taj7tftJy1GvMWyAhTNXdC/fFR" 92 crossorigin="anonymous" 93 ></script> 94 </head> 95 <body style="width: 100%; height: 100%; margin: 0; overflow: hidden;"> 96 <div id="graphiql" style="height: 100vh;">Loading...</div> 97 <script> 98 function fetchGQL(params) { 99 return fetch("/graphql", { 100 method: "post", 101 body: JSON.stringify(params), 102 credentials: "include", 103 }).then(function (resp) { 104 return resp.text(); 105 }).then(function (body) { 106 try { 107 return JSON.parse(body); 108 } catch (error) { 109 return body; 110 } 111 }); 112 } 113 ReactDOM.render( 114 React.createElement(GraphiQL, {fetcher: fetchGQL}), 115 document.getElementById("graphiql") 116 ) 117 </script> 118 </body> 119 </html> 120 `)