import angular from 'angular'; import _ from 'lodash-es'; import PortainerError from 'Portainer/error'; import KubernetesConfigMapConverter from 'Kubernetes/converters/configMap'; import { KubernetesCommonParams } from 'Kubernetes/models/common/params'; import { KubernetesPortainerAccessConfigMap } from 'Kubernetes/models/config-map/models'; class KubernetesConfigMapService { /* @ngInject */ constructor($async, KubernetesConfigMaps) { this.$async = $async; this.KubernetesConfigMaps = KubernetesConfigMaps; this.getAsync = this.getAsync.bind(this); this.getAllAsync = this.getAllAsync.bind(this); this.createAsync = this.createAsync.bind(this); this.updateAsync = this.updateAsync.bind(this); this.deleteAsync = this.deleteAsync.bind(this); } getAccess(namespace, name) { return this.$async(async () => { try { const params = new KubernetesCommonParams(); params.id = name; const raw = await this.KubernetesConfigMaps(namespace).get(params).$promise; return KubernetesConfigMapConverter.apiToPortainerAccessConfigMap(raw); } catch (err) { if (err.status === 404) { return new KubernetesPortainerAccessConfigMap(); } throw new PortainerError('Unable to retrieve Portainer accesses', err); } }); } createAccess(config) { return this.$async(async () => { try { const payload = KubernetesConfigMapConverter.createAccessPayload(config); const params = {}; const namespace = payload.metadata.namespace; const data = await this.KubernetesConfigMaps(namespace).create(params, payload).$promise; return KubernetesConfigMapConverter.apiToPortainerAccessConfigMap(data); } catch (err) { throw new PortainerError('Unable to create Portainer accesses', err); } }); } updateAccess(config) { return this.$async(async () => { try { if (!config.Id) { return await this.createAccess(config); } const payload = KubernetesConfigMapConverter.updateAccessPayload(config); const params = new KubernetesCommonParams(); params.id = payload.metadata.name; const namespace = payload.metadata.namespace; const data = await this.KubernetesConfigMaps(namespace).update(params, payload).$promise; return KubernetesConfigMapConverter.apiToPortainerAccessConfigMap(data); } catch (err) { throw new PortainerError('Unable to update Portainer accesses', err); } }); } /** * GET */ async getAsync(namespace, name) { try { const params = new KubernetesCommonParams(); params.id = name; const [rawPromise, yamlPromise] = await Promise.allSettled([ this.KubernetesConfigMaps(namespace).get(params).$promise, this.KubernetesConfigMaps(namespace).getYaml(params).$promise, ]); if (_.get(rawPromise, 'reason.status') === 404 && _.get(yamlPromise, 'reason.status') === 404) { return KubernetesConfigMapConverter.defaultConfigMap(namespace, name); } // Saving binary data to 'data' field in configMap Object is not allowed by kubernetes and getYaml() may get // an error. We should keep binary data to 'binaryData' field instead of 'data'. Before that, we // use response from get() and ignore 500 error as a workaround. if (rawPromise.value) { return KubernetesConfigMapConverter.apiToConfigMap(rawPromise.value, yamlPromise.value); } throw new PortainerError('Unable to retrieve config map ', name); } catch (err) { if (err.status === 404) { return KubernetesConfigMapConverter.defaultConfigMap(namespace, name); } throw new PortainerError('Unable to retrieve config map', err); } } async getAllAsync(namespace) { try { const data = await this.KubernetesConfigMaps(namespace).get().$promise; return _.map(data.items, (item) => KubernetesConfigMapConverter.apiToConfigMap(item)); } catch (err) { throw new PortainerError('Unable to retrieve config maps', err); } } get(namespace, name) { if (name) { return this.$async(this.getAsync, namespace, name); } return this.$async(this.getAllAsync, namespace); } /** * CREATE */ async createAsync(config) { try { const payload = KubernetesConfigMapConverter.createPayload(config); const params = {}; const namespace = payload.metadata.namespace; const data = await this.KubernetesConfigMaps(namespace).create(params, payload).$promise; return KubernetesConfigMapConverter.apiToConfigMap(data); } catch (err) { throw new PortainerError('Unable to create config map', err); } } create(config) { return this.$async(this.createAsync, config); } /** * UPDATE */ async updateAsync(config) { try { if (!config.Id) { return await this.create(config); } const payload = KubernetesConfigMapConverter.updatePayload(config); const params = new KubernetesCommonParams(); params.id = payload.metadata.name; const namespace = payload.metadata.namespace; const data = await this.KubernetesConfigMaps(namespace).update(params, payload).$promise; return KubernetesConfigMapConverter.apiToConfigMap(data); } catch (err) { throw new PortainerError('Unable to update config map', err); } } update(config) { return this.$async(this.updateAsync, config); } /** * DELETE */ async deleteAsync(config) { try { const params = new KubernetesCommonParams(); params.id = config.Name; const namespace = config.Namespace; await this.KubernetesConfigMaps(namespace).delete(params).$promise; } catch (err) { throw new PortainerError('Unable to delete config map', err); } } delete(config) { return this.$async(this.deleteAsync, config); } } export default KubernetesConfigMapService; angular.module('portainer.kubernetes').service('KubernetesConfigMapService', KubernetesConfigMapService);