├── .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 |
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 |
--------------------------------------------------------------------------------