| 
									
										
										
										
											2019-01-21 06:38:13 -08:00
										 |  |  | // The MIT License (MIT) | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Copyright (c) 2016 Muhammed Thanish | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Permission is hereby granted, free of charge, to any person obtaining a copy | 
					
						
							|  |  |  | // of this software and associated documentation files (the "Software"), to deal | 
					
						
							|  |  |  | // in the Software without restriction, including without limitation the rights | 
					
						
							|  |  |  | // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
					
						
							|  |  |  | // copies of the Software, and to permit persons to whom the Software is | 
					
						
							|  |  |  | // furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The above copyright notice and this permission notice shall be included in all | 
					
						
							|  |  |  | // copies or substantial portions of the Software. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | 
					
						
							|  |  |  | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | 
					
						
							|  |  |  | // SOFTWARE. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package graphql | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"bytes" | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"net/http" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // GraphiQL is an in-browser IDE for exploring GraphiQL APIs. | 
					
						
							|  |  |  | // This handler returns GraphiQL when requested. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // For more information, see https://github.com/graphql/graphiql. | 
					
						
							|  |  |  | type GraphiQL struct{} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func respond(w http.ResponseWriter, body []byte, code int) { | 
					
						
							|  |  |  | 	w.Header().Set("Content-Type", "application/json; charset=utf-8") | 
					
						
							|  |  |  | 	w.Header().Set("X-Content-Type-Options", "nosniff") | 
					
						
							|  |  |  | 	w.WriteHeader(code) | 
					
						
							|  |  |  | 	_, _ = w.Write(body) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func errorJSON(msg string) []byte { | 
					
						
							|  |  |  | 	buf := bytes.Buffer{} | 
					
						
							|  |  |  | 	fmt.Fprintf(&buf, `{"error": "%s"}`, msg) | 
					
						
							|  |  |  | 	return buf.Bytes() | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (h GraphiQL) ServeHTTP(w http.ResponseWriter, r *http.Request) { | 
					
						
							|  |  |  | 	if r.Method != "GET" { | 
					
						
							|  |  |  | 		respond(w, errorJSON("only GET requests are supported"), http.StatusMethodNotAllowed) | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-09-10 12:20:36 +03:00
										 |  |  | 	w.Header().Set("Content-Type", "text/html") | 
					
						
							| 
									
										
										
										
											2019-01-21 06:38:13 -08:00
										 |  |  | 	w.Write(graphiql) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var graphiql = []byte(` | 
					
						
							|  |  |  | <!DOCTYPE html> | 
					
						
							|  |  |  | <html> | 
					
						
							|  |  |  | 	<head> | 
					
						
							| 
									
										
										
										
											2019-06-24 11:56:55 +03:00
										 |  |  | 		<link | 
					
						
							|  |  |  |                 rel="icon" | 
					
						
							|  |  |  |                 type="image/png" | 
					
						
							|  |  |  |                 href="" | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <link | 
					
						
							|  |  |  |                 rel="stylesheet" | 
					
						
							|  |  |  |                 href="https://cdnjs.cloudflare.com/ajax/libs/graphiql/0.13.0/graphiql.css" | 
					
						
							|  |  |  |                 integrity="sha384-Qua2xoKBxcHOg1ivsKWo98zSI5KD/UuBpzMIg8coBd4/jGYoxeozCYFI9fesatT0" | 
					
						
							|  |  |  |                 crossorigin="anonymous" | 
					
						
							|  |  |  |         /> | 
					
						
							|  |  |  |         <script | 
					
						
							|  |  |  |                 src="https://cdnjs.cloudflare.com/ajax/libs/fetch/3.0.0/fetch.min.js" | 
					
						
							|  |  |  |                 integrity="sha384-5B8/4F9AQqp/HCHReGLSOWbyAOwnJsPrvx6C0+VPUr44Olzi99zYT1xbVh+ZanQJ" | 
					
						
							|  |  |  |                 crossorigin="anonymous" | 
					
						
							|  |  |  |         ></script> | 
					
						
							|  |  |  |         <script | 
					
						
							|  |  |  |                 src="https://cdnjs.cloudflare.com/ajax/libs/react/16.8.5/umd/react.production.min.js" | 
					
						
							|  |  |  |                 integrity="sha384-dOCiLz3nZfHiJj//EWxjwSKSC6Z1IJtyIEK/b/xlHVNdVLXDYSesoxiZb94bbuGE" | 
					
						
							|  |  |  |                 crossorigin="anonymous" | 
					
						
							|  |  |  |         ></script> | 
					
						
							|  |  |  |         <script | 
					
						
							|  |  |  |                 src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.8.5/umd/react-dom.production.min.js" | 
					
						
							|  |  |  |                 integrity="sha384-QI+ql5f+khgo3mMdCktQ3E7wUKbIpuQo8S5rA/3i1jg2rMsloCNyiZclI7sFQUGN" | 
					
						
							|  |  |  |                 crossorigin="anonymous" | 
					
						
							|  |  |  |         ></script> | 
					
						
							|  |  |  |         <script | 
					
						
							|  |  |  |                 src="https://cdnjs.cloudflare.com/ajax/libs/graphiql/0.13.0/graphiql.min.js" | 
					
						
							|  |  |  |                 integrity="sha384-roSmzNmO4zJK9X4lwggDi4/oVy+9V4nlS1+MN8Taj7tftJy1GvMWyAhTNXdC/fFR" | 
					
						
							|  |  |  |                 crossorigin="anonymous" | 
					
						
							|  |  |  |         ></script> | 
					
						
							| 
									
										
										
										
											2019-01-21 06:38:13 -08:00
										 |  |  | 	</head> | 
					
						
							|  |  |  | 	<body style="width: 100%; height: 100%; margin: 0; overflow: hidden;"> | 
					
						
							|  |  |  | 		<div id="graphiql" style="height: 100vh;">Loading...</div> | 
					
						
							|  |  |  | 		<script> | 
					
						
							|  |  |  | 			function fetchGQL(params) { | 
					
						
							|  |  |  | 				return fetch("/graphql", { | 
					
						
							|  |  |  | 					method: "post", | 
					
						
							|  |  |  | 					body: JSON.stringify(params), | 
					
						
							|  |  |  | 					credentials: "include", | 
					
						
							|  |  |  | 				}).then(function (resp) { | 
					
						
							|  |  |  | 					return resp.text(); | 
					
						
							|  |  |  | 				}).then(function (body) { | 
					
						
							|  |  |  | 					try { | 
					
						
							|  |  |  | 						return JSON.parse(body); | 
					
						
							|  |  |  | 					} catch (error) { | 
					
						
							|  |  |  | 						return body; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				}); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			ReactDOM.render( | 
					
						
							|  |  |  | 				React.createElement(GraphiQL, {fetcher: fetchGQL}), | 
					
						
							|  |  |  | 				document.getElementById("graphiql") | 
					
						
							|  |  |  | 			) | 
					
						
							|  |  |  | 		</script> | 
					
						
							|  |  |  | 	</body> | 
					
						
							|  |  |  | </html> | 
					
						
							|  |  |  | `) |