UNPKG

fauna-gql-upload

Version:

Manage your FaunaDB resources in within your project and upload them using a single command

180 lines (179 loc) 9.84 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __generator = (this && this.__generator) || function (thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (_) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; exports.__esModule = true; var fs_1 = __importDefault(require("fs")); var path_1 = __importDefault(require("path")); var node_fetch_1 = __importDefault(require("node-fetch")); var yargs_1 = __importDefault(require("yargs")); var prompts_1 = __importDefault(require("prompts")); var cli_spinner_1 = __importDefault(require("cli-spinner")); var wait_1 = __importDefault(require("../util/wait")); var logger_1 = require("../util/logger"); var env_1 = require("../util/env"); var getEndpoint_1 = __importDefault(require("../util/getEndpoint")); var error_1 = __importDefault(require("../util/error")); var Spinner = cli_spinner_1["default"].Spinner; // Override the prompt if user supplies '-y' or '--yes' var defaultYes = yargs_1["default"].argv.yes || yargs_1["default"].argv.y; prompts_1["default"].override(defaultYes ? { shouldOverride: true } : {}); function buildSchema(dir) { return __awaiter(this, void 0, void 0, function () { var directory, files, schemaFiles, schemaParts, concatenatedSchema; var _this = this; return __generator(this, function (_a) { switch (_a.label) { case 0: (0, logger_1.status)("Concatenating schema files...", "info"); directory = path_1["default"].join(process.cwd(), dir); return [4 /*yield*/, fs_1["default"].promises.readdir(directory)]; case 1: files = _a.sent(); schemaFiles = files.filter(function (file) { return file.endsWith(".graphql") || file.endsWith(".gql"); }); if (schemaFiles.length === 0) { (0, logger_1.status)("No GraphQL schema files found in directory. Make sure that all files in the specified directory ends in one of the following extensions: `.gql` or `.graphql`", "error"); return [2 /*return*/, null]; } return [4 /*yield*/, Promise.all(schemaFiles.map(function (file) { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) { return [2 /*return*/, fs_1["default"].promises.readFile(path_1["default"].join(directory, file), "utf8")]; }); }); }))]; case 2: schemaParts = _a.sent(); concatenatedSchema = schemaParts.join("\n"); return [2 /*return*/, concatenatedSchema]; } }); }); } function uploadSchema(options) { return __awaiter(this, void 0, void 0, function () { var graphqlEndpoint, schemaDir, schemaPath, schema, _a, data, spinner, shouldOverride, answer, mode, endpoint, res, result; return __generator(this, function (_b) { switch (_b.label) { case 0: return [4 /*yield*/, (0, getEndpoint_1["default"])()]; case 1: graphqlEndpoint = (_b.sent()).graphql; schemaDir = options.schemaDir; schemaPath = options.schemaPath; if (!(schemaDir && schemaPath)) return [3 /*break*/, 3]; return [4 /*yield*/, buildSchema(schemaDir)]; case 2: _a = _b.sent(); return [3 /*break*/, 4]; case 3: _a = (schemaPath ? path_1["default"].join(process.cwd(), schemaPath) : null); _b.label = 4; case 4: schema = _a; if (!schema) { (0, logger_1.status)("Cannot read schema. Make sure you've specified a schemaDir or schemaPath", "error"); return [2 /*return*/]; } if (!schemaDir) { if (schema) { if (!fs_1["default"].existsSync(schema)) { (0, error_1["default"])("Cannot find schema at \x1b[4m" + schema + "\x1b[0m"); } } } if (options.override) { (0, logger_1.status)("The `override` option has been deprecated. Please use `--mode override` instead.", "error"); } data = schemaDir ? schema : fs_1["default"].createReadStream(schema); spinner = new Spinner("Overriding schema.. %s"); shouldOverride = false; if (!(options.override || options.mode === "override")) return [3 /*break*/, 6]; return [4 /*yield*/, (0, prompts_1["default"])({ type: "confirm", name: "shouldOverride", message: "Be careful! Overriding a schema will delete all collections, indexes, and documents. Do you want to continue?" })]; case 5: answer = _b.sent(); shouldOverride = answer.shouldOverride; _b.label = 6; case 6: if ((options.override || options.mode === "override") && !shouldOverride) return [2 /*return*/]; if (shouldOverride) { (0, logger_1.status)("Okay, this could take a while. Sit tight..."); spinner.start(); } mode = shouldOverride ? "override" : (options.mode || "merge"); endpoint = "".concat(graphqlEndpoint, "/import?mode=").concat(mode); return [4 /*yield*/, (0, node_fetch_1["default"])(endpoint, { method: "POST", headers: { "Authorization": "Bearer ".concat(env_1.secret), "Content-Type": "text/plain" }, body: data })]; case 7: res = _b.sent(); return [4 /*yield*/, res.text()]; case 8: result = _b.sent(); if (!shouldOverride) return [3 /*break*/, 10]; (0, logger_1.status)("Waiting 65 seconds before uploading resources."); return [4 /*yield*/, (0, wait_1["default"])(65 * 1000)]; case 9: _b.sent(); spinner.stop(true); _b.label = 10; case 10: if (!res.ok) { (0, logger_1.status)(result, "error"); return [2 /*return*/, false]; } if (res.ok) { (0, logger_1.status)("updated schema", "success"); return [2 /*return*/, true]; } return [2 /*return*/]; } }); }); } exports["default"] = uploadSchema;