GSI - Employe Self Service Mobile
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

109 lines
5.9 KiB

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getUsedProducts = exports.bulkCheckProductsProvisioned = exports.checkProductsProvisioned = exports.DeferredProduct = void 0;
const { marked } = require("marked");
const api_1 = require("../api");
const apiv2_1 = require("../apiv2");
const functional_1 = require("../functional");
const error_1 = require("../error");
const planner_1 = require("../deploy/extensions/planner");
const logger_1 = require("../logger");
var DeferredProduct;
(function (DeferredProduct) {
DeferredProduct[DeferredProduct["STORAGE"] = 0] = "STORAGE";
DeferredProduct[DeferredProduct["AUTH"] = 1] = "AUTH";
})(DeferredProduct = exports.DeferredProduct || (exports.DeferredProduct = {}));
async function checkProductsProvisioned(projectId, spec) {
const usedProducts = getUsedProducts(spec);
await checkProducts(projectId, usedProducts);
}
exports.checkProductsProvisioned = checkProductsProvisioned;
async function bulkCheckProductsProvisioned(projectId, instanceSpecs) {
const usedProducts = await Promise.all(instanceSpecs.map(async (i) => {
const extensionSpec = await (0, planner_1.getExtensionSpec)(i);
return getUsedProducts(extensionSpec);
}));
await checkProducts(projectId, [...(0, functional_1.flattenArray)(usedProducts)]);
}
exports.bulkCheckProductsProvisioned = bulkCheckProductsProvisioned;
async function checkProducts(projectId, usedProducts) {
const needProvisioning = [];
let isStorageProvisionedPromise;
let isAuthProvisionedPromise;
if (usedProducts.includes(DeferredProduct.STORAGE)) {
isStorageProvisionedPromise = isStorageProvisioned(projectId);
}
if (usedProducts.includes(DeferredProduct.AUTH)) {
isAuthProvisionedPromise = isAuthProvisioned(projectId);
}
try {
if (isStorageProvisionedPromise && !(await isStorageProvisionedPromise)) {
needProvisioning.push(DeferredProduct.STORAGE);
}
if (isAuthProvisionedPromise && !(await isAuthProvisionedPromise)) {
needProvisioning.push(DeferredProduct.AUTH);
}
}
catch (err) {
logger_1.logger.debug(`Error while checking product provisioning, failing open: ${err}`);
}
if (needProvisioning.length > 0) {
let errorMessage = "Some services used by this extension have not been set up on your " +
"Firebase project. To ensure this extension works as intended, you must enable these " +
"services by following the provided links, then retry this command\n\n";
if (needProvisioning.includes(DeferredProduct.STORAGE)) {
errorMessage +=
" - Firebase Storage: store and retrieve user-generated files like images, audio, and " +
"video without server-side code.\n";
errorMessage += ` https://console.firebase.google.com/project/${projectId}/storage`;
errorMessage += "\n";
}
if (needProvisioning.includes(DeferredProduct.AUTH)) {
errorMessage +=
" - Firebase Authentication: authenticate and manage users from a variety of providers " +
"without server-side code.\n";
errorMessage += ` https://console.firebase.google.com/project/${projectId}/authentication/users`;
}
throw new error_1.FirebaseError(marked(errorMessage), { exit: 2 });
}
}
function getUsedProducts(spec) {
var _a, _b;
const usedProducts = [];
const usedApis = (_a = spec.apis) === null || _a === void 0 ? void 0 : _a.map((api) => api.apiName);
const usedRoles = (_b = spec.roles) === null || _b === void 0 ? void 0 : _b.map((r) => r.role.split(".")[0]);
const usedTriggers = spec.resources.map((r) => getTriggerType(r.propertiesYaml));
if ((usedApis === null || usedApis === void 0 ? void 0 : usedApis.includes("storage-component.googleapis.com")) ||
(usedRoles === null || usedRoles === void 0 ? void 0 : usedRoles.includes("storage")) ||
usedTriggers.find((t) => t === null || t === void 0 ? void 0 : t.startsWith("google.storage."))) {
usedProducts.push(DeferredProduct.STORAGE);
}
if ((usedApis === null || usedApis === void 0 ? void 0 : usedApis.includes("identitytoolkit.googleapis.com")) ||
(usedRoles === null || usedRoles === void 0 ? void 0 : usedRoles.includes("firebaseauth")) ||
usedTriggers.find((t) => t === null || t === void 0 ? void 0 : t.startsWith("providers/firebase.auth/"))) {
usedProducts.push(DeferredProduct.AUTH);
}
return usedProducts;
}
exports.getUsedProducts = getUsedProducts;
function getTriggerType(propertiesYaml) {
var _a;
return (_a = propertiesYaml === null || propertiesYaml === void 0 ? void 0 : propertiesYaml.match(/eventType:\ ([\S]+)/)) === null || _a === void 0 ? void 0 : _a[1];
}
async function isStorageProvisioned(projectId) {
var _a, _b;
const client = new apiv2_1.Client({ urlPrefix: api_1.firebaseStorageOrigin, apiVersion: "v1beta" });
const resp = await client.get(`/projects/${projectId}/buckets`);
return !!((_b = (_a = resp.body) === null || _a === void 0 ? void 0 : _a.buckets) === null || _b === void 0 ? void 0 : _b.find((bucket) => {
const bucketResourceName = bucket.name;
const bucketResourceNameTokens = bucketResourceName.split("/");
const pattern = "^" + projectId + "(.[[a-z0-9]+)*.appspot.com$";
return new RegExp(pattern).test(bucketResourceNameTokens[bucketResourceNameTokens.length - 1]);
}));
}
async function isAuthProvisioned(projectId) {
var _a, _b;
const client = new apiv2_1.Client({ urlPrefix: api_1.firedataOrigin, apiVersion: "v1" });
const resp = await client.get(`/projects/${projectId}/products`);
return !!((_b = (_a = resp.body) === null || _a === void 0 ? void 0 : _a.activation) === null || _b === void 0 ? void 0 : _b.map((a) => a.service).includes("FIREBASE_AUTH"));
}