├── .gitignore ├── LICENSE ├── README.md ├── bin └── easygraphql-firebase.js ├── commands └── start.js ├── package-lock.json ├── package.json ├── scripts └── createPackage.sh ├── templates ├── apiFileIndex.txt ├── starterFile.txt ├── starterFileGitignore.txt ├── testFileMutation.txt └── testFileQuery.txt └── util ├── createApi.js ├── createApp.js ├── createEnvFile.js ├── createResolvers.js ├── createSchema.js ├── createTests.js ├── deployNow.js ├── queryGenerator └── index.js └── startServer.js /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .vscode 3 | .DS_Store 4 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | ###The MIT License 2 | 3 | Copyright (c) 2018 EasyGraphQL 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 13 | all 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 21 | THE SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |

2 | easygraphql-firebase 3 |
4 | easygraphql-firebase 5 |
6 |
7 |

8 | 9 | `easygraphql-firebase` is global package that will create a GraphQL server connected 10 | to your Firebase real-time database just using a GraphQL schema. 11 | 12 | ## Installation 13 | ```bash 14 | $ npm install easygraphql-firebase -g 15 | ``` 16 | 17 | ## Usage 18 | To get started with your GraphQL-Firebase server you need to have: 19 | 20 | + GraphQL schema. 21 | + Firebase API key. 22 | + Firebase database url. 23 | 24 | Create a GraphQL schema file. 25 | ```graphql 26 | type Student { 27 | key: ID! 28 | age: Int! 29 | name: String! 30 | } 31 | 32 | type School { 33 | key: ID! 34 | location: String! 35 | students: Int! 36 | name: String! 37 | student: Student! 38 | } 39 | 40 | input StudentInput { 41 | age: Int! 42 | name: String! 43 | } 44 | 45 | input SchoolInput { 46 | location: String! 47 | students: Int! 48 | name: String! 49 | phone: String! 50 | student: StudentInput! 51 | } 52 | 53 | type Query { 54 | getStudentByUsername(name: String!): Student! 55 | getStudents: [Student!]! 56 | getSchool(name: String!): School! 57 | getSchools: [School!]! 58 | } 59 | 60 | type Mutation { 61 | createStudent(input: StudentInput!): Student! 62 | createSchool(input: SchoolInput!): School! 63 | } 64 | ``` 65 | 66 | #### Run on your terminal 67 | 68 | ```bash 69 | $ easygraphql-firebase 70 | ``` 71 | by default it is going to run the server automatically. 72 | 73 | You can set flags to prevent running it automatically, set apiKey, set databaseUrl and also pass the schema name. 74 | 75 | ```bash 76 | $ easygraphql-firebase schema.gql --apiKey= --databaseUrl= --start=false 77 | ``` 78 | 79 | and select the GraphQL schema you want to use; also, it will ask for some env variables, 80 | you can press enter and add them later. 81 | 82 | `easygraphql-firebase` will start creating the whole project, and also it will add to the new schema 83 | some new queries, like 84 | ```graphql 85 | type Query { 86 | .... 87 | getUserByKey(key: ID!): User 88 | getSchoolByKey(key: ID!): School 89 | } 90 | ``` 91 | 92 | also, there is going to be a folder to make tests, it is using [`easygraphql-tester`](https://github.com/EasyGraphQL/easygraphql-tester) 93 | so, if you want to test your queries and mutations, visit the folder `test` and add on cases your own tests, add a name to identify them. 94 | 95 | ```js 96 | const cases = [ 97 | { 98 | name: 'Should get school by key', 99 | query: ` 100 | { 101 | getSchoolByKey(key: "-LTYEa4geFv52c5rzpCS") { 102 | name 103 | } 104 | } 105 | `, 106 | expected: true 107 | } 108 | ] 109 | ``` 110 | 111 | ### Result 112 | ```shell 113 | Validate query 114 | ✓ Should validate the query: Should get school by key 115 | ``` 116 | 117 | ## Collections 118 | 119 | The collections that are going to be query are going to be the name of the expected type in lowercase with an `s` at the end. 120 | 121 | E.g 122 | If you have this query `getStudentByUsername(name: String!): Student!` the resolver is going to search on Firebase 123 | for a collection called `students` 124 | 125 | ## Run it 126 | To run your project visit the generated folder and run: 127 | 128 | ```bash 129 | $ npm run start 130 | ``` 131 | 132 | ## Recommendations 133 | This a **beta** version, so the recommendations are: 134 | 135 | + Just set one argument to the queries. 136 | + Add nested fields from the input, if you want to add custom logic, edit the resolvers. 137 | + Test your queries / mutations. 138 | + If you are having a lot of records, and you are making a query that returns an array 139 | add a limit to it! 140 | 141 | ## Deploying with Now ▲ 142 | To deploy with now, be sure to have it installed and config on your computer. 143 | 144 | To use it, just pass the flag `--now` to the command on the terminal: 145 | 146 | ```bash 147 | $ easygraphql-firebase --now 148 | ``` 149 | 150 | # License 151 | ### The MIT License 152 | 153 | Copyright (c) 2018 EasyGraphQL 154 | 155 | Permission is hereby granted, free of charge, to any person obtaining a copy 156 | of this software and associated documentation files (the "Software"), to deal 157 | in the Software without restriction, including without limitation the rights 158 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 159 | copies of the Software, and to permit persons to whom the Software is 160 | furnished to do so, subject to the following conditions: 161 | 162 | The above copyright notice and this permission notice shall be included in 163 | all copies or substantial portions of the Software. 164 | 165 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 166 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 167 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 168 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 169 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 170 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 171 | THE SOFTWARE. 172 | -------------------------------------------------------------------------------- /bin/easygraphql-firebase.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | "use strict"; 4 | 5 | const createProject = require("../commands/start"); 6 | 7 | createProject(); 8 | -------------------------------------------------------------------------------- /commands/start.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const inquirer = require("inquirer"); 4 | const ora = require("ora"); 5 | const fs = require("fs-extra"); 6 | const path = require("path"); 7 | const { spawn } = require("child_process"); 8 | const argv = require("minimist")(process.argv.slice(2)); 9 | 10 | const spinner = ora("Creating easygraphql-firebase 🔥🔥🔥🔥"); 11 | 12 | const createApp = require("../util/createApp"); 13 | const createApi = require("../util/createApi"); 14 | const createSchema = require("../util/createSchema"); 15 | const createResolvers = require("../util/createResolvers"); 16 | const createEnvFile = require("../util/createEnvFile"); 17 | const createTests = require("../util/createTests"); 18 | const startServer = require("../util/startServer"); 19 | const deployNow = require("../util/deployNow"); 20 | 21 | const questions = []; 22 | 23 | function createProject() { 24 | let fileName; 25 | let filePath; 26 | 27 | const arg = argv._.length > 0 ? argv._[0] : false; 28 | const apiKey = argv.apiKey ? argv.apiKey : null; 29 | const databaseUrl = argv.databaseUrl ? argv.databaseUrl : null; 30 | const start = !(argv.start && argv.start === "false"); 31 | const port = argv.p && argv.p > 999 ? argv.p : 7000; 32 | const now = !!argv.now; 33 | 34 | if ( 35 | arg && 36 | (arg.includes(".gql") || arg.includes(".graphql")) && 37 | fs.existsSync(arg) 38 | ) { 39 | fileName = arg; 40 | } else if (arg && fs.existsSync(arg)) { 41 | let files = fs.readdirSync(arg); 42 | files = files.filter( 43 | file => file.includes(".gql") || file.includes(".graphql") 44 | ); 45 | const options = { 46 | type: "list", 47 | name: "schemaName", 48 | message: "Schema file name", 49 | choices: files 50 | }; 51 | questions.push(options); 52 | filePath = arg; 53 | } else { 54 | let files = fs.readdirSync(path.resolve()); 55 | files = files.filter( 56 | file => file.includes(".gql") || file.includes(".graphql") 57 | ); 58 | if (files.length === 0) { 59 | console.log("> Error: There are no GraphQL schema in this dir! ❌"); 60 | process.exit(1); 61 | } 62 | const options = { 63 | type: "list", 64 | name: "schemaName", 65 | message: "Schema file name", 66 | choices: files 67 | }; 68 | questions.push(options); 69 | } 70 | 71 | if (!apiKey) { 72 | questions.push({ 73 | type: "input", 74 | name: "apiKey", 75 | message: "Your Firebase api key", 76 | validate: apiKey => typeof apiKey === "string" 77 | }); 78 | } 79 | 80 | if (!databaseUrl) { 81 | questions.push({ 82 | type: "input", 83 | name: "databaseUrl", 84 | message: "Your Firebase database url", 85 | validate: databaseUrl => typeof databaseUrl === "string" 86 | }); 87 | } 88 | 89 | inquirer 90 | .prompt(questions) 91 | .then(answers => 92 | handleResponse( 93 | answers, 94 | fileName, 95 | filePath, 96 | start, 97 | port, 98 | apiKey, 99 | databaseUrl, 100 | now 101 | ) 102 | ); 103 | } 104 | 105 | async function handleResponse( 106 | answers, 107 | fileName, 108 | filePath, 109 | start, 110 | port, 111 | apiKey, 112 | databaseUrl, 113 | now 114 | ) { 115 | let dirPath; 116 | try { 117 | fileName = fileName || answers["schemaName"]; 118 | apiKey = apiKey || answers["apiKey"]; 119 | databaseUrl = databaseUrl || answers["databaseUrl"]; 120 | spinner.start(); 121 | 122 | const dirPath = path.join(path.resolve(), "generated"); 123 | createApp(dirPath); 124 | await createApi(dirPath); 125 | createSchema(dirPath, fileName, filePath); 126 | createEnvFile(dirPath, apiKey, databaseUrl); 127 | createResolvers(dirPath); 128 | createTests(dirPath); 129 | if (start && !now) { 130 | startServer(dirPath, port); 131 | } 132 | if (now) { 133 | deployNow(dirPath, apiKey, databaseUrl); 134 | } 135 | spawn("standard", ["--fix"], { 136 | cwd: dirPath 137 | }); 138 | spinner.stop(); 139 | } catch (err) { 140 | spinner.stop(); 141 | console.log("> Error:", err.message); 142 | fs.removeSync(dirPath); 143 | process.exit(1); 144 | } 145 | } 146 | 147 | module.exports = createProject; 148 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "easygraphql-firebase", 3 | "version": "0.0.4", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.5.5", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 10 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.5.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 19 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@firebase/app": { 28 | "version": "0.3.5", 29 | "resolved": "https://registry.npmjs.org/@firebase/app/-/app-0.3.5.tgz", 30 | "integrity": "sha512-DaAlb74yzwXbkFXvfsUVFeurSETPJAvKNtVpAKlS6RThyD+Y+ci1/8JVw4INm2hihbj/edxlAUelg9eoOZNCKA==", 31 | "requires": { 32 | "@firebase/app-types": "0.3.2", 33 | "@firebase/util": "0.2.3", 34 | "dom-storage": "2.1.0", 35 | "tslib": "1.9.0", 36 | "xmlhttprequest": "1.8.0" 37 | } 38 | }, 39 | "@firebase/app-types": { 40 | "version": "0.3.2", 41 | "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.3.2.tgz", 42 | "integrity": "sha512-ZD8lTgW07NGgo75bTyBJA8Lt9+NweNzot7lrsBtIvfciwUzaFJLsv2EShqjBeuhF7RpG6YFucJ6m67w5buCtzw==" 43 | }, 44 | "@firebase/auth": { 45 | "version": "0.9.0", 46 | "resolved": "https://registry.npmjs.org/@firebase/auth/-/auth-0.9.0.tgz", 47 | "integrity": "sha512-pNxfxFr4/tJluGfmPYUiuy2Tq/ZSRniJlWP4fj1mg+a9r+KevheeISZdWEZwJMosieXeCg+BzY0tvFD9j5ZrDw==", 48 | "requires": { 49 | "@firebase/auth-types": "0.5.0" 50 | } 51 | }, 52 | "@firebase/auth-types": { 53 | "version": "0.5.0", 54 | "resolved": "https://registry.npmjs.org/@firebase/auth-types/-/auth-types-0.5.0.tgz", 55 | "integrity": "sha512-DSjtsIjTy5RSiWyGHqiGkLcDgEgFEf2aD2O0t/0+lHmAzxUGrJFO5+IkPNV6i0ffmtiJaXQDJ7z7q4OdypDBCg==" 56 | }, 57 | "@firebase/database": { 58 | "version": "0.3.7", 59 | "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.3.7.tgz", 60 | "integrity": "sha512-BB5L3PqwQVJUdS1WY+sq3eun5n5oimFWolXYl6pyACJwqL2qnPp0cnjK6kOqTsRPPMayZZmfUI38RBDwXaUJhQ==", 61 | "requires": { 62 | "@firebase/database-types": "0.3.2", 63 | "@firebase/logger": "0.1.2", 64 | "@firebase/util": "0.2.3", 65 | "faye-websocket": "0.11.1", 66 | "tslib": "1.9.0" 67 | } 68 | }, 69 | "@firebase/database-types": { 70 | "version": "0.3.2", 71 | "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.3.2.tgz", 72 | "integrity": "sha512-9ZYdvYQ6r3aaHJarhUM5Hf6lQWu3ZJme+RR0o8qfBb9L04TL3uNjt+AJFku1ysVPntTn+9GqJjiIB2/OC3JtwA==" 73 | }, 74 | "@firebase/firestore": { 75 | "version": "0.9.0", 76 | "resolved": "https://registry.npmjs.org/@firebase/firestore/-/firestore-0.9.0.tgz", 77 | "integrity": "sha512-ub9BXce75D7t2yQxqopJhqE5YrsdePLg7wP8aMLR2Twe+O89IZqOhdbE0VALjplD2rAWXkOLqf6zYsppu2hh4g==", 78 | "requires": { 79 | "@firebase/firestore-types": "0.8.0", 80 | "@firebase/logger": "0.1.2", 81 | "@firebase/webchannel-wrapper": "0.2.11", 82 | "grpc": "1.16.1", 83 | "tslib": "1.9.0" 84 | } 85 | }, 86 | "@firebase/firestore-types": { 87 | "version": "0.8.0", 88 | "resolved": "https://registry.npmjs.org/@firebase/firestore-types/-/firestore-types-0.8.0.tgz", 89 | "integrity": "sha512-FdLy2TbZ6aAeT9eDmVMPAFsUqhjN2e+jcdVpl0Pz1W6ElRWWyr30hgTY7xIqIKpMs1iT6IF/8w9CKvI6fPbKxA==" 90 | }, 91 | "@firebase/functions": { 92 | "version": "0.3.3", 93 | "resolved": "https://registry.npmjs.org/@firebase/functions/-/functions-0.3.3.tgz", 94 | "integrity": "sha512-t8CE1AQivqWeDJ1MvaITGn+x6Z78CVnJi3mLz/+2Vx7UwU4HRhkfJcxhrRnnMzWY9OoCJ9j1wUoDsXfKmU546w==", 95 | "requires": { 96 | "@firebase/functions-types": "0.2.1", 97 | "@firebase/messaging-types": "0.2.3", 98 | "isomorphic-fetch": "2.2.1", 99 | "tslib": "1.9.0" 100 | } 101 | }, 102 | "@firebase/functions-types": { 103 | "version": "0.2.1", 104 | "resolved": "https://registry.npmjs.org/@firebase/functions-types/-/functions-types-0.2.1.tgz", 105 | "integrity": "sha512-hH78lgDoa5E1peBSXnfQyshENmh/5a8aia+S4Ocjc53OUWRJ4VqYwWUV5gE4b2mqVKTpN4akJccLq2pCnNGZcA==" 106 | }, 107 | "@firebase/logger": { 108 | "version": "0.1.2", 109 | "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.1.2.tgz", 110 | "integrity": "sha512-4NHGRIbZChg9vDUxynzYrw14G/U/71v0pea+jXPicrpflL0N0PSCULXGGSTmzn9fqZ5W5djEwVLBCVwKndXG8w==" 111 | }, 112 | "@firebase/messaging": { 113 | "version": "0.3.7", 114 | "resolved": "https://registry.npmjs.org/@firebase/messaging/-/messaging-0.3.7.tgz", 115 | "integrity": "sha512-8tZgRVJuvmFe5HDUiKvGAsK/jehrMnoUx95XU3RkZHX2D5QHjXAvvXIfFQ118EtG5/whZoEo1nCjEHAd9mSalA==", 116 | "requires": { 117 | "@firebase/messaging-types": "0.2.3", 118 | "@firebase/util": "0.2.3", 119 | "tslib": "1.9.0" 120 | } 121 | }, 122 | "@firebase/messaging-types": { 123 | "version": "0.2.3", 124 | "resolved": "https://registry.npmjs.org/@firebase/messaging-types/-/messaging-types-0.2.3.tgz", 125 | "integrity": "sha512-avwCgZzcx2uxIW/wT3p3G/EyHftIrvMyiTS7AA7dxDlzfx+8dpAeTsb1+jsHJT4F6foSh5HG17Nw8sDzYuxH1Q==" 126 | }, 127 | "@firebase/polyfill": { 128 | "version": "0.3.3", 129 | "resolved": "https://registry.npmjs.org/@firebase/polyfill/-/polyfill-0.3.3.tgz", 130 | "integrity": "sha512-xs8IZf1WEbufYXyfV8YjmiFZOaujRRq0T03NteihYfuGVTTym7z5SmvLvEHLEUjf2fgeobPEzZ2JgrCQHS+QHw==", 131 | "requires": { 132 | "core-js": "2.5.5", 133 | "promise-polyfill": "7.1.2", 134 | "whatwg-fetch": "2.0.4" 135 | }, 136 | "dependencies": { 137 | "whatwg-fetch": { 138 | "version": "2.0.4", 139 | "resolved": "http://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-2.0.4.tgz", 140 | "integrity": "sha512-dcQ1GWpOD/eEQ97k66aiEVpNnapVj90/+R+SXTPYGHpYBBypfKJEQjLrvMZ7YXbKm21gXd4NcuxUTjiv1YtLng==" 141 | } 142 | } 143 | }, 144 | "@firebase/storage": { 145 | "version": "0.2.4", 146 | "resolved": "https://registry.npmjs.org/@firebase/storage/-/storage-0.2.4.tgz", 147 | "integrity": "sha512-uqA6CoZYkugk69ImqB16VBPP7JRPRfZwcUP9CsE0GPVGQkZQQfBGwzIyEoFA8lUfVLrvxQiL0sQvHUXZ945LMg==", 148 | "requires": { 149 | "@firebase/storage-types": "0.2.3", 150 | "tslib": "1.9.0" 151 | } 152 | }, 153 | "@firebase/storage-types": { 154 | "version": "0.2.3", 155 | "resolved": "https://registry.npmjs.org/@firebase/storage-types/-/storage-types-0.2.3.tgz", 156 | "integrity": "sha512-RaZeam2LgsB7xwAtOQr4G0Geoyf7D5TnLF3a12By6Rh0Z9PqBSlWn0SVYGW3SkmxIdqvWZMZvCyamUlqQvQzWw==" 157 | }, 158 | "@firebase/util": { 159 | "version": "0.2.3", 160 | "resolved": "https://registry.npmjs.org/@firebase/util/-/util-0.2.3.tgz", 161 | "integrity": "sha512-ngAG4qYpcnnshUKbBlEiR9+j37U7dTrTVJlS4v7ahW1ROuyLT9xj6cWyHQANzcTR2yKLmEv3yfwoZwedz7V0oQ==", 162 | "requires": { 163 | "tslib": "1.9.0" 164 | } 165 | }, 166 | "@firebase/webchannel-wrapper": { 167 | "version": "0.2.11", 168 | "resolved": "https://registry.npmjs.org/@firebase/webchannel-wrapper/-/webchannel-wrapper-0.2.11.tgz", 169 | "integrity": "sha512-WyMXDxk/WZ+f2lOCeEvDWUce2f5Kk2sNfvArK8f+PlUnzFdy/MBzLXrmbMgyZXP7GP4ooUxYV8Sdmoh1hGk1Uw==" 170 | }, 171 | "@types/normalize-package-data": { 172 | "version": "2.4.0", 173 | "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 174 | "integrity": "sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==", 175 | "dev": true 176 | }, 177 | "ansi-escapes": { 178 | "version": "3.1.0", 179 | "resolved": "http://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", 180 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==" 181 | }, 182 | "ansi-regex": { 183 | "version": "2.1.1", 184 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 185 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 186 | }, 187 | "ansi-styles": { 188 | "version": "3.2.1", 189 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 190 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 191 | "dev": true, 192 | "requires": { 193 | "color-convert": "^1.9.0" 194 | } 195 | }, 196 | "arch": { 197 | "version": "2.1.1", 198 | "resolved": "https://registry.npmjs.org/arch/-/arch-2.1.1.tgz", 199 | "integrity": "sha512-BLM56aPo9vLLFVa8+/+pJLnrZ7QGGTVHWsCwieAWT9o9K8UeGaQbzZbGoabWLOo2ksBCztoXdqBZBplqLDDCSg==" 200 | }, 201 | "argparse": { 202 | "version": "1.0.10", 203 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 204 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 205 | "dev": true, 206 | "requires": { 207 | "sprintf-js": "~1.0.2" 208 | } 209 | }, 210 | "ascli": { 211 | "version": "1.0.1", 212 | "resolved": "https://registry.npmjs.org/ascli/-/ascli-1.0.1.tgz", 213 | "integrity": "sha1-vPpZdKYvGOgcq660lzKrSoj5Brw=", 214 | "requires": { 215 | "colour": "~0.7.1", 216 | "optjs": "~3.2.2" 217 | } 218 | }, 219 | "balanced-match": { 220 | "version": "1.0.0", 221 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 222 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 223 | }, 224 | "brace-expansion": { 225 | "version": "1.1.11", 226 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 227 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 228 | "requires": { 229 | "balanced-match": "^1.0.0", 230 | "concat-map": "0.0.1" 231 | } 232 | }, 233 | "bytebuffer": { 234 | "version": "5.0.1", 235 | "resolved": "https://registry.npmjs.org/bytebuffer/-/bytebuffer-5.0.1.tgz", 236 | "integrity": "sha1-WC7qSxqHO20CCkjVjfhfC7ps/d0=", 237 | "requires": { 238 | "long": "~3" 239 | } 240 | }, 241 | "caller-callsite": { 242 | "version": "2.0.0", 243 | "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", 244 | "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", 245 | "dev": true, 246 | "requires": { 247 | "callsites": "^2.0.0" 248 | } 249 | }, 250 | "caller-path": { 251 | "version": "2.0.0", 252 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", 253 | "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", 254 | "dev": true, 255 | "requires": { 256 | "caller-callsite": "^2.0.0" 257 | } 258 | }, 259 | "callsites": { 260 | "version": "2.0.0", 261 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", 262 | "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=", 263 | "dev": true 264 | }, 265 | "camelcase": { 266 | "version": "2.1.1", 267 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", 268 | "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=" 269 | }, 270 | "chalk": { 271 | "version": "2.4.1", 272 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 273 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 274 | "requires": { 275 | "ansi-styles": "^3.2.1", 276 | "escape-string-regexp": "^1.0.5", 277 | "supports-color": "^5.3.0" 278 | }, 279 | "dependencies": { 280 | "ansi-styles": { 281 | "version": "3.2.1", 282 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 283 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 284 | "requires": { 285 | "color-convert": "^1.9.0" 286 | } 287 | }, 288 | "supports-color": { 289 | "version": "5.5.0", 290 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 291 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 292 | "requires": { 293 | "has-flag": "^3.0.0" 294 | } 295 | } 296 | } 297 | }, 298 | "chardet": { 299 | "version": "0.7.0", 300 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 301 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==" 302 | }, 303 | "ci-info": { 304 | "version": "2.0.0", 305 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 306 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 307 | "dev": true 308 | }, 309 | "cli-cursor": { 310 | "version": "2.1.0", 311 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 312 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 313 | "requires": { 314 | "restore-cursor": "^2.0.0" 315 | } 316 | }, 317 | "cli-spinners": { 318 | "version": "1.3.1", 319 | "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-1.3.1.tgz", 320 | "integrity": "sha512-1QL4544moEsDVH9T/l6Cemov/37iv1RtoKf7NJ04A60+4MREXNfx/QvavbH6QoGdsD4N4Mwy49cmaINR/o2mdg==" 321 | }, 322 | "cli-width": { 323 | "version": "2.2.0", 324 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 325 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=" 326 | }, 327 | "clipboardy": { 328 | "version": "1.2.3", 329 | "resolved": "https://registry.npmjs.org/clipboardy/-/clipboardy-1.2.3.tgz", 330 | "integrity": "sha512-2WNImOvCRe6r63Gk9pShfkwXsVtKCroMAevIbiae021mS850UkWPbevxsBz3tnvjZIEGvlwaqCPsw+4ulzNgJA==", 331 | "requires": { 332 | "arch": "^2.1.0", 333 | "execa": "^0.8.0" 334 | } 335 | }, 336 | "cliui": { 337 | "version": "3.2.0", 338 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", 339 | "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", 340 | "requires": { 341 | "string-width": "^1.0.1", 342 | "strip-ansi": "^3.0.1", 343 | "wrap-ansi": "^2.0.0" 344 | } 345 | }, 346 | "clone": { 347 | "version": "1.0.4", 348 | "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", 349 | "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=" 350 | }, 351 | "code-point-at": { 352 | "version": "1.1.0", 353 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 354 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 355 | }, 356 | "color-convert": { 357 | "version": "1.9.3", 358 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 359 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 360 | "requires": { 361 | "color-name": "1.1.3" 362 | } 363 | }, 364 | "color-name": { 365 | "version": "1.1.3", 366 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 367 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 368 | }, 369 | "colour": { 370 | "version": "0.7.1", 371 | "resolved": "https://registry.npmjs.org/colour/-/colour-0.7.1.tgz", 372 | "integrity": "sha1-nLFpkX7F0SwHNtPoaFdG3xyt93g=" 373 | }, 374 | "concat-map": { 375 | "version": "0.0.1", 376 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 377 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 378 | }, 379 | "core-js": { 380 | "version": "2.5.5", 381 | "resolved": "http://registry.npmjs.org/core-js/-/core-js-2.5.5.tgz", 382 | "integrity": "sha1-sU3ek2xkDAV5prUMq8wTLdYSfjs=" 383 | }, 384 | "cosmiconfig": { 385 | "version": "5.2.1", 386 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.1.tgz", 387 | "integrity": "sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA==", 388 | "dev": true, 389 | "requires": { 390 | "import-fresh": "^2.0.0", 391 | "is-directory": "^0.3.1", 392 | "js-yaml": "^3.13.1", 393 | "parse-json": "^4.0.0" 394 | } 395 | }, 396 | "cross-spawn": { 397 | "version": "6.0.5", 398 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 399 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 400 | "dev": true, 401 | "requires": { 402 | "nice-try": "^1.0.4", 403 | "path-key": "^2.0.1", 404 | "semver": "^5.5.0", 405 | "shebang-command": "^1.2.0", 406 | "which": "^1.2.9" 407 | } 408 | }, 409 | "decamelize": { 410 | "version": "1.2.0", 411 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 412 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 413 | }, 414 | "defaults": { 415 | "version": "1.0.3", 416 | "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.3.tgz", 417 | "integrity": "sha1-xlYFHpgX2f8I7YgUd/P+QBnz730=", 418 | "requires": { 419 | "clone": "^1.0.2" 420 | } 421 | }, 422 | "dom-storage": { 423 | "version": "2.1.0", 424 | "resolved": "https://registry.npmjs.org/dom-storage/-/dom-storage-2.1.0.tgz", 425 | "integrity": "sha512-g6RpyWXzl0RR6OTElHKBl7nwnK87GUyZMYC7JWsB/IA73vpqK2K6LT39x4VepLxlSsWBFrPVLnsSR5Jyty0+2Q==" 426 | }, 427 | "easygraphql-parser": { 428 | "version": "0.0.2", 429 | "resolved": "https://registry.npmjs.org/easygraphql-parser/-/easygraphql-parser-0.0.2.tgz", 430 | "integrity": "sha512-NF3MyA5q6gUomX1p7yYZj8li4JCx9vyR8I7FfrmNQK+SIfFJE7KePM7N17NmIvKUT9/jY62hVsH6586hAWMVfw==", 431 | "requires": { 432 | "graphql": "^14.0.2", 433 | "lodash.mergewith": "^4.6.1" 434 | } 435 | }, 436 | "encoding": { 437 | "version": "0.1.12", 438 | "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.12.tgz", 439 | "integrity": "sha1-U4tm8+5izRq1HsMjgp0flIDHS+s=", 440 | "requires": { 441 | "iconv-lite": "~0.4.13" 442 | } 443 | }, 444 | "end-of-stream": { 445 | "version": "1.4.4", 446 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 447 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 448 | "dev": true, 449 | "requires": { 450 | "once": "^1.4.0" 451 | } 452 | }, 453 | "error-ex": { 454 | "version": "1.3.2", 455 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 456 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 457 | "dev": true, 458 | "requires": { 459 | "is-arrayish": "^0.2.1" 460 | } 461 | }, 462 | "escape-string-regexp": { 463 | "version": "1.0.5", 464 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 465 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 466 | }, 467 | "esprima": { 468 | "version": "4.0.1", 469 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 470 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 471 | "dev": true 472 | }, 473 | "esutils": { 474 | "version": "2.0.3", 475 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 476 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 477 | "dev": true 478 | }, 479 | "execa": { 480 | "version": "0.8.0", 481 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.8.0.tgz", 482 | "integrity": "sha1-2NdrvBtVIX7RkP1t1J08d07PyNo=", 483 | "requires": { 484 | "cross-spawn": "^5.0.1", 485 | "get-stream": "^3.0.0", 486 | "is-stream": "^1.1.0", 487 | "npm-run-path": "^2.0.0", 488 | "p-finally": "^1.0.0", 489 | "signal-exit": "^3.0.0", 490 | "strip-eof": "^1.0.0" 491 | }, 492 | "dependencies": { 493 | "cross-spawn": { 494 | "version": "5.1.0", 495 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 496 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 497 | "requires": { 498 | "lru-cache": "^4.0.1", 499 | "shebang-command": "^1.2.0", 500 | "which": "^1.2.9" 501 | } 502 | } 503 | } 504 | }, 505 | "external-editor": { 506 | "version": "3.0.3", 507 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 508 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 509 | "requires": { 510 | "chardet": "^0.7.0", 511 | "iconv-lite": "^0.4.24", 512 | "tmp": "^0.0.33" 513 | } 514 | }, 515 | "faye-websocket": { 516 | "version": "0.11.1", 517 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.1.tgz", 518 | "integrity": "sha1-8O/hjE9W5PQK/H4Gxxn9XuYYjzg=", 519 | "requires": { 520 | "websocket-driver": ">=0.5.1" 521 | } 522 | }, 523 | "figures": { 524 | "version": "2.0.0", 525 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 526 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 527 | "requires": { 528 | "escape-string-regexp": "^1.0.5" 529 | } 530 | }, 531 | "find-up": { 532 | "version": "4.1.0", 533 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 534 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 535 | "dev": true, 536 | "requires": { 537 | "locate-path": "^5.0.0", 538 | "path-exists": "^4.0.0" 539 | } 540 | }, 541 | "firebase": { 542 | "version": "5.7.0", 543 | "resolved": "https://registry.npmjs.org/firebase/-/firebase-5.7.0.tgz", 544 | "integrity": "sha512-8sQYXCUbUuzpyZS+XpBogstQE/7lvX6tPWtrUH0Cf4mH7flH/Sue5GUvZzwBpkgKOrMpI+clzuoYm/ffGi/TjQ==", 545 | "requires": { 546 | "@firebase/app": "0.3.5", 547 | "@firebase/auth": "0.9.0", 548 | "@firebase/database": "0.3.7", 549 | "@firebase/firestore": "0.9.0", 550 | "@firebase/functions": "0.3.3", 551 | "@firebase/messaging": "0.3.7", 552 | "@firebase/polyfill": "0.3.3", 553 | "@firebase/storage": "0.2.4" 554 | } 555 | }, 556 | "fs-extra": { 557 | "version": "7.0.1", 558 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", 559 | "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", 560 | "requires": { 561 | "graceful-fs": "^4.1.2", 562 | "jsonfile": "^4.0.0", 563 | "universalify": "^0.1.0" 564 | } 565 | }, 566 | "fs.realpath": { 567 | "version": "1.0.0", 568 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 569 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 570 | }, 571 | "get-stdin": { 572 | "version": "7.0.0", 573 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-7.0.0.tgz", 574 | "integrity": "sha512-zRKcywvrXlXsA0v0i9Io4KDRaAw7+a1ZpjRwl9Wox8PFlVCCHra7E9c4kqXCoCM9nR5tBkaTTZRBoCm60bFqTQ==", 575 | "dev": true 576 | }, 577 | "get-stream": { 578 | "version": "3.0.0", 579 | "resolved": "http://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 580 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=" 581 | }, 582 | "glob": { 583 | "version": "7.1.3", 584 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 585 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 586 | "requires": { 587 | "fs.realpath": "^1.0.0", 588 | "inflight": "^1.0.4", 589 | "inherits": "2", 590 | "minimatch": "^3.0.4", 591 | "once": "^1.3.0", 592 | "path-is-absolute": "^1.0.0" 593 | } 594 | }, 595 | "graceful-fs": { 596 | "version": "4.1.15", 597 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 598 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==" 599 | }, 600 | "graphql": { 601 | "version": "14.0.2", 602 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-14.0.2.tgz", 603 | "integrity": "sha512-gUC4YYsaiSJT1h40krG3J+USGlwhzNTXSb4IOZljn9ag5Tj+RkoXrWp+Kh7WyE3t1NCfab5kzCuxBIvOMERMXw==", 604 | "requires": { 605 | "iterall": "^1.2.2" 606 | } 607 | }, 608 | "grpc": { 609 | "version": "1.16.1", 610 | "resolved": "https://registry.npmjs.org/grpc/-/grpc-1.16.1.tgz", 611 | "integrity": "sha512-7uHN1Nd3UqfvwgQ6f5U3+EZb/0iuHJ9mbPH+ydaTkszJsUi3nwdz6DuSh0eJwYVXXn6Gojv2khiQAadMongGKg==", 612 | "requires": { 613 | "lodash": "^4.17.5", 614 | "nan": "^2.0.0", 615 | "node-pre-gyp": "^0.12.0", 616 | "protobufjs": "^5.0.3" 617 | }, 618 | "dependencies": { 619 | "abbrev": { 620 | "version": "1.1.1", 621 | "bundled": true 622 | }, 623 | "ansi-regex": { 624 | "version": "2.1.1", 625 | "bundled": true 626 | }, 627 | "aproba": { 628 | "version": "1.2.0", 629 | "bundled": true 630 | }, 631 | "are-we-there-yet": { 632 | "version": "1.1.5", 633 | "bundled": true, 634 | "requires": { 635 | "delegates": "^1.0.0", 636 | "readable-stream": "^2.0.6" 637 | } 638 | }, 639 | "balanced-match": { 640 | "version": "1.0.0", 641 | "bundled": true 642 | }, 643 | "brace-expansion": { 644 | "version": "1.1.11", 645 | "bundled": true, 646 | "requires": { 647 | "balanced-match": "^1.0.0", 648 | "concat-map": "0.0.1" 649 | } 650 | }, 651 | "chownr": { 652 | "version": "1.1.1", 653 | "bundled": true 654 | }, 655 | "code-point-at": { 656 | "version": "1.1.0", 657 | "bundled": true 658 | }, 659 | "concat-map": { 660 | "version": "0.0.1", 661 | "bundled": true 662 | }, 663 | "console-control-strings": { 664 | "version": "1.1.0", 665 | "bundled": true 666 | }, 667 | "core-util-is": { 668 | "version": "1.0.2", 669 | "bundled": true 670 | }, 671 | "debug": { 672 | "version": "2.6.9", 673 | "bundled": true, 674 | "requires": { 675 | "ms": "2.0.0" 676 | } 677 | }, 678 | "deep-extend": { 679 | "version": "0.6.0", 680 | "bundled": true 681 | }, 682 | "delegates": { 683 | "version": "1.0.0", 684 | "bundled": true 685 | }, 686 | "detect-libc": { 687 | "version": "1.0.3", 688 | "bundled": true 689 | }, 690 | "fs-minipass": { 691 | "version": "1.2.5", 692 | "bundled": true, 693 | "requires": { 694 | "minipass": "^2.2.1" 695 | } 696 | }, 697 | "fs.realpath": { 698 | "version": "1.0.0", 699 | "bundled": true 700 | }, 701 | "gauge": { 702 | "version": "2.7.4", 703 | "bundled": true, 704 | "requires": { 705 | "aproba": "^1.0.3", 706 | "console-control-strings": "^1.0.0", 707 | "has-unicode": "^2.0.0", 708 | "object-assign": "^4.1.0", 709 | "signal-exit": "^3.0.0", 710 | "string-width": "^1.0.1", 711 | "strip-ansi": "^3.0.1", 712 | "wide-align": "^1.1.0" 713 | } 714 | }, 715 | "glob": { 716 | "version": "7.1.3", 717 | "bundled": true, 718 | "requires": { 719 | "fs.realpath": "^1.0.0", 720 | "inflight": "^1.0.4", 721 | "inherits": "2", 722 | "minimatch": "^3.0.4", 723 | "once": "^1.3.0", 724 | "path-is-absolute": "^1.0.0" 725 | } 726 | }, 727 | "has-unicode": { 728 | "version": "2.0.1", 729 | "bundled": true 730 | }, 731 | "iconv-lite": { 732 | "version": "0.4.24", 733 | "bundled": true, 734 | "requires": { 735 | "safer-buffer": ">= 2.1.2 < 3" 736 | } 737 | }, 738 | "ignore-walk": { 739 | "version": "3.0.1", 740 | "bundled": true, 741 | "requires": { 742 | "minimatch": "^3.0.4" 743 | } 744 | }, 745 | "inflight": { 746 | "version": "1.0.6", 747 | "bundled": true, 748 | "requires": { 749 | "once": "^1.3.0", 750 | "wrappy": "1" 751 | } 752 | }, 753 | "inherits": { 754 | "version": "2.0.3", 755 | "bundled": true 756 | }, 757 | "ini": { 758 | "version": "1.3.5", 759 | "bundled": true 760 | }, 761 | "is-fullwidth-code-point": { 762 | "version": "1.0.0", 763 | "bundled": true, 764 | "requires": { 765 | "number-is-nan": "^1.0.0" 766 | } 767 | }, 768 | "isarray": { 769 | "version": "1.0.0", 770 | "bundled": true 771 | }, 772 | "minimatch": { 773 | "version": "3.0.4", 774 | "bundled": true, 775 | "requires": { 776 | "brace-expansion": "^1.1.7" 777 | } 778 | }, 779 | "minimist": { 780 | "version": "1.2.0", 781 | "bundled": true 782 | }, 783 | "minipass": { 784 | "version": "2.3.5", 785 | "bundled": true, 786 | "requires": { 787 | "safe-buffer": "^5.1.2", 788 | "yallist": "^3.0.0" 789 | } 790 | }, 791 | "minizlib": { 792 | "version": "1.1.1", 793 | "bundled": true, 794 | "requires": { 795 | "minipass": "^2.2.1" 796 | } 797 | }, 798 | "mkdirp": { 799 | "version": "0.5.1", 800 | "bundled": true, 801 | "requires": { 802 | "minimist": "0.0.8" 803 | }, 804 | "dependencies": { 805 | "minimist": { 806 | "version": "0.0.8", 807 | "bundled": true 808 | } 809 | } 810 | }, 811 | "ms": { 812 | "version": "2.0.0", 813 | "bundled": true 814 | }, 815 | "needle": { 816 | "version": "2.2.4", 817 | "bundled": true, 818 | "requires": { 819 | "debug": "^2.1.2", 820 | "iconv-lite": "^0.4.4", 821 | "sax": "^1.2.4" 822 | } 823 | }, 824 | "node-pre-gyp": { 825 | "version": "0.12.0", 826 | "bundled": true, 827 | "requires": { 828 | "detect-libc": "^1.0.2", 829 | "mkdirp": "^0.5.1", 830 | "needle": "^2.2.1", 831 | "nopt": "^4.0.1", 832 | "npm-packlist": "^1.1.6", 833 | "npmlog": "^4.0.2", 834 | "rc": "^1.2.7", 835 | "rimraf": "^2.6.1", 836 | "semver": "^5.3.0", 837 | "tar": "^4" 838 | } 839 | }, 840 | "nopt": { 841 | "version": "4.0.1", 842 | "bundled": true, 843 | "requires": { 844 | "abbrev": "1", 845 | "osenv": "^0.1.4" 846 | } 847 | }, 848 | "npm-bundled": { 849 | "version": "1.0.5", 850 | "bundled": true 851 | }, 852 | "npm-packlist": { 853 | "version": "1.1.12", 854 | "bundled": true, 855 | "requires": { 856 | "ignore-walk": "^3.0.1", 857 | "npm-bundled": "^1.0.1" 858 | } 859 | }, 860 | "npmlog": { 861 | "version": "4.1.2", 862 | "bundled": true, 863 | "requires": { 864 | "are-we-there-yet": "~1.1.2", 865 | "console-control-strings": "~1.1.0", 866 | "gauge": "~2.7.3", 867 | "set-blocking": "~2.0.0" 868 | } 869 | }, 870 | "number-is-nan": { 871 | "version": "1.0.1", 872 | "bundled": true 873 | }, 874 | "object-assign": { 875 | "version": "4.1.1", 876 | "bundled": true 877 | }, 878 | "once": { 879 | "version": "1.4.0", 880 | "bundled": true, 881 | "requires": { 882 | "wrappy": "1" 883 | } 884 | }, 885 | "os-homedir": { 886 | "version": "1.0.2", 887 | "bundled": true 888 | }, 889 | "os-tmpdir": { 890 | "version": "1.0.2", 891 | "bundled": true 892 | }, 893 | "osenv": { 894 | "version": "0.1.5", 895 | "bundled": true, 896 | "requires": { 897 | "os-homedir": "^1.0.0", 898 | "os-tmpdir": "^1.0.0" 899 | } 900 | }, 901 | "path-is-absolute": { 902 | "version": "1.0.1", 903 | "bundled": true 904 | }, 905 | "process-nextick-args": { 906 | "version": "2.0.0", 907 | "bundled": true 908 | }, 909 | "rc": { 910 | "version": "1.2.8", 911 | "bundled": true, 912 | "requires": { 913 | "deep-extend": "^0.6.0", 914 | "ini": "~1.3.0", 915 | "minimist": "^1.2.0", 916 | "strip-json-comments": "~2.0.1" 917 | } 918 | }, 919 | "readable-stream": { 920 | "version": "2.3.6", 921 | "bundled": true, 922 | "requires": { 923 | "core-util-is": "~1.0.0", 924 | "inherits": "~2.0.3", 925 | "isarray": "~1.0.0", 926 | "process-nextick-args": "~2.0.0", 927 | "safe-buffer": "~5.1.1", 928 | "string_decoder": "~1.1.1", 929 | "util-deprecate": "~1.0.1" 930 | } 931 | }, 932 | "rimraf": { 933 | "version": "2.6.2", 934 | "bundled": true, 935 | "requires": { 936 | "glob": "^7.0.5" 937 | } 938 | }, 939 | "safe-buffer": { 940 | "version": "5.1.2", 941 | "bundled": true 942 | }, 943 | "safer-buffer": { 944 | "version": "2.1.2", 945 | "bundled": true 946 | }, 947 | "sax": { 948 | "version": "1.2.4", 949 | "bundled": true 950 | }, 951 | "semver": { 952 | "version": "5.6.0", 953 | "bundled": true 954 | }, 955 | "set-blocking": { 956 | "version": "2.0.0", 957 | "bundled": true 958 | }, 959 | "signal-exit": { 960 | "version": "3.0.2", 961 | "bundled": true 962 | }, 963 | "string-width": { 964 | "version": "1.0.2", 965 | "bundled": true, 966 | "requires": { 967 | "code-point-at": "^1.0.0", 968 | "is-fullwidth-code-point": "^1.0.0", 969 | "strip-ansi": "^3.0.0" 970 | } 971 | }, 972 | "string_decoder": { 973 | "version": "1.1.1", 974 | "bundled": true, 975 | "requires": { 976 | "safe-buffer": "~5.1.0" 977 | } 978 | }, 979 | "strip-ansi": { 980 | "version": "3.0.1", 981 | "bundled": true, 982 | "requires": { 983 | "ansi-regex": "^2.0.0" 984 | } 985 | }, 986 | "strip-json-comments": { 987 | "version": "2.0.1", 988 | "bundled": true 989 | }, 990 | "tar": { 991 | "version": "4.4.8", 992 | "bundled": true, 993 | "requires": { 994 | "chownr": "^1.1.1", 995 | "fs-minipass": "^1.2.5", 996 | "minipass": "^2.3.4", 997 | "minizlib": "^1.1.1", 998 | "mkdirp": "^0.5.0", 999 | "safe-buffer": "^5.1.2", 1000 | "yallist": "^3.0.2" 1001 | } 1002 | }, 1003 | "util-deprecate": { 1004 | "version": "1.0.2", 1005 | "bundled": true 1006 | }, 1007 | "wide-align": { 1008 | "version": "1.1.3", 1009 | "bundled": true, 1010 | "requires": { 1011 | "string-width": "^1.0.2 || 2" 1012 | } 1013 | }, 1014 | "wrappy": { 1015 | "version": "1.0.2", 1016 | "bundled": true 1017 | }, 1018 | "yallist": { 1019 | "version": "3.0.2", 1020 | "bundled": true 1021 | } 1022 | } 1023 | }, 1024 | "has-flag": { 1025 | "version": "3.0.0", 1026 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1027 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 1028 | }, 1029 | "hosted-git-info": { 1030 | "version": "2.8.5", 1031 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.5.tgz", 1032 | "integrity": "sha512-kssjab8CvdXfcXMXVcvsXum4Hwdq9XGtRD3TteMEvEbq0LXyiNQr6AprqKqfeaDXze7SxWvRxdpwE6ku7ikLkg==", 1033 | "dev": true 1034 | }, 1035 | "http-parser-js": { 1036 | "version": "0.5.0", 1037 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.0.tgz", 1038 | "integrity": "sha512-cZdEF7r4gfRIq7ezX9J0T+kQmJNOub71dWbgAXVHDct80TKP4MCETtZQ31xyv38UwgzkWPYF/Xc0ge55dW9Z9w==" 1039 | }, 1040 | "husky": { 1041 | "version": "3.0.8", 1042 | "resolved": "https://registry.npmjs.org/husky/-/husky-3.0.8.tgz", 1043 | "integrity": "sha512-HFOsgcyrX3qe/rBuqyTt+P4Gxn5P0seJmr215LAZ/vnwK3jWB3r0ck7swbzGRUbufCf9w/lgHPVbF/YXQALgfQ==", 1044 | "dev": true, 1045 | "requires": { 1046 | "chalk": "^2.4.2", 1047 | "cosmiconfig": "^5.2.1", 1048 | "execa": "^1.0.0", 1049 | "get-stdin": "^7.0.0", 1050 | "is-ci": "^2.0.0", 1051 | "opencollective-postinstall": "^2.0.2", 1052 | "pkg-dir": "^4.2.0", 1053 | "please-upgrade-node": "^3.2.0", 1054 | "read-pkg": "^5.1.1", 1055 | "run-node": "^1.0.0", 1056 | "slash": "^3.0.0" 1057 | }, 1058 | "dependencies": { 1059 | "chalk": { 1060 | "version": "2.4.2", 1061 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1062 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1063 | "dev": true, 1064 | "requires": { 1065 | "ansi-styles": "^3.2.1", 1066 | "escape-string-regexp": "^1.0.5", 1067 | "supports-color": "^5.3.0" 1068 | } 1069 | }, 1070 | "execa": { 1071 | "version": "1.0.0", 1072 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", 1073 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", 1074 | "dev": true, 1075 | "requires": { 1076 | "cross-spawn": "^6.0.0", 1077 | "get-stream": "^4.0.0", 1078 | "is-stream": "^1.1.0", 1079 | "npm-run-path": "^2.0.0", 1080 | "p-finally": "^1.0.0", 1081 | "signal-exit": "^3.0.0", 1082 | "strip-eof": "^1.0.0" 1083 | } 1084 | }, 1085 | "get-stream": { 1086 | "version": "4.1.0", 1087 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 1088 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 1089 | "dev": true, 1090 | "requires": { 1091 | "pump": "^3.0.0" 1092 | } 1093 | } 1094 | } 1095 | }, 1096 | "iconv-lite": { 1097 | "version": "0.4.24", 1098 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1099 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1100 | "requires": { 1101 | "safer-buffer": ">= 2.1.2 < 3" 1102 | } 1103 | }, 1104 | "import-fresh": { 1105 | "version": "2.0.0", 1106 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", 1107 | "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", 1108 | "dev": true, 1109 | "requires": { 1110 | "caller-path": "^2.0.0", 1111 | "resolve-from": "^3.0.0" 1112 | } 1113 | }, 1114 | "inflight": { 1115 | "version": "1.0.6", 1116 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1117 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1118 | "requires": { 1119 | "once": "^1.3.0", 1120 | "wrappy": "1" 1121 | } 1122 | }, 1123 | "inherits": { 1124 | "version": "2.0.3", 1125 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1126 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1127 | }, 1128 | "inquirer": { 1129 | "version": "6.2.1", 1130 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.1.tgz", 1131 | "integrity": "sha512-088kl3DRT2dLU5riVMKKr1DlImd6X7smDhpXUCkJDCKvTEJeRiXh0G132HG9u5a+6Ylw9plFRY7RuTnwohYSpg==", 1132 | "requires": { 1133 | "ansi-escapes": "^3.0.0", 1134 | "chalk": "^2.0.0", 1135 | "cli-cursor": "^2.1.0", 1136 | "cli-width": "^2.0.0", 1137 | "external-editor": "^3.0.0", 1138 | "figures": "^2.0.0", 1139 | "lodash": "^4.17.10", 1140 | "mute-stream": "0.0.7", 1141 | "run-async": "^2.2.0", 1142 | "rxjs": "^6.1.0", 1143 | "string-width": "^2.1.0", 1144 | "strip-ansi": "^5.0.0", 1145 | "through": "^2.3.6" 1146 | }, 1147 | "dependencies": { 1148 | "ansi-regex": { 1149 | "version": "3.0.0", 1150 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1151 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 1152 | }, 1153 | "is-fullwidth-code-point": { 1154 | "version": "2.0.0", 1155 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1156 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 1157 | }, 1158 | "string-width": { 1159 | "version": "2.1.1", 1160 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1161 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1162 | "requires": { 1163 | "is-fullwidth-code-point": "^2.0.0", 1164 | "strip-ansi": "^4.0.0" 1165 | }, 1166 | "dependencies": { 1167 | "strip-ansi": { 1168 | "version": "4.0.0", 1169 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1170 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1171 | "requires": { 1172 | "ansi-regex": "^3.0.0" 1173 | } 1174 | } 1175 | } 1176 | }, 1177 | "strip-ansi": { 1178 | "version": "5.0.0", 1179 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", 1180 | "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", 1181 | "requires": { 1182 | "ansi-regex": "^4.0.0" 1183 | }, 1184 | "dependencies": { 1185 | "ansi-regex": { 1186 | "version": "4.0.0", 1187 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", 1188 | "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==" 1189 | } 1190 | } 1191 | } 1192 | } 1193 | }, 1194 | "invert-kv": { 1195 | "version": "1.0.0", 1196 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", 1197 | "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=" 1198 | }, 1199 | "is-arrayish": { 1200 | "version": "0.2.1", 1201 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1202 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1203 | "dev": true 1204 | }, 1205 | "is-ci": { 1206 | "version": "2.0.0", 1207 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 1208 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 1209 | "dev": true, 1210 | "requires": { 1211 | "ci-info": "^2.0.0" 1212 | } 1213 | }, 1214 | "is-directory": { 1215 | "version": "0.3.1", 1216 | "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", 1217 | "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", 1218 | "dev": true 1219 | }, 1220 | "is-fullwidth-code-point": { 1221 | "version": "1.0.0", 1222 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1223 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1224 | "requires": { 1225 | "number-is-nan": "^1.0.0" 1226 | } 1227 | }, 1228 | "is-promise": { 1229 | "version": "2.1.0", 1230 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1231 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 1232 | }, 1233 | "is-stream": { 1234 | "version": "1.1.0", 1235 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1236 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 1237 | }, 1238 | "isexe": { 1239 | "version": "2.0.0", 1240 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1241 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1242 | }, 1243 | "isomorphic-fetch": { 1244 | "version": "2.2.1", 1245 | "resolved": "https://registry.npmjs.org/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz", 1246 | "integrity": "sha1-YRrhrPFPXoH3KVB0coGf6XM1WKk=", 1247 | "requires": { 1248 | "node-fetch": "^1.0.1", 1249 | "whatwg-fetch": ">=0.10.0" 1250 | } 1251 | }, 1252 | "iterall": { 1253 | "version": "1.2.2", 1254 | "resolved": "https://registry.npmjs.org/iterall/-/iterall-1.2.2.tgz", 1255 | "integrity": "sha512-yynBb1g+RFUPY64fTrFv7nsjRrENBQJaX2UL+2Szc9REFrSNm1rpSXHGzhmAy7a9uv3vlvgBlXnf9RqmPH1/DA==" 1256 | }, 1257 | "js-tokens": { 1258 | "version": "4.0.0", 1259 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1260 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1261 | "dev": true 1262 | }, 1263 | "js-yaml": { 1264 | "version": "3.13.1", 1265 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1266 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1267 | "dev": true, 1268 | "requires": { 1269 | "argparse": "^1.0.7", 1270 | "esprima": "^4.0.0" 1271 | } 1272 | }, 1273 | "json-parse-better-errors": { 1274 | "version": "1.0.2", 1275 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1276 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1277 | "dev": true 1278 | }, 1279 | "jsonfile": { 1280 | "version": "4.0.0", 1281 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 1282 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 1283 | "requires": { 1284 | "graceful-fs": "^4.1.6" 1285 | } 1286 | }, 1287 | "lcid": { 1288 | "version": "1.0.0", 1289 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", 1290 | "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", 1291 | "requires": { 1292 | "invert-kv": "^1.0.0" 1293 | } 1294 | }, 1295 | "lines-and-columns": { 1296 | "version": "1.1.6", 1297 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", 1298 | "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", 1299 | "dev": true 1300 | }, 1301 | "locate-path": { 1302 | "version": "5.0.0", 1303 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 1304 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1305 | "dev": true, 1306 | "requires": { 1307 | "p-locate": "^4.1.0" 1308 | } 1309 | }, 1310 | "lodash": { 1311 | "version": "4.17.11", 1312 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1313 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 1314 | }, 1315 | "lodash.mergewith": { 1316 | "version": "4.6.1", 1317 | "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.1.tgz", 1318 | "integrity": "sha512-eWw5r+PYICtEBgrBE5hhlT6aAa75f411bgDz/ZL2KZqYV03USvucsxcHUIlGTDTECs1eunpI7HOV7U+WLDvNdQ==" 1319 | }, 1320 | "log-symbols": { 1321 | "version": "2.2.0", 1322 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", 1323 | "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", 1324 | "requires": { 1325 | "chalk": "^2.0.1" 1326 | } 1327 | }, 1328 | "long": { 1329 | "version": "3.2.0", 1330 | "resolved": "https://registry.npmjs.org/long/-/long-3.2.0.tgz", 1331 | "integrity": "sha1-2CG3E4yhy1gcFymQ7xTbIAtcR0s=" 1332 | }, 1333 | "lru-cache": { 1334 | "version": "4.1.5", 1335 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 1336 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 1337 | "requires": { 1338 | "pseudomap": "^1.0.2", 1339 | "yallist": "^2.1.2" 1340 | } 1341 | }, 1342 | "mimic-fn": { 1343 | "version": "1.2.0", 1344 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1345 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==" 1346 | }, 1347 | "minimatch": { 1348 | "version": "3.0.4", 1349 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1350 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1351 | "requires": { 1352 | "brace-expansion": "^1.1.7" 1353 | } 1354 | }, 1355 | "minimist": { 1356 | "version": "1.2.0", 1357 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1358 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 1359 | }, 1360 | "mute-stream": { 1361 | "version": "0.0.7", 1362 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1363 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=" 1364 | }, 1365 | "nan": { 1366 | "version": "2.11.1", 1367 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.11.1.tgz", 1368 | "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA==" 1369 | }, 1370 | "nice-try": { 1371 | "version": "1.0.5", 1372 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1373 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1374 | "dev": true 1375 | }, 1376 | "node-fetch": { 1377 | "version": "1.7.3", 1378 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-1.7.3.tgz", 1379 | "integrity": "sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ==", 1380 | "requires": { 1381 | "encoding": "^0.1.11", 1382 | "is-stream": "^1.0.1" 1383 | } 1384 | }, 1385 | "normalize-package-data": { 1386 | "version": "2.5.0", 1387 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1388 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1389 | "dev": true, 1390 | "requires": { 1391 | "hosted-git-info": "^2.1.4", 1392 | "resolve": "^1.10.0", 1393 | "semver": "2 || 3 || 4 || 5", 1394 | "validate-npm-package-license": "^3.0.1" 1395 | } 1396 | }, 1397 | "npm-run-path": { 1398 | "version": "2.0.2", 1399 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1400 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1401 | "requires": { 1402 | "path-key": "^2.0.0" 1403 | } 1404 | }, 1405 | "number-is-nan": { 1406 | "version": "1.0.1", 1407 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1408 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1409 | }, 1410 | "once": { 1411 | "version": "1.4.0", 1412 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1413 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1414 | "requires": { 1415 | "wrappy": "1" 1416 | } 1417 | }, 1418 | "onetime": { 1419 | "version": "2.0.1", 1420 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1421 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1422 | "requires": { 1423 | "mimic-fn": "^1.0.0" 1424 | } 1425 | }, 1426 | "opencollective-postinstall": { 1427 | "version": "2.0.2", 1428 | "resolved": "https://registry.npmjs.org/opencollective-postinstall/-/opencollective-postinstall-2.0.2.tgz", 1429 | "integrity": "sha512-pVOEP16TrAO2/fjej1IdOyupJY8KDUM1CvsaScRbw6oddvpQoOfGk4ywha0HKKVAD6RkW4x6Q+tNBwhf3Bgpuw==", 1430 | "dev": true 1431 | }, 1432 | "optjs": { 1433 | "version": "3.2.2", 1434 | "resolved": "https://registry.npmjs.org/optjs/-/optjs-3.2.2.tgz", 1435 | "integrity": "sha1-aabOicRCpEQDFBrS+bNwvVu29O4=" 1436 | }, 1437 | "ora": { 1438 | "version": "3.0.0", 1439 | "resolved": "https://registry.npmjs.org/ora/-/ora-3.0.0.tgz", 1440 | "integrity": "sha512-LBS97LFe2RV6GJmXBi6OKcETKyklHNMV0xw7BtsVn2MlsgsydyZetSCbCANr+PFLmDyv4KV88nn0eCKza665Mg==", 1441 | "requires": { 1442 | "chalk": "^2.3.1", 1443 | "cli-cursor": "^2.1.0", 1444 | "cli-spinners": "^1.1.0", 1445 | "log-symbols": "^2.2.0", 1446 | "strip-ansi": "^4.0.0", 1447 | "wcwidth": "^1.0.1" 1448 | }, 1449 | "dependencies": { 1450 | "ansi-regex": { 1451 | "version": "3.0.0", 1452 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1453 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 1454 | }, 1455 | "strip-ansi": { 1456 | "version": "4.0.0", 1457 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1458 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1459 | "requires": { 1460 | "ansi-regex": "^3.0.0" 1461 | } 1462 | } 1463 | } 1464 | }, 1465 | "os-locale": { 1466 | "version": "1.4.0", 1467 | "resolved": "http://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", 1468 | "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", 1469 | "requires": { 1470 | "lcid": "^1.0.0" 1471 | } 1472 | }, 1473 | "os-tmpdir": { 1474 | "version": "1.0.2", 1475 | "resolved": "http://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1476 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1477 | }, 1478 | "p-finally": { 1479 | "version": "1.0.0", 1480 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1481 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" 1482 | }, 1483 | "p-limit": { 1484 | "version": "2.2.1", 1485 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", 1486 | "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", 1487 | "dev": true, 1488 | "requires": { 1489 | "p-try": "^2.0.0" 1490 | } 1491 | }, 1492 | "p-locate": { 1493 | "version": "4.1.0", 1494 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 1495 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 1496 | "dev": true, 1497 | "requires": { 1498 | "p-limit": "^2.2.0" 1499 | } 1500 | }, 1501 | "p-try": { 1502 | "version": "2.2.0", 1503 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1504 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1505 | "dev": true 1506 | }, 1507 | "parse-json": { 1508 | "version": "4.0.0", 1509 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1510 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1511 | "dev": true, 1512 | "requires": { 1513 | "error-ex": "^1.3.1", 1514 | "json-parse-better-errors": "^1.0.1" 1515 | } 1516 | }, 1517 | "path-exists": { 1518 | "version": "4.0.0", 1519 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1520 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1521 | "dev": true 1522 | }, 1523 | "path-is-absolute": { 1524 | "version": "1.0.1", 1525 | "resolved": "http://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1526 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1527 | }, 1528 | "path-key": { 1529 | "version": "2.0.1", 1530 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1531 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 1532 | }, 1533 | "path-parse": { 1534 | "version": "1.0.6", 1535 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1536 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1537 | "dev": true 1538 | }, 1539 | "pkg-dir": { 1540 | "version": "4.2.0", 1541 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 1542 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 1543 | "dev": true, 1544 | "requires": { 1545 | "find-up": "^4.0.0" 1546 | } 1547 | }, 1548 | "please-upgrade-node": { 1549 | "version": "3.2.0", 1550 | "resolved": "https://registry.npmjs.org/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz", 1551 | "integrity": "sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg==", 1552 | "dev": true, 1553 | "requires": { 1554 | "semver-compare": "^1.0.0" 1555 | } 1556 | }, 1557 | "prettier": { 1558 | "version": "1.18.2", 1559 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.18.2.tgz", 1560 | "integrity": "sha512-OeHeMc0JhFE9idD4ZdtNibzY0+TPHSpSSb9h8FqtP+YnoZZ1sl8Vc9b1sasjfymH3SonAF4QcA2+mzHPhMvIiw==", 1561 | "dev": true 1562 | }, 1563 | "promise-polyfill": { 1564 | "version": "7.1.2", 1565 | "resolved": "https://registry.npmjs.org/promise-polyfill/-/promise-polyfill-7.1.2.tgz", 1566 | "integrity": "sha512-FuEc12/eKqqoRYIGBrUptCBRhobL19PS2U31vMNTfyck1FxPyMfgsXyW4Mav85y/ZN1hop3hOwRlUDok23oYfQ==" 1567 | }, 1568 | "protobufjs": { 1569 | "version": "5.0.3", 1570 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-5.0.3.tgz", 1571 | "integrity": "sha512-55Kcx1MhPZX0zTbVosMQEO5R6/rikNXd9b6RQK4KSPcrSIIwoXTtebIczUrXlwaSrbz4x8XUVThGPob1n8I4QA==", 1572 | "requires": { 1573 | "ascli": "~1", 1574 | "bytebuffer": "~5", 1575 | "glob": "^7.0.5", 1576 | "yargs": "^3.10.0" 1577 | } 1578 | }, 1579 | "pseudomap": { 1580 | "version": "1.0.2", 1581 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1582 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1583 | }, 1584 | "pump": { 1585 | "version": "3.0.0", 1586 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1587 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1588 | "dev": true, 1589 | "requires": { 1590 | "end-of-stream": "^1.1.0", 1591 | "once": "^1.3.1" 1592 | } 1593 | }, 1594 | "read-pkg": { 1595 | "version": "5.2.0", 1596 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.2.0.tgz", 1597 | "integrity": "sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==", 1598 | "dev": true, 1599 | "requires": { 1600 | "@types/normalize-package-data": "^2.4.0", 1601 | "normalize-package-data": "^2.5.0", 1602 | "parse-json": "^5.0.0", 1603 | "type-fest": "^0.6.0" 1604 | }, 1605 | "dependencies": { 1606 | "parse-json": { 1607 | "version": "5.0.0", 1608 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.0.0.tgz", 1609 | "integrity": "sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw==", 1610 | "dev": true, 1611 | "requires": { 1612 | "@babel/code-frame": "^7.0.0", 1613 | "error-ex": "^1.3.1", 1614 | "json-parse-better-errors": "^1.0.1", 1615 | "lines-and-columns": "^1.1.6" 1616 | } 1617 | } 1618 | } 1619 | }, 1620 | "resolve": { 1621 | "version": "1.12.0", 1622 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", 1623 | "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", 1624 | "dev": true, 1625 | "requires": { 1626 | "path-parse": "^1.0.6" 1627 | } 1628 | }, 1629 | "resolve-from": { 1630 | "version": "3.0.0", 1631 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", 1632 | "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=", 1633 | "dev": true 1634 | }, 1635 | "restore-cursor": { 1636 | "version": "2.0.0", 1637 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1638 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1639 | "requires": { 1640 | "onetime": "^2.0.0", 1641 | "signal-exit": "^3.0.2" 1642 | } 1643 | }, 1644 | "run-async": { 1645 | "version": "2.3.0", 1646 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1647 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1648 | "requires": { 1649 | "is-promise": "^2.1.0" 1650 | } 1651 | }, 1652 | "run-node": { 1653 | "version": "1.0.0", 1654 | "resolved": "https://registry.npmjs.org/run-node/-/run-node-1.0.0.tgz", 1655 | "integrity": "sha512-kc120TBlQ3mih1LSzdAJXo4xn/GWS2ec0l3S+syHDXP9uRr0JAT8Qd3mdMuyjqCzeZktgP3try92cEgf9Nks8A==", 1656 | "dev": true 1657 | }, 1658 | "rxjs": { 1659 | "version": "6.3.3", 1660 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.3.3.tgz", 1661 | "integrity": "sha512-JTWmoY9tWCs7zvIk/CvRjhjGaOd+OVBM987mxFo+OW66cGpdKjZcpmc74ES1sB//7Kl/PAe8+wEakuhG4pcgOw==", 1662 | "requires": { 1663 | "tslib": "^1.9.0" 1664 | } 1665 | }, 1666 | "safer-buffer": { 1667 | "version": "2.1.2", 1668 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1669 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1670 | }, 1671 | "semver": { 1672 | "version": "5.7.1", 1673 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1674 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1675 | "dev": true 1676 | }, 1677 | "semver-compare": { 1678 | "version": "1.0.0", 1679 | "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", 1680 | "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=", 1681 | "dev": true 1682 | }, 1683 | "shebang-command": { 1684 | "version": "1.2.0", 1685 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1686 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1687 | "requires": { 1688 | "shebang-regex": "^1.0.0" 1689 | } 1690 | }, 1691 | "shebang-regex": { 1692 | "version": "1.0.0", 1693 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1694 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 1695 | }, 1696 | "signal-exit": { 1697 | "version": "3.0.2", 1698 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1699 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 1700 | }, 1701 | "slash": { 1702 | "version": "3.0.0", 1703 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1704 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1705 | "dev": true 1706 | }, 1707 | "spdx-correct": { 1708 | "version": "3.1.0", 1709 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 1710 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 1711 | "dev": true, 1712 | "requires": { 1713 | "spdx-expression-parse": "^3.0.0", 1714 | "spdx-license-ids": "^3.0.0" 1715 | } 1716 | }, 1717 | "spdx-exceptions": { 1718 | "version": "2.2.0", 1719 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 1720 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 1721 | "dev": true 1722 | }, 1723 | "spdx-expression-parse": { 1724 | "version": "3.0.0", 1725 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1726 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1727 | "dev": true, 1728 | "requires": { 1729 | "spdx-exceptions": "^2.1.0", 1730 | "spdx-license-ids": "^3.0.0" 1731 | } 1732 | }, 1733 | "spdx-license-ids": { 1734 | "version": "3.0.5", 1735 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 1736 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 1737 | "dev": true 1738 | }, 1739 | "sprintf-js": { 1740 | "version": "1.0.3", 1741 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1742 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1743 | "dev": true 1744 | }, 1745 | "string-width": { 1746 | "version": "1.0.2", 1747 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1748 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1749 | "requires": { 1750 | "code-point-at": "^1.0.0", 1751 | "is-fullwidth-code-point": "^1.0.0", 1752 | "strip-ansi": "^3.0.0" 1753 | } 1754 | }, 1755 | "strip-ansi": { 1756 | "version": "3.0.1", 1757 | "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1758 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1759 | "requires": { 1760 | "ansi-regex": "^2.0.0" 1761 | } 1762 | }, 1763 | "strip-eof": { 1764 | "version": "1.0.0", 1765 | "resolved": "http://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 1766 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" 1767 | }, 1768 | "supports-color": { 1769 | "version": "5.5.0", 1770 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1771 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1772 | "dev": true, 1773 | "requires": { 1774 | "has-flag": "^3.0.0" 1775 | } 1776 | }, 1777 | "through": { 1778 | "version": "2.3.8", 1779 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 1780 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 1781 | }, 1782 | "tmp": { 1783 | "version": "0.0.33", 1784 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1785 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1786 | "requires": { 1787 | "os-tmpdir": "~1.0.2" 1788 | } 1789 | }, 1790 | "tslib": { 1791 | "version": "1.9.0", 1792 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.0.tgz", 1793 | "integrity": "sha512-f/qGG2tUkrISBlQZEjEqoZ3B2+npJjIf04H1wuAv9iA8i04Icp+61KRXxFdha22670NJopsZCIjhC3SnjPRKrQ==" 1794 | }, 1795 | "type-fest": { 1796 | "version": "0.6.0", 1797 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.6.0.tgz", 1798 | "integrity": "sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==", 1799 | "dev": true 1800 | }, 1801 | "universalify": { 1802 | "version": "0.1.2", 1803 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1804 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" 1805 | }, 1806 | "validate-npm-package-license": { 1807 | "version": "3.0.4", 1808 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1809 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1810 | "dev": true, 1811 | "requires": { 1812 | "spdx-correct": "^3.0.0", 1813 | "spdx-expression-parse": "^3.0.0" 1814 | } 1815 | }, 1816 | "wcwidth": { 1817 | "version": "1.0.1", 1818 | "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", 1819 | "integrity": "sha1-8LDc+RW8X/FSivrbLA4XtTLaL+g=", 1820 | "requires": { 1821 | "defaults": "^1.0.3" 1822 | } 1823 | }, 1824 | "websocket-driver": { 1825 | "version": "0.7.0", 1826 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.0.tgz", 1827 | "integrity": "sha1-DK+dLXVdk67gSdS90NP+LMoqJOs=", 1828 | "requires": { 1829 | "http-parser-js": ">=0.4.0", 1830 | "websocket-extensions": ">=0.1.1" 1831 | } 1832 | }, 1833 | "websocket-extensions": { 1834 | "version": "0.1.3", 1835 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.3.tgz", 1836 | "integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==" 1837 | }, 1838 | "whatwg-fetch": { 1839 | "version": "3.0.0", 1840 | "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-3.0.0.tgz", 1841 | "integrity": "sha512-9GSJUgz1D4MfyKU7KRqwOjXCXTqWdFNvEr7eUBYchQiVc744mqK/MzXPNR2WsPkmkOa4ywfg8C2n8h+13Bey1Q==" 1842 | }, 1843 | "which": { 1844 | "version": "1.3.1", 1845 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1846 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1847 | "requires": { 1848 | "isexe": "^2.0.0" 1849 | } 1850 | }, 1851 | "window-size": { 1852 | "version": "0.1.4", 1853 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.4.tgz", 1854 | "integrity": "sha1-+OGqHuWlPsW/FR/6CXQqatdpeHY=" 1855 | }, 1856 | "wrap-ansi": { 1857 | "version": "2.1.0", 1858 | "resolved": "http://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 1859 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 1860 | "requires": { 1861 | "string-width": "^1.0.1", 1862 | "strip-ansi": "^3.0.1" 1863 | } 1864 | }, 1865 | "wrappy": { 1866 | "version": "1.0.2", 1867 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1868 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1869 | }, 1870 | "xmlhttprequest": { 1871 | "version": "1.8.0", 1872 | "resolved": "https://registry.npmjs.org/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz", 1873 | "integrity": "sha1-Z/4HXFwk/vOfnWX197f+dRcZaPw=" 1874 | }, 1875 | "y18n": { 1876 | "version": "3.2.1", 1877 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", 1878 | "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=" 1879 | }, 1880 | "yallist": { 1881 | "version": "2.1.2", 1882 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 1883 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 1884 | }, 1885 | "yargs": { 1886 | "version": "3.32.0", 1887 | "resolved": "http://registry.npmjs.org/yargs/-/yargs-3.32.0.tgz", 1888 | "integrity": "sha1-AwiOnr+edWtpdRYR0qXvWRSCyZU=", 1889 | "requires": { 1890 | "camelcase": "^2.0.1", 1891 | "cliui": "^3.0.3", 1892 | "decamelize": "^1.1.1", 1893 | "os-locale": "^1.4.0", 1894 | "string-width": "^1.0.1", 1895 | "window-size": "^0.1.4", 1896 | "y18n": "^3.2.0" 1897 | } 1898 | } 1899 | } 1900 | } 1901 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "easygraphql-firebase", 3 | "version": "0.0.4", 4 | "description": "Create GraphQL server connected with Firebase just with a schema.", 5 | "bin": { 6 | "easygraphql-firebase": "./bin/easygraphql-firebase.js" 7 | }, 8 | "scripts": { 9 | "prettier:check": "prettier --write './{bin,commands,util}/**/*.{js,graphql}'", 10 | "prettier:format": "prettier --write './{bin,commands,util}/**/*.{js,graphql}'" 11 | }, 12 | "husky": { 13 | "hooks": { 14 | "pre-commit": "npm run prettier:format && git add ." 15 | } 16 | }, 17 | "homepage": "https://github.com/EasyGraphQL/easygraphql-firebase", 18 | "author": { 19 | "name": "EasyGraphQL", 20 | "url": "https://github.com/EasyGraphQL" 21 | }, 22 | "repository": { 23 | "type": "git", 24 | "url": "https://github.com/EasyGraphQL/easygraphql-firebase" 25 | }, 26 | "bugs": { 27 | "url": "https://github.com/EasyGraphQL/easygraphql-firebase/issues" 28 | }, 29 | "license": "MIT", 30 | "dependencies": { 31 | "clipboardy": "^1.2.3", 32 | "easygraphql-parser": "0.0.2", 33 | "firebase": "^5.7.0", 34 | "fs-extra": "^7.0.1", 35 | "inquirer": "^6.2.1", 36 | "minimist": "^1.2.0", 37 | "ora": "^3.0.0" 38 | }, 39 | "devDependencies": { 40 | "husky": "^3.0.8", 41 | "prettier": "^1.18.2" 42 | } 43 | } -------------------------------------------------------------------------------- /scripts/createPackage.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | npm init -y 3 | npm install -s express cors body-parser express-graphql graphql graphql-tools dotenv firebase 4 | npm install --save-dev easygraphql-tester mocha 5 | -------------------------------------------------------------------------------- /templates/apiFileIndex.txt: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const path = require('path') 4 | const fs = require('fs') 5 | 6 | const schema = fs.readFileSync(path.join(__dirname, 'schema.gql'), 'utf8') 7 | const resolvers = require('./resolvers') 8 | 9 | module.exports = { 10 | typeDefs: schema, 11 | resolvers 12 | } 13 | -------------------------------------------------------------------------------- /templates/starterFile.txt: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const express = require('express') 4 | const cors = require('cors') 5 | const bodyParser = require('body-parser') 6 | const graphqlHTTP = require('express-graphql') 7 | const { makeExecutableSchema } = require('graphql-tools') 8 | const firebaseClient = require('firebase') 9 | 10 | const gqlServerConfig = require('./api') 11 | 12 | if (process.env.NODE_ENV === 'development') { 13 | require('dotenv').config({ path: 'development.env' }) 14 | } 15 | 16 | const app = express() 17 | 18 | app.set('port', process.env.PORT || 7000) 19 | app.use(bodyParser.json({ limit: '10mb' })) 20 | app.use(bodyParser.urlencoded({ extended: true })) 21 | 22 | app.use(cors()) 23 | 24 | const schema = makeExecutableSchema(gqlServerConfig) 25 | 26 | const firebase = firebaseClient.initializeApp({ 27 | apiKey: process.env.FIREBASE_API_KEY, 28 | databaseURL: process.env.FIREBASE_DATABASE_URL 29 | }); 30 | 31 | app.use('/graphql', (req, res) => { 32 | graphqlHTTP({ 33 | schema, 34 | graphiql: true, 35 | context: { firebase } 36 | })(req, res) 37 | }) 38 | 39 | const server = app.listen(app.get('port'), () => { 40 | console.log(`Server running -> PORT ${server.address().port}`) 41 | }) 42 | 43 | module.exports = app 44 | -------------------------------------------------------------------------------- /templates/starterFileGitignore.txt: -------------------------------------------------------------------------------- 1 | # dependencies 2 | /node_modules/ 3 | 4 | # misc 5 | /variables.env -------------------------------------------------------------------------------- /templates/testFileMutation.txt: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const EasyGraphQLTester = require('easygraphql-tester') 4 | const fs = require('fs') 5 | const path = require('path') 6 | 7 | const typeDefs = fs.readFileSync( 8 | path.join(__dirname, '..', 'api', 'schema.gql'), 9 | 'utf8', 10 | ) 11 | 12 | describe('Validate mutation', () => { 13 | let tester 14 | before(() => { 15 | tester = new EasyGraphQLTester(typeDefs) 16 | }) 17 | 18 | const cases = [ 19 | { 20 | name: '', 21 | mutation: `', 23 | input: {} 24 | } 25 | ] 26 | 27 | cases.forEach(({ name, mutation, expected }) => { 28 | it(`Should validate the query: ${name}`, () => tester.test(expected, mutation, input)) 29 | }) 30 | }) 31 | -------------------------------------------------------------------------------- /templates/testFileQuery.txt: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const EasyGraphQLTester = require('easygraphql-tester') 4 | const fs = require('fs') 5 | const path = require('path') 6 | 7 | const typeDefs = fs.readFileSync( 8 | path.join(__dirname, '..', 'api', 'schema.gql'), 9 | 'utf8', 10 | ) 11 | 12 | describe('Validate query', () => { 13 | let tester 14 | before(() => { 15 | tester = new EasyGraphQLTester(typeDefs) 16 | }) 17 | 18 | const cases = [ 19 | { 20 | name: '', 21 | query: `', 23 | } 24 | ] 25 | 26 | cases.forEach(({ name, query, expected }) => { 27 | it(`Should validate the query: ${name}`, () => tester.test(expected, query)) 28 | }) 29 | }) 30 | -------------------------------------------------------------------------------- /util/createApi.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const path = require("path"); 4 | const fs = require("fs-extra"); 5 | 6 | const templatesPath = path.join(__dirname, "..", "templates"); 7 | 8 | function createApp(dirPath) { 9 | try { 10 | const apiDirPath = `${dirPath}/api`; 11 | fs.ensureDirSync(apiDirPath); 12 | createApiIndex(apiDirPath); 13 | } catch (err) { 14 | throw err; 15 | } 16 | } 17 | 18 | function createApiIndex(apiDirPath) { 19 | fs.copySync(`${templatesPath}/apiFileIndex.txt`, `${apiDirPath}/index.js`); 20 | } 21 | 22 | module.exports = createApp; 23 | -------------------------------------------------------------------------------- /util/createApp.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const path = require("path"); 4 | const fs = require("fs-extra"); 5 | const { spawnSync } = require("child_process"); 6 | const templatesPath = path.join(__dirname, "..", "templates"); 7 | 8 | async function createApp(dirPath) { 9 | try { 10 | fs.ensureDirSync(dirPath); 11 | await createPackageJson(dirPath); 12 | createAppFile(dirPath); 13 | createGitIgnoreFile(dirPath); 14 | editPackageJson(dirPath); 15 | } catch (err) { 16 | throw err; 17 | } 18 | } 19 | 20 | function createPackageJson(dirPath) { 21 | return new Promise(resolve => { 22 | resolve( 23 | spawnSync( 24 | "sh", 25 | [`${path.join(__dirname, "..", "scripts", "createPackage.sh")}`], 26 | { 27 | cwd: dirPath 28 | } 29 | ) 30 | ); 31 | }); 32 | } 33 | 34 | function createAppFile(dirPath) { 35 | fs.copySync(`${templatesPath}/starterFile.txt`, `${dirPath}/App.js`); 36 | } 37 | 38 | function createGitIgnoreFile(dirPath) { 39 | fs.copySync( 40 | `${templatesPath}/starterFileGitignore.txt`, 41 | `${dirPath}/.gitignore` 42 | ); 43 | } 44 | 45 | function editPackageJson(dirPath) { 46 | const data = fs 47 | .readFileSync(`${dirPath}/package.json`, "utf8") 48 | .toString() 49 | .split("\n"); 50 | const scriptPosition = data.indexOf(' "scripts": {'); 51 | data.splice(scriptPosition + 1, 0, ' "start": "node App.js",'); 52 | data.splice( 53 | scriptPosition + 1, 54 | 0, 55 | ' "dev": "NODE_ENV=development node App.js",' 56 | ); 57 | const text = data.join("\n"); 58 | const updatedPackage = text.replace( 59 | ' "test": "echo \\"Error: no test specified\\" && exit 1"', 60 | ' "test": "mocha"' 61 | ); 62 | fs.outputFileSync(`${dirPath}/package.json`, updatedPackage); 63 | } 64 | 65 | module.exports = createApp; 66 | -------------------------------------------------------------------------------- /util/createEnvFile.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const fs = require("fs-extra"); 4 | 5 | function createEnv(folderPath, apiKey, databaseUrl) { 6 | try { 7 | fs.ensureDirSync(folderPath); 8 | createEnvFile(folderPath, apiKey, databaseUrl); 9 | } catch (err) { 10 | throw err; 11 | } 12 | } 13 | 14 | function createEnvFile(folderPath, apiKey, databaseUrl) { 15 | const result = `FIREBASE_API_KEY="${apiKey}" 16 | FIREBASE_DATABASE_URL="${databaseUrl}" 17 | `; 18 | fs.outputFileSync(`${folderPath}/development.env`, result); 19 | } 20 | 21 | module.exports = createEnv; 22 | -------------------------------------------------------------------------------- /util/createResolvers.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const fs = require("fs-extra"); 4 | const path = require("path"); 5 | const parser = require("easygraphql-parser"); 6 | 7 | const { createQuery, createMutation } = require("./queryGenerator"); 8 | 9 | function createResolver(dirPath) { 10 | const apiDirPath = `${dirPath}/api`; 11 | editSchema(apiDirPath); 12 | const schema = fs.readFileSync(path.join(apiDirPath, "schema.gql"), "utf8"); 13 | const parsedSchema = parser(schema); 14 | 15 | const result = []; 16 | const queriesAndMutations = { 17 | Query: [], 18 | Mutation: [] 19 | }; 20 | for (const key of Object.keys(parsedSchema)) { 21 | if (key === "Query") { 22 | parsedSchema[key].fields.forEach(query => { 23 | const createdQuery = createQuery(query); 24 | result.push(createdQuery); 25 | queriesAndMutations.Query.push(query.name); 26 | }); 27 | } else if (key === "Mutation") { 28 | parsedSchema[key].fields.forEach(mutation => { 29 | const createdMutation = createMutation(mutation); 30 | result.push(createdMutation); 31 | queriesAndMutations.Mutation.push(mutation.name); 32 | }); 33 | } 34 | } 35 | 36 | const modulToExport = ` 37 | module.exports = { 38 | Query: { 39 | ${queriesAndMutations.Query.join(",\n")} 40 | }, 41 | Mutation: { 42 | ${queriesAndMutations.Mutation.join(",\n")} 43 | } 44 | } 45 | `; 46 | result.push(modulToExport); 47 | 48 | fs.outputFileSync(`${apiDirPath}/resolvers.js`, result.join("\r\n")); 49 | } 50 | 51 | function editSchema(apiDirPath) { 52 | const schema = fs.readFileSync(path.join(apiDirPath, "schema.gql"), "utf8"); 53 | const parsedSchema = parser(schema); 54 | const newQueries = []; 55 | const newMutations = []; 56 | const updateInputs = []; 57 | 58 | const queries = parsedSchema.Query.fields; 59 | const mutations = parsedSchema.Mutation.fields; 60 | 61 | for (const query of queries) { 62 | const searchByKey = ` get${query.type}ByKey(key: ID!): ${query.type}`; 63 | 64 | if (newQueries.indexOf(searchByKey) < 0) { 65 | newQueries.push(searchByKey); 66 | } 67 | } 68 | 69 | for (const mutation of mutations) { 70 | const { type } = mutation; 71 | 72 | const updateByKey = ` update${type}ByKey(input: Update${type}Input!): ${type}`; 73 | 74 | if (newMutations.indexOf(updateByKey) < 0) { 75 | newMutations.push(updateByKey); 76 | } 77 | 78 | const fields = []; 79 | for (const field of parsedSchema[type].fields) { 80 | const x = parsedSchema[field.type]; 81 | if (field.name.toLowerCase() !== "key" && !x) { 82 | fields.push(`${field.name}: ${field.type}`); 83 | } else if (x && x.type === "EnumTypeDefinition") { 84 | fields.push(`${field.name}: ${field.type}`); 85 | } 86 | } 87 | 88 | const input = ` 89 | input Update${type}Input { 90 | key: ID! 91 | ${fields.join("\n ")} 92 | } 93 | `; 94 | 95 | if (updateInputs.indexOf(input) < 0) { 96 | updateInputs.push(input); 97 | } 98 | } 99 | 100 | const data = schema.split("\n"); 101 | if (newQueries.length) { 102 | const queryPosition = data.indexOf("type Query {"); 103 | data.splice(queryPosition + 1, 0, `${newQueries.join("\n")}`); 104 | } 105 | 106 | if (newMutations.length) { 107 | const mutationPosition = data.indexOf("type Mutation {"); 108 | data.splice(mutationPosition + 1, 0, `${newMutations.join("\n")}`); 109 | } 110 | const text = data.join("\n"); 111 | 112 | const fileName = `${apiDirPath}/schema.gql`; 113 | fs.outputFileSync(fileName, text); 114 | fs.appendFileSync(fileName, updateInputs.join("")); 115 | } 116 | 117 | module.exports = createResolver; 118 | -------------------------------------------------------------------------------- /util/createSchema.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const path = require("path"); 4 | const fs = require("fs-extra"); 5 | const { buildSchema } = require("graphql"); 6 | 7 | function addGQLSchema(dirPath, schemaName, filePath) { 8 | try { 9 | const apiDirPath = `${dirPath}/api`; 10 | if (!dirPath) { 11 | throw new Error("The path can't be empty"); 12 | } 13 | if (!schemaName) { 14 | throw new Error("The schema file name can't be empty"); 15 | } 16 | 17 | let fileType = schemaName.split("."); 18 | fileType = fileType[fileType.length - 1]; 19 | 20 | if (fileType !== "gql" && fileType !== "graphql") { 21 | throw new Error( 22 | "The file type is not valid, it mush be .gql or .graphql" 23 | ); 24 | } 25 | 26 | filePath = filePath 27 | ? path.join(path.resolve(), filePath, schemaName) 28 | : path.join(path.resolve(), schemaName); 29 | validateSchema(filePath); 30 | copySchema(filePath, apiDirPath); 31 | } catch (err) { 32 | throw err; 33 | } 34 | } 35 | 36 | function validateSchema(filePath) { 37 | const schemaCode = fs.readFileSync(filePath, "utf8"); 38 | buildSchema(schemaCode); 39 | } 40 | 41 | function copySchema(filePath, apiDirPath) { 42 | fs.copySync(filePath, `${apiDirPath}/schema.gql`); 43 | } 44 | 45 | module.exports = addGQLSchema; 46 | -------------------------------------------------------------------------------- /util/createTests.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const path = require("path"); 4 | const fs = require("fs-extra"); 5 | const templatesPath = path.join(__dirname, "..", "templates"); 6 | 7 | function createTests(dirPath) { 8 | try { 9 | const testsDirPath = `${dirPath}/test`; 10 | fs.ensureDirSync(testsDirPath); 11 | createQueryTestFile(testsDirPath); 12 | createMutationTestFile(testsDirPath); 13 | } catch (err) { 14 | throw err; 15 | } 16 | } 17 | 18 | function createQueryTestFile(testsDirPath) { 19 | fs.copySync( 20 | `${templatesPath}/testFileQuery.txt`, 21 | `${testsDirPath}/queries.js` 22 | ); 23 | } 24 | 25 | function createMutationTestFile(testsDirPath) { 26 | fs.copySync( 27 | `${templatesPath}/testFileMutation.txt`, 28 | `${testsDirPath}/mutation.js` 29 | ); 30 | } 31 | 32 | module.exports = createTests; 33 | -------------------------------------------------------------------------------- /util/deployNow.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const fs = require("fs-extra"); 4 | const { spawn } = require("child_process"); 5 | const clipboardy = require("clipboardy"); 6 | const ora = require("ora"); 7 | 8 | const spinner = ora("▲ Deploying to now!"); 9 | 10 | function deployNow(dirPath, apiKey, databaseUrl) { 11 | try { 12 | spinner.start(); 13 | if (!dirPath) { 14 | throw new Error("The path cant be empty"); 15 | } 16 | createNowEnvFile(dirPath, apiKey, databaseUrl); 17 | runDeployNow(dirPath); 18 | } catch (err) { 19 | throw err; 20 | } 21 | } 22 | 23 | function createNowEnvFile(dirPath, apiKey, databaseUrl) { 24 | const nowEnv = { 25 | env: { 26 | FIREBASE_API_KEY: apiKey, 27 | FIREBASE_DATABASE_URL: databaseUrl 28 | } 29 | }; 30 | fs.outputFileSync(`${dirPath}/now.json`, JSON.stringify(nowEnv)); 31 | } 32 | 33 | function runDeployNow(dirPath) { 34 | const consoleProcess = spawn("now", ["-p"], { 35 | cwd: dirPath 36 | }); 37 | 38 | let nowUrl; 39 | consoleProcess.stdout.setEncoding("utf8"); 40 | consoleProcess.stderr.setEncoding("utf8"); 41 | consoleProcess.stderr.pipe(process.stdout); 42 | 43 | consoleProcess.stdout.on("data", data => { 44 | if (data.includes("https://")) { 45 | nowUrl = `${data}/graphql`; 46 | clipboardy.writeSync(nowUrl); 47 | } 48 | }); 49 | 50 | consoleProcess.stderr.on("data", data => { 51 | console.log(data); 52 | }); 53 | 54 | consoleProcess.on("close", code => { 55 | if (nowUrl) { 56 | spinner.succeed(); 57 | console.log("> url copied on clipboard: ", nowUrl); 58 | console.log("> Thanks for using easygraphql 😀"); 59 | } else { 60 | console.log("There was an error deploying to now ▲"); 61 | } 62 | }); 63 | } 64 | 65 | module.exports = deployNow; 66 | -------------------------------------------------------------------------------- /util/queryGenerator/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | function createQuery(query) { 4 | const { name, type, isArray } = query; 5 | 6 | const args = query.arguments.map(arg => arg.name); 7 | 8 | const queryArgs = args.length ? `const { ${args.join(", ")} } = args` : ""; 9 | 10 | const databaseName = `${type.toLowerCase()}s`; 11 | const databseRef = `firebase.database().ref('${databaseName}')`; 12 | 13 | let response; 14 | 15 | if (name === `get${type}ByKey`) { 16 | response = ` 17 | const ref = firebase.database().ref(\`/${databaseName}/$\{key}\`) 18 | const result = (await ref.once('value')).val() 19 | const data = Object.assign({ key }, result) 20 | 21 | return data 22 | `; 23 | } else if (isArray) { 24 | response = ` 25 | const ref = ${databseRef} 26 | const result = [] 27 | await ref.once('value', function(snapshot) { 28 | snapshot.forEach(function(childSnapshot) { 29 | const childKey = childSnapshot.key; 30 | const childData = childSnapshot.val(); 31 | 32 | const data = Object.assign({ key: childKey }, childData) 33 | result.push(data) 34 | }); 35 | }); 36 | return result 37 | `; 38 | } else { 39 | response = ` 40 | const ref = ${databseRef} 41 | const result = await new Promise(resolve => { 42 | ref.orderByChild('${args[0]}').equalTo(${ 43 | args[0] 44 | }).on('child_added', function(snapshot) { 45 | const key = snapshot.key; 46 | const data = snapshot.val(); 47 | 48 | resolve(Object.assign({ key }, data)) 49 | }) 50 | }); 51 | return result 52 | `; 53 | } 54 | 55 | const createdQuery = ` 56 | const ${name} = async (obj, args, { firebase }) => { 57 | ${queryArgs} 58 | ${response} 59 | } 60 | `; 61 | 62 | return createdQuery; 63 | } 64 | 65 | function createMutation(mutation) { 66 | const { name, type } = mutation; 67 | 68 | const databaseName = `${type.toLowerCase()}s`; 69 | 70 | let result; 71 | if (name === `update${type}ByKey`) { 72 | result = ` 73 | const key = input.key 74 | delete input.key 75 | 76 | const ref = firebase.database().ref(\`/${databaseName}/$\{key}\`) 77 | const result = (await ref.once('value')).val() 78 | const infoToUpdate = Object.assign({}, result, input) 79 | 80 | firebase.database().ref(\`/${databaseName}/$\{key}\`).set(infoToUpdate) 81 | 82 | const data = Object.assign({ key }, infoToUpdate) 83 | 84 | return data 85 | `; 86 | } else { 87 | result = ` 88 | const ref = firebase.database().ref().child('${databaseName}').push({ ...input }) 89 | 90 | const result = Object.assign({ key: ref.key }, input) 91 | return result 92 | `; 93 | } 94 | 95 | const createdMutation = ` 96 | const ${name} = async (obj, { input }, { firebase }) => { 97 | ${result} 98 | } 99 | `; 100 | 101 | return createdMutation; 102 | } 103 | 104 | module.exports = { createQuery, createMutation }; 105 | -------------------------------------------------------------------------------- /util/startServer.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const { spawn } = require("child_process"); 4 | const clipboardy = require("clipboardy"); 5 | const ora = require("ora"); 6 | 7 | const spinner = ora("Starting server locally ⏳"); 8 | 9 | function runLocal(dirPath, port) { 10 | spinner.start(); 11 | if (!dirPath) { 12 | throw new Error("The path cant be empty"); 13 | } 14 | startServer(dirPath, port); 15 | } 16 | 17 | function startServer(dirPath, port) { 18 | spawn("npm", ["run", "dev"], { 19 | cwd: dirPath 20 | }); 21 | 22 | spinner.succeed(); 23 | const localUrl = `http://localhost:${port}/graphql`; 24 | clipboardy.writeSync(localUrl); 25 | console.log("> url copied on clipboard: ", localUrl); 26 | 27 | process.on("SIGINT", exitHandler.bind(null, { dirPath })); 28 | process.on("SIGUSR1", exitHandler.bind(null, { dirPath })); 29 | process.on("SIGUSR2", exitHandler.bind(null, { dirPath })); 30 | process.on("uncaughtException", exitHandler.bind(null, { dirPath })); 31 | } 32 | 33 | function exitHandler(options) { 34 | console.log("> Thanks for using easygraphql-firebase 😀"); 35 | } 36 | 37 | module.exports = runLocal; 38 | --------------------------------------------------------------------------------