UNPKG

@topgroup/diginext

Version:

A BUILD SERVER & CLI to deploy apps to any Kubernetes clusters.

173 lines (172 loc) 8.85 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.MonitorNamespaceService = void 0; const k8s_1 = __importDefault(require("../modules/k8s")); const mongodb_1 = require("../plugins/mongodb"); const ClusterService_1 = require("./ClusterService"); class MonitorNamespaceService { constructor(ownership) { this.ownership = ownership; this.user = ownership === null || ownership === void 0 ? void 0 : ownership.owner; this.workspace = ownership === null || ownership === void 0 ? void 0 : ownership.workspace; } async create(data, options) { const { DB } = await Promise.resolve().then(() => __importStar(require("../modules/api/DB"))); const { name, cluster: clusterSlugOrId } = data; if (!clusterSlugOrId) throw new Error(`Param "clusterSlug" is required.`); const cluster = await DB.findOne("cluster", { $or: [{ slug: clusterSlugOrId }, { _id: clusterSlugOrId }], workspace: this.workspace._id }); if (!cluster) throw new Error(`Cluster "${clusterSlugOrId}" not found.`); const { contextName: context } = cluster; if (!context) throw new Error(`Unverified cluster: "${clusterSlugOrId}"`); // check name existed const isExisted = await k8s_1.default.isNamespaceExisted(name); if (isExisted) throw new Error(`Namespace "${name}" is existed.`); const namespace = await k8s_1.default.createNamespace(name, { context }); // namespace.workspace = MongoDB.toString(this.workspace._id); // namespace.clusterSlug = clusterSlug; // namespace.cluster = MongoDB.toString(cluster._id); return namespace; } async find(filter, options) { const { DB } = await Promise.resolve().then(() => __importStar(require("../modules/api/DB"))); let { cluster: clusterIdOrSlug, name, ...rest } = filter; let data = []; const clusterSvc = new ClusterService_1.ClusterService(this.ownership); if (!clusterIdOrSlug) { const clusters = await clusterSvc.find({ workspace: this.workspace._id, ...rest }); const ls = await Promise.all(clusters.map(async (_cluster) => { const { contextName: context } = _cluster; if (!context) return []; let nsList = name ? [(await k8s_1.default.getNamespace(name, { context, output: options === null || options === void 0 ? void 0 : options.output }))] : await k8s_1.default.getAllNamespaces({ context, output: options === null || options === void 0 ? void 0 : options.output }); nsList = nsList.map((ns) => { ns.workspace = mongodb_1.MongoDB.toString(this.workspace._id); ns.clusterSlug = _cluster.slug; ns.cluster = mongodb_1.MongoDB.toString(_cluster._id); return ns; }); return nsList; })); ls.map((nsList) => nsList.map((ns) => data.push(ns))); } else { const clusterFilter = mongodb_1.MongoDB.isValidObjectId(clusterIdOrSlug) ? { _id: clusterIdOrSlug } : { slug: clusterIdOrSlug }; const cluster = await clusterSvc.findOne({ ...clusterFilter, workspace: this.workspace._id, ...rest, }); if (!cluster) throw new Error(`Cluster "${cluster}" not found.`); const { contextName: context } = cluster; if (!context) throw new Error(`Unverified cluster: "${cluster}"`); data = name ? [(await k8s_1.default.getNamespace(name, { context, output: options === null || options === void 0 ? void 0 : options.output }))] : await k8s_1.default.getAllNamespaces({ context, output: options === null || options === void 0 ? void 0 : options.output }); data = data.map((ns) => { ns.workspace = mongodb_1.MongoDB.toString(this.workspace._id); ns.clusterSlug = cluster.slug; ns.cluster = mongodb_1.MongoDB.toString(cluster._id); return ns; }); } return data; } async findOne(filter, options) { const data = await this.find(filter, options); return data[0]; } async update(filter, data, options) { // check permissions // await checkPermissionsByFilter("frameworks", this, filter, this.user); // return super.update(filter, data, options); return []; } async allResources(filter, options) { const { MonitorDeploymentService, MonitorIngressService, MonitorPodService, MonitorSecretService, MonitorServiceService, MonitorStatefulSetService, // pvc } = await Promise.resolve().then(() => __importStar(require("./MonitorService"))); const resourceFilter = {}; resourceFilter.cluster = filter.cluster; resourceFilter.namespace = filter.name; resourceFilter.labels = filter.labels; // get ingresses const ingSvc = new MonitorIngressService(this.ownership); const ingresses = await ingSvc.find(resourceFilter, options); // get services const svcSvc = new MonitorServiceService(this.ownership); const services = await svcSvc.find(resourceFilter, options); // get deployments const deploymentSvc = new MonitorDeploymentService(this.ownership); const deployments = await deploymentSvc.find(resourceFilter, options); // get statefulsets const statefulSetSvc = new MonitorStatefulSetService(this.ownership); const statefulSets = await statefulSetSvc.find(resourceFilter, options); // get pods const podSvc = new MonitorPodService(this.ownership); const pods = await podSvc.find(resourceFilter, options); // get persistent volume claims // get secrets const secretSvc = new MonitorSecretService(this.ownership); const secrets = await secretSvc.find(resourceFilter, options); return { ingresses, services, deployments, statefulSets, pods, secrets }; } async delete(params) { const { DB } = await Promise.resolve().then(() => __importStar(require("../modules/api/DB"))); const { cluster: clusterSlugOrId, name } = params; if (!clusterSlugOrId) throw new Error(`Param "cluster" is required.`); if (!name) throw new Error(`Param "name" is required.`); const clusterFilter = mongodb_1.MongoDB.isValidObjectId(clusterSlugOrId) ? { _id: clusterSlugOrId } : { slug: clusterSlugOrId }; const cluster = await DB.findOne("cluster", { ...clusterFilter, workspace: this.workspace._id }); if (!cluster) throw new Error(`Cluster "${clusterSlugOrId}" not found.`); const { contextName: context } = cluster; if (!context) throw new Error(`Unverified cluster: "${clusterSlugOrId}"`); // check name existed const isExisted = await k8s_1.default.isNamespaceExisted(name); if (!isExisted) throw new Error(`Namespace "${name}" not found.`); const namespace = await k8s_1.default.deleteNamespace(name, { context }); // namespace.workspace = MongoDB.toString(this.workspace._id); // namespace.clusterSlug = clusterSlug; // namespace.cluster = MongoDB.toString(cluster._id); return namespace; } } exports.MonitorNamespaceService = MonitorNamespaceService;