@drunk-pulumi/azure 0.0.19 → 0.0.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Aks/Helper.d.ts +0 -18
- package/Aks/Helper.js +50 -32
- package/Common/AutoTags.js +2 -1
- package/package.json +3 -6
- package/KubeX/AcrSecret.d.ts +0 -15
- package/KubeX/AcrSecret.js +0 -31
- package/KubeX/Apps/AstroPage.d.ts +0 -12
- package/KubeX/Apps/AstroPage.js +0 -33
- package/KubeX/Apps/KafKa.d.ts +0 -6
- package/KubeX/Apps/KafKa.js +0 -13
- package/KubeX/Apps/Nobelium.d.ts +0 -13
- package/KubeX/Apps/Nobelium.js +0 -37
- package/KubeX/Apps/Wikijs.d.ts +0 -30
- package/KubeX/Apps/Wikijs.js +0 -54
- package/KubeX/Apps/WordPress.d.ts +0 -24
- package/KubeX/Apps/WordPress.js +0 -55
- package/KubeX/Apps/YarpProxy/index.d.ts +0 -17
- package/KubeX/Apps/YarpProxy/index.js +0 -107
- package/KubeX/Apps/YarpProxy/type.d.ts +0 -55
- package/KubeX/Apps/YarpProxy/type.js +0 -3
- package/KubeX/CertHelper.d.ts +0 -1
- package/KubeX/CertHelper.js +0 -9
- package/KubeX/CertImports.d.ts +0 -19
- package/KubeX/CertImports.js +0 -70
- package/KubeX/CloudFlare/CertCreator.d.ts +0 -19
- package/KubeX/CloudFlare/CertCreator.js +0 -90
- package/KubeX/CloudFlare/CertImports.d.ts +0 -17
- package/KubeX/CloudFlare/CertImports.js +0 -34
- package/KubeX/CloudFlare/DynamicDns.d.ts +0 -21
- package/KubeX/CloudFlare/DynamicDns.js +0 -39
- package/KubeX/CloudFlare/Tunnel-Helm.d.ts +0 -17
- package/KubeX/CloudFlare/Tunnel-Helm.js +0 -12
- package/KubeX/CloudFlare/Tunnel.d.ts +0 -23
- package/KubeX/CloudFlare/Tunnel.js +0 -54
- package/KubeX/CloudFlare/index.d.ts +0 -13
- package/KubeX/CloudFlare/index.js +0 -36
- package/KubeX/Clusters/K3s/AutoUpgradeController/index.d.ts +0 -6
- package/KubeX/Clusters/K3s/AutoUpgradeController/index.js +0 -60
- package/KubeX/ConfigSecret.d.ts +0 -24
- package/KubeX/ConfigSecret.js +0 -38
- package/KubeX/Core/CertManager/index.d.ts +0 -24
- package/KubeX/Core/CertManager/index.js +0 -96
- package/KubeX/Core/KsCertSecret.d.ts +0 -12
- package/KubeX/Core/KsCertSecret.js +0 -22
- package/KubeX/Core/KsSecret.d.ts +0 -9
- package/KubeX/Core/KsSecret.js +0 -12
- package/KubeX/Core/LoadBalancer/MetalLB.d.ts +0 -7
- package/KubeX/Core/LoadBalancer/MetalLB.js +0 -21
- package/KubeX/Core/Monitoring/index.d.ts +0 -22
- package/KubeX/Core/Monitoring/index.js +0 -322
- package/KubeX/Core/Namespace.d.ts +0 -12
- package/KubeX/Core/Namespace.js +0 -41
- package/KubeX/Core/Nginx/index.d.ts +0 -60
- package/KubeX/Core/Nginx/index.js +0 -109
- package/KubeX/Core/OAuthProxy/index.d.ts +0 -0
- package/KubeX/Core/OAuthProxy/index.js +0 -3
- package/KubeX/Core/ResourceQuota.d.ts +0 -12
- package/KubeX/Core/ResourceQuota.js +0 -13
- package/KubeX/Core/SecurityRules.d.ts +0 -34
- package/KubeX/Core/SecurityRules.js +0 -93
- package/KubeX/Core/StorageClass/azureBlob.d.ts +0 -20
- package/KubeX/Core/StorageClass/azureBlob.js +0 -77
- package/KubeX/Core/StorageClass/azureFile.d.ts +0 -17
- package/KubeX/Core/StorageClass/azureFile.js +0 -45
- package/KubeX/Core/StorageClass/index.d.ts +0 -13
- package/KubeX/Core/StorageClass/index.js +0 -25
- package/KubeX/Core/index.d.ts +0 -57
- package/KubeX/Core/index.js +0 -94
- package/KubeX/Databases/MariaDb.d.ts +0 -11
- package/KubeX/Databases/MariaDb.js +0 -39
- package/KubeX/Databases/MySql.V2.d.ts +0 -11
- package/KubeX/Databases/MySql.V2.js +0 -40
- package/KubeX/Databases/MySql.d.ts +0 -13
- package/KubeX/Databases/MySql.js +0 -55
- package/KubeX/Databases/PostgreSql/PostgreSQL-HA.d.ts +0 -10
- package/KubeX/Databases/PostgreSql/PostgreSQL-HA.js +0 -47
- package/KubeX/Databases/PostgreSql/PostgreSQL.d.ts +0 -10
- package/KubeX/Databases/PostgreSql/PostgreSQL.js +0 -51
- package/KubeX/Databases/PostgreSql/PostgreSql.v1.d.ts +0 -13
- package/KubeX/Databases/PostgreSql/PostgreSql.v1.js +0 -56
- package/KubeX/Databases/PostgreSql/index.d.ts +0 -17
- package/KubeX/Databases/PostgreSql/index.js +0 -6
- package/KubeX/Databases/RedisCache.d.ts +0 -14
- package/KubeX/Databases/RedisCache.js +0 -65
- package/KubeX/Databases/SqlServer.d.ts +0 -15
- package/KubeX/Databases/SqlServer.js +0 -77
- package/KubeX/Deployment/PodAutoscaler.d.ts +0 -14
- package/KubeX/Deployment/PodAutoscaler.js +0 -51
- package/KubeX/Deployment/index.d.ts +0 -136
- package/KubeX/Deployment/index.js +0 -306
- package/KubeX/Helpers.d.ts +0 -4
- package/KubeX/Helpers.js +0 -17
- package/KubeX/Ingress/AppGatewayIngress.d.ts +0 -2
- package/KubeX/Ingress/AppGatewayIngress.js +0 -4
- package/KubeX/Ingress/Conts.d.ts +0 -13
- package/KubeX/Ingress/Conts.js +0 -18
- package/KubeX/Ingress/NginxIngress.d.ts +0 -3
- package/KubeX/Ingress/NginxIngress.js +0 -186
- package/KubeX/Ingress/NginxProxy.d.ts +0 -21
- package/KubeX/Ingress/NginxProxy.js +0 -43
- package/KubeX/Ingress/TraefikIngress/CustomHeader.d.ts +0 -15
- package/KubeX/Ingress/TraefikIngress/CustomHeader.js +0 -15
- package/KubeX/Ingress/TraefikIngress/index.d.ts +0 -11
- package/KubeX/Ingress/TraefikIngress/index.js +0 -95
- package/KubeX/Ingress/index.d.ts +0 -5
- package/KubeX/Ingress/index.js +0 -12
- package/KubeX/Ingress/type.d.ts +0 -82
- package/KubeX/Ingress/type.js +0 -3
- package/KubeX/Providers/index.d.ts +0 -8
- package/KubeX/Providers/index.js +0 -15
- package/KubeX/Storage/Longhorn/index.d.ts +0 -15
- package/KubeX/Storage/Longhorn/index.js +0 -54
- package/KubeX/Storage/index.d.ts +0 -25
- package/KubeX/Storage/index.js +0 -79
- package/KubeX/Tools/AWS/LocalStack.d.ts +0 -7
- package/KubeX/Tools/AWS/LocalStack.js +0 -29
- package/KubeX/Tools/AWS/S3.d.ts +0 -6
- package/KubeX/Tools/AWS/S3.js +0 -44
- package/KubeX/Tools/AWS/index.d.ts +0 -7
- package/KubeX/Tools/AWS/index.js +0 -14
- package/KubeX/Tools/AppHealthzMonitor.d.ts +0 -18
- package/KubeX/Tools/AppHealthzMonitor.js +0 -52
- package/KubeX/Tools/ArgoCD/index.d.ts +0 -17
- package/KubeX/Tools/ArgoCD/index.js +0 -131
- package/KubeX/Tools/Dapr/Storage.d.ts +0 -66
- package/KubeX/Tools/Dapr/Storage.js +0 -70
- package/KubeX/Tools/Dapr/index.d.ts +0 -10
- package/KubeX/Tools/Dapr/index.js +0 -31
- package/KubeX/Tools/Echo-App.d.ts +0 -3
- package/KubeX/Tools/Echo-App.js +0 -21
- package/KubeX/Tools/Gitea/GiteaRepo.d.ts +0 -72
- package/KubeX/Tools/Gitea/GiteaRepo.js +0 -184
- package/KubeX/Tools/Gitea/GiteaRunner.d.ts +0 -11
- package/KubeX/Tools/Gitea/GiteaRunner.js +0 -37
- package/KubeX/Tools/Gitea/GiteaRunner.v1.d.ts +0 -11
- package/KubeX/Tools/Gitea/GiteaRunner.v1.js +0 -123
- package/KubeX/Tools/HarborRepo.d.ts +0 -29
- package/KubeX/Tools/HarborRepo.js +0 -78
- package/KubeX/Tools/HelloWorld.d.ts +0 -3
- package/KubeX/Tools/HelloWorld.js +0 -21
- package/KubeX/Tools/KubeCleanup.d.ts +0 -9
- package/KubeX/Tools/KubeCleanup.js +0 -34
- package/KubeX/Tools/NoIp.d.ts +0 -13
- package/KubeX/Tools/NoIp.js +0 -24
- package/KubeX/Tools/OpenLDAP/index.d.ts +0 -12
- package/KubeX/Tools/OpenLDAP/index.js +0 -56
- package/KubeX/Tools/OutlineVpn/index.d.ts +0 -25
- package/KubeX/Tools/OutlineVpn/index.js +0 -256
- package/KubeX/Tools/SqlPad.d.ts +0 -29
- package/KubeX/Tools/SqlPad.js +0 -133
- package/KubeX/Tools/ToolPod.d.ts +0 -10
- package/KubeX/Tools/ToolPod.js +0 -40
- package/KubeX/Tools/UptimeKuma.d.ts +0 -6
- package/KubeX/Tools/UptimeKuma.js +0 -38
- package/KubeX/Tools/index.d.ts +0 -27
- package/KubeX/Tools/index.js +0 -35
- package/KubeX/VairableResolvers/index.d.ts +0 -15
- package/KubeX/VairableResolvers/index.js +0 -49
- package/KubeX/kx/index.d.ts +0 -114
- package/KubeX/kx/index.js +0 -423
- package/KubeX/types.d.ts +0 -49
- package/KubeX/types.js +0 -3
package/KubeX/Tools/index.js
DELETED
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const KubeCleanup_1 = require("./KubeCleanup");
|
|
4
|
-
const ToolPod_1 = require("./ToolPod");
|
|
5
|
-
const SqlPad_1 = require("./SqlPad");
|
|
6
|
-
const OutlineVpn_1 = require("./OutlineVpn");
|
|
7
|
-
const NoIp_1 = require("./NoIp");
|
|
8
|
-
const AppHealthzMonitor_1 = require("./AppHealthzMonitor");
|
|
9
|
-
const UptimeKuma_1 = require("./UptimeKuma");
|
|
10
|
-
const OpenLDAP_1 = require("./OpenLDAP");
|
|
11
|
-
const HelloWorld_1 = require("./HelloWorld");
|
|
12
|
-
const Echo_App_1 = require("./Echo-App");
|
|
13
|
-
exports.default = async ({ helloWorld, echo, enableKubeCleanup, toolPod, noIp, sqlPad, outlineVpn, openLdap, appHealthMonitor, uptimeKuma, namespace, ...others }) => {
|
|
14
|
-
if (helloWorld)
|
|
15
|
-
(0, HelloWorld_1.default)({ namespace, ...others, ...helloWorld });
|
|
16
|
-
if (echo)
|
|
17
|
-
(0, Echo_App_1.default)({ namespace, ...others, ...echo });
|
|
18
|
-
if (enableKubeCleanup)
|
|
19
|
-
(0, KubeCleanup_1.default)({ namespace, ...others });
|
|
20
|
-
if (toolPod)
|
|
21
|
-
(0, ToolPod_1.default)({ namespace, ...others, ...toolPod });
|
|
22
|
-
if (noIp)
|
|
23
|
-
(0, NoIp_1.default)({ namespace, ...others, ...noIp });
|
|
24
|
-
if (sqlPad)
|
|
25
|
-
await (0, SqlPad_1.default)({ namespace, ...others, ...sqlPad });
|
|
26
|
-
if (outlineVpn)
|
|
27
|
-
await (0, OutlineVpn_1.default)({ ...others, ...outlineVpn });
|
|
28
|
-
if (openLdap)
|
|
29
|
-
(0, OpenLDAP_1.default)({ ...others, ...openLdap });
|
|
30
|
-
if (appHealthMonitor)
|
|
31
|
-
(0, AppHealthzMonitor_1.default)({ namespace, ...others, ...appHealthMonitor });
|
|
32
|
-
if (uptimeKuma)
|
|
33
|
-
(0, UptimeKuma_1.default)({ namespace, ...others, ...uptimeKuma });
|
|
34
|
-
};
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvS3ViZVgvVG9vbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSwrQ0FBd0M7QUFDeEMsdUNBQWtEO0FBQ2xELHFDQUErQztBQUMvQyw2Q0FBd0Q7QUFDeEQsaUNBQXlDO0FBQ3pDLDJEQUE4RTtBQUM5RSw2Q0FBMkQ7QUFDM0QseUNBQXFEO0FBQ3JELDZDQUFzQztBQUN0Qyx5Q0FBaUM7QUF5QmpDLGtCQUFlLEtBQUssRUFBRSxFQUNwQixVQUFVLEVBQ1YsSUFBSSxFQUVKLGlCQUFpQixFQUNqQixPQUFPLEVBQ1AsSUFBSSxFQUNKLE1BQU0sRUFDTixVQUFVLEVBQ1YsUUFBUSxFQUNSLGdCQUFnQixFQUNoQixVQUFVLEVBQ1YsU0FBUyxFQUNULEdBQUcsTUFBTSxFQUNILEVBQUUsRUFBRTtJQUNWLElBQUksVUFBVTtRQUFFLElBQUEsb0JBQVUsRUFBQyxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sRUFBRSxHQUFHLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFDcEUsSUFBSSxJQUFJO1FBQUUsSUFBQSxrQkFBTyxFQUFDLEVBQUUsU0FBUyxFQUFFLEdBQUcsTUFBTSxFQUFFLEdBQUcsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUVyRCxJQUFJLGlCQUFpQjtRQUFFLElBQUEscUJBQVcsRUFBQyxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDN0QsSUFBSSxPQUFPO1FBQUUsSUFBQSxpQkFBTyxFQUFDLEVBQUUsU0FBUyxFQUFFLEdBQUcsTUFBTSxFQUFFLEdBQUcsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUMzRCxJQUFJLElBQUk7UUFBRSxJQUFBLGNBQUksRUFBQyxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDLENBQUM7SUFDbEQsSUFBSSxNQUFNO1FBQUUsTUFBTSxJQUFBLGdCQUFNLEVBQUMsRUFBRSxTQUFTLEVBQUUsR0FBRyxNQUFNLEVBQUUsR0FBRyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQzlELElBQUksVUFBVTtRQUFFLE1BQU0sSUFBQSxvQkFBVSxFQUFDLEVBQUUsR0FBRyxNQUFNLEVBQUUsR0FBRyxVQUFVLEVBQUUsQ0FBQyxDQUFDO0lBQy9ELElBQUksUUFBUTtRQUFFLElBQUEsa0JBQVEsRUFBQyxFQUFFLEdBQUcsTUFBTSxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUNuRCxJQUFJLGdCQUFnQjtRQUNsQixJQUFBLDJCQUFnQixFQUFDLEVBQUUsU0FBUyxFQUFFLEdBQUcsTUFBTSxFQUFFLEdBQUcsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDO0lBQ2xFLElBQUksVUFBVTtRQUFFLElBQUEsb0JBQVUsRUFBQyxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sRUFBRSxHQUFHLFVBQVUsRUFBRSxDQUFDLENBQUM7QUFDdEUsQ0FBQyxDQUFDIn0=
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { KeyVaultInfo } from '../../types';
|
|
2
|
-
import { Input, Output } from '@pulumi/pulumi';
|
|
3
|
-
interface Props {
|
|
4
|
-
config: {
|
|
5
|
-
[key: string]: string | Input<string>;
|
|
6
|
-
};
|
|
7
|
-
vaultInfo: KeyVaultInfo;
|
|
8
|
-
}
|
|
9
|
-
/** Resolve the secrets from KeyVault*/
|
|
10
|
-
export declare const secretOutput: (vaultInfo: KeyVaultInfo, ...names: string[]) => Output<Array<string | undefined>>;
|
|
11
|
-
declare const resolver: ({ config, vaultInfo }: Props) => Promise<{
|
|
12
|
-
configMap: Record<string, Input<string>>;
|
|
13
|
-
secrets: Record<string, Input<string>>;
|
|
14
|
-
}>;
|
|
15
|
-
export default resolver;
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.secretOutput = void 0;
|
|
4
|
-
const Helper_1 = require("../../KeyVault/Helper");
|
|
5
|
-
const pulumi_1 = require("@pulumi/pulumi");
|
|
6
|
-
/** Resolve the secrets from KeyVault*/
|
|
7
|
-
const secretOutput = (vaultInfo, ...names) => (0, pulumi_1.output)(Promise.all(names.map(async (n) => {
|
|
8
|
-
const rs = await (0, Helper_1.getSecret)({ name: n, vaultInfo });
|
|
9
|
-
return rs?.value ?? n;
|
|
10
|
-
})));
|
|
11
|
-
exports.secretOutput = secretOutput;
|
|
12
|
-
const resolver = async ({ config, vaultInfo }) => {
|
|
13
|
-
const secrets = {};
|
|
14
|
-
const configMap = {};
|
|
15
|
-
const notfound = new Array();
|
|
16
|
-
const rs = await Promise.all(Object.keys(config)
|
|
17
|
-
.sort()
|
|
18
|
-
.map(async (k) => {
|
|
19
|
-
let value = config[k];
|
|
20
|
-
let secret = false;
|
|
21
|
-
if (typeof value === 'string' &&
|
|
22
|
-
value.startsWith('$(') &&
|
|
23
|
-
value.endsWith(')')) {
|
|
24
|
-
secret = true;
|
|
25
|
-
const key = value.replace('$(', '').replace(')', '').trim();
|
|
26
|
-
value = (await (0, Helper_1.getSecret)({ name: key, vaultInfo }))?.value;
|
|
27
|
-
}
|
|
28
|
-
if (value)
|
|
29
|
-
return { key: k, value, secret };
|
|
30
|
-
else {
|
|
31
|
-
notfound.push(k);
|
|
32
|
-
return undefined;
|
|
33
|
-
}
|
|
34
|
-
}));
|
|
35
|
-
if (notfound.length > 0) {
|
|
36
|
-
throw new Error(`The variable "${notfound.join('\n')}" is invalid or not from: ${vaultInfo.name}`);
|
|
37
|
-
}
|
|
38
|
-
rs.forEach((v) => {
|
|
39
|
-
if (!v)
|
|
40
|
-
return;
|
|
41
|
-
if (v.secret)
|
|
42
|
-
secrets[v.key] = v.value;
|
|
43
|
-
else
|
|
44
|
-
configMap[v.key] = v.value;
|
|
45
|
-
});
|
|
46
|
-
return { configMap, secrets };
|
|
47
|
-
};
|
|
48
|
-
exports.default = resolver;
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvS3ViZVgvVmFpcmFibGVSZXNvbHZlcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0Esa0RBQWtEO0FBQ2xELDJDQUF1RDtBQU92RCx1Q0FBdUM7QUFDaEMsTUFBTSxZQUFZLEdBQUcsQ0FDMUIsU0FBdUIsRUFDdkIsR0FBRyxLQUFlLEVBQ2lCLEVBQUUsQ0FDckMsSUFBQSxlQUFNLEVBQ0osT0FBTyxDQUFDLEdBQUcsQ0FDVCxLQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDLEVBQUUsRUFBRTtJQUNwQixNQUFNLEVBQUUsR0FBRyxNQUFNLElBQUEsa0JBQVMsRUFBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUNuRCxPQUFPLEVBQUUsRUFBRSxLQUFLLElBQUksQ0FBQyxDQUFDO0FBQ3hCLENBQUMsQ0FBQyxDQUNILENBQ0YsQ0FBQztBQVhTLFFBQUEsWUFBWSxnQkFXckI7QUFFSixNQUFNLFFBQVEsR0FBRyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFTLEVBQUUsRUFBRTtJQUN0RCxNQUFNLE9BQU8sR0FBa0MsRUFBRSxDQUFDO0lBQ2xELE1BQU0sU0FBUyxHQUFrQyxFQUFFLENBQUM7SUFDcEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLEVBQVUsQ0FBQztJQUVyQyxNQUFNLEVBQUUsR0FBRyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQzFCLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDO1NBQ2hCLElBQUksRUFBRTtTQUNOLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDZixJQUFJLEtBQUssR0FBOEIsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pELElBQUksTUFBTSxHQUFZLEtBQUssQ0FBQztRQUU1QixJQUNFLE9BQU8sS0FBSyxLQUFLLFFBQVE7WUFDekIsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUM7WUFDdEIsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFDbkIsQ0FBQztZQUNELE1BQU0sR0FBRyxJQUFJLENBQUM7WUFDZCxNQUFNLEdBQUcsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQzVELEtBQUssR0FBRyxDQUFDLE1BQU0sSUFBQSxrQkFBUyxFQUFDLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDO1FBQzdELENBQUM7UUFFRCxJQUFJLEtBQUs7WUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7YUFDdkMsQ0FBQztZQUNKLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDakIsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztJQUNILENBQUMsQ0FBQyxDQUNMLENBQUM7SUFFRixJQUFJLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FDYixpQkFBaUIsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsNkJBQ2xDLFNBQVMsQ0FBQyxJQUNaLEVBQUUsQ0FDSCxDQUFDO0lBQ0osQ0FBQztJQUVELEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtRQUNmLElBQUksQ0FBQyxDQUFDO1lBQUUsT0FBTztRQUNmLElBQUksQ0FBQyxDQUFDLE1BQU07WUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUM7O1lBQ2xDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUNsQyxDQUFDLENBQUMsQ0FBQztJQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLENBQUM7QUFDaEMsQ0FBQyxDQUFDO0FBRUYsa0JBQWUsUUFBUSxDQUFDIn0=
|
package/KubeX/kx/index.d.ts
DELETED
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import * as k8s from '@pulumi/kubernetes';
|
|
2
|
-
import * as pulumi from '@pulumi/pulumi';
|
|
3
|
-
export declare namespace types {
|
|
4
|
-
type EnvMap = Record<string, pulumi.Input<string | k8s.types.input.core.v1.EnvVarSource>>;
|
|
5
|
-
type PortMap = Record<string, pulumi.Input<number>>;
|
|
6
|
-
enum ServiceType {
|
|
7
|
-
ClusterIP = "ClusterIP",
|
|
8
|
-
LoadBalancer = "LoadBalancer"
|
|
9
|
-
}
|
|
10
|
-
type VolumeMount = {
|
|
11
|
-
volume: pulumi.Input<k8s.types.input.core.v1.Volume>;
|
|
12
|
-
destPath: pulumi.Input<string>;
|
|
13
|
-
srcPath?: pulumi.Input<string>;
|
|
14
|
-
};
|
|
15
|
-
type Container = Omit<k8s.types.input.core.v1.Container, 'env' | 'name' | 'ports' | 'volumeMounts'> & {
|
|
16
|
-
env?: pulumi.Input<pulumi.Input<k8s.types.input.core.v1.EnvVar>[] | EnvMap>;
|
|
17
|
-
name?: pulumi.Input<string>;
|
|
18
|
-
ports?: pulumi.Input<pulumi.Input<k8s.types.input.core.v1.ContainerPort>[] | PortMap>;
|
|
19
|
-
volumeMounts?: pulumi.Input<pulumi.Input<k8s.types.input.core.v1.VolumeMount | VolumeMount>[]>;
|
|
20
|
-
};
|
|
21
|
-
type PodSpec = Omit<k8s.types.input.core.v1.PodSpec, 'containers' | 'initContainers'> & {
|
|
22
|
-
containers: pulumi.Input<pulumi.Input<Container>[]>;
|
|
23
|
-
initContainers?: pulumi.Input<pulumi.Input<Container>[]>;
|
|
24
|
-
};
|
|
25
|
-
type Pod = Omit<k8s.types.input.core.v1.Pod, 'spec'> & {
|
|
26
|
-
spec: pulumi.Input<PodSpec | PodBuilder>;
|
|
27
|
-
};
|
|
28
|
-
type DeploymentSpec = Omit<k8s.types.input.apps.v1.DeploymentSpec, 'template'> & {
|
|
29
|
-
template: pulumi.Input<Pod>;
|
|
30
|
-
};
|
|
31
|
-
type Deployment = Omit<k8s.types.input.apps.v1.Deployment, 'spec'> & {
|
|
32
|
-
spec: pulumi.Input<DeploymentSpec | k8s.types.input.apps.v1.DeploymentSpec>;
|
|
33
|
-
};
|
|
34
|
-
type ServiceSpec = Omit<k8s.types.input.core.v1.ServiceSpec, 'ports' | 'type'> & {
|
|
35
|
-
name?: string;
|
|
36
|
-
ports?: pulumi.Input<pulumi.Input<k8s.types.input.core.v1.ServicePort>[] | PortMap>;
|
|
37
|
-
type?: pulumi.Input<ServiceType | string>;
|
|
38
|
-
};
|
|
39
|
-
type Service = Omit<k8s.types.input.core.v1.Service, 'spec'> & {
|
|
40
|
-
spec: pulumi.Input<ServiceSpec>;
|
|
41
|
-
};
|
|
42
|
-
type StatefulSetSpec = Omit<k8s.types.input.apps.v1.StatefulSetSpec, 'template'> & {
|
|
43
|
-
template: pulumi.Input<Pod>;
|
|
44
|
-
};
|
|
45
|
-
type StatefulSet = Omit<k8s.types.input.apps.v1.StatefulSet, 'spec'> & {
|
|
46
|
-
spec: pulumi.Input<StatefulSetSpec | k8s.types.input.apps.v1.StatefulSetSpec>;
|
|
47
|
-
};
|
|
48
|
-
type JobSpec = Omit<k8s.types.input.batch.v1.JobSpec, 'template'> & {
|
|
49
|
-
template: pulumi.Input<Pod>;
|
|
50
|
-
};
|
|
51
|
-
type Job = Omit<k8s.types.input.batch.v1.Job, 'spec'> & {
|
|
52
|
-
spec: pulumi.Input<JobSpec | k8s.types.input.batch.v1.JobSpec>;
|
|
53
|
-
};
|
|
54
|
-
type CronJobSpec = Omit<k8s.types.input.batch.v1.CronJobSpec, 'jobTemplate'> & {
|
|
55
|
-
template: pulumi.Input<Pod>;
|
|
56
|
-
};
|
|
57
|
-
type CronJob = Omit<k8s.types.input.batch.v1.CronJob, 'spec'> & {
|
|
58
|
-
spec: pulumi.Input<CronJobSpec | k8s.types.input.batch.v1.CronJobSpec>;
|
|
59
|
-
};
|
|
60
|
-
type PodBuilderDeploymentSpec = Omit<k8s.types.input.apps.v1.DeploymentSpec, 'selector' | 'template'>;
|
|
61
|
-
type PodBuilderJobSpec = Omit<k8s.types.input.batch.v1.JobSpec, 'template'>;
|
|
62
|
-
}
|
|
63
|
-
export declare class PodBuilder {
|
|
64
|
-
readonly podSpec: pulumi.Output<k8s.types.input.core.v1.PodSpec>;
|
|
65
|
-
private readonly podName;
|
|
66
|
-
constructor(args: types.PodSpec);
|
|
67
|
-
asDeploymentSpec(args?: types.PodBuilderDeploymentSpec): pulumi.Output<k8s.types.input.apps.v1.DeploymentSpec>;
|
|
68
|
-
asStatefulSetSpec(args?: {
|
|
69
|
-
replicas?: number;
|
|
70
|
-
}): pulumi.Output<k8s.types.input.apps.v1.StatefulSetSpec>;
|
|
71
|
-
asJobSpec(args?: types.PodBuilderJobSpec): pulumi.Output<k8s.types.input.batch.v1.JobSpec>;
|
|
72
|
-
asCronJobSpec({ schedule, concurrencyPolicy, failedJobsHistoryLimit, startingDeadlineSeconds, suspend, successfulJobsHistoryLimit, ...args }: Partial<types.PodBuilderJobSpec> & Omit<k8s.types.input.batch.v1.CronJobSpec, 'jobTemplate'>): pulumi.Output<k8s.types.input.batch.v1.CronJobSpec>;
|
|
73
|
-
}
|
|
74
|
-
export declare class Pod extends k8s.core.v1.Pod {
|
|
75
|
-
constructor(name: string, args: types.Pod, opts?: pulumi.CustomResourceOptions);
|
|
76
|
-
}
|
|
77
|
-
export declare class Deployment extends k8s.apps.v1.Deployment {
|
|
78
|
-
readonly name: string;
|
|
79
|
-
private readonly opts?;
|
|
80
|
-
constructor(name: string, args: types.Deployment, opts?: pulumi.CustomResourceOptions);
|
|
81
|
-
createService({ name, ...args }?: types.ServiceSpec): Service;
|
|
82
|
-
}
|
|
83
|
-
export declare class Service extends k8s.core.v1.Service {
|
|
84
|
-
constructor(name: string, args: types.Service, opts?: pulumi.CustomResourceOptions);
|
|
85
|
-
/**
|
|
86
|
-
* Endpoint of the Service. This can be either an IP address or a hostname,
|
|
87
|
-
* depending on the k8s cluster provider.
|
|
88
|
-
*/
|
|
89
|
-
get endpoint(): pulumi.Output<string>;
|
|
90
|
-
}
|
|
91
|
-
export declare class StatefulSet extends pulumi.ComponentResource {
|
|
92
|
-
private readonly name;
|
|
93
|
-
private readonly opts?;
|
|
94
|
-
constructor(name: string, args: types.StatefulSet, opts?: pulumi.CustomResourceOptions);
|
|
95
|
-
}
|
|
96
|
-
export declare class Job extends k8s.batch.v1.Job {
|
|
97
|
-
private readonly name;
|
|
98
|
-
private readonly opts?;
|
|
99
|
-
constructor(name: string, args: types.Job, opts?: pulumi.CustomResourceOptions);
|
|
100
|
-
}
|
|
101
|
-
export declare class PersistentVolumeClaim extends k8s.core.v1.PersistentVolumeClaim {
|
|
102
|
-
constructor(name: string, args: k8s.types.input.core.v1.PersistentVolumeClaim, opts?: pulumi.CustomResourceOptions);
|
|
103
|
-
mount(destPath: pulumi.Input<string>, srcPath?: pulumi.Input<string>): pulumi.Output<types.VolumeMount>;
|
|
104
|
-
}
|
|
105
|
-
export declare class ConfigMap extends k8s.core.v1.ConfigMap {
|
|
106
|
-
constructor(name: string, args: k8s.types.input.core.v1.ConfigMap, opts?: pulumi.CustomResourceOptions);
|
|
107
|
-
mount(destPath: pulumi.Input<string>, srcPath?: pulumi.Input<string>): pulumi.Output<types.VolumeMount>;
|
|
108
|
-
asEnvValue(key: pulumi.Input<string>): pulumi.Output<k8s.types.input.core.v1.EnvVarSource>;
|
|
109
|
-
}
|
|
110
|
-
export declare class Secret extends k8s.core.v1.Secret {
|
|
111
|
-
constructor(name: string, args: k8s.types.input.core.v1.Secret, opts?: pulumi.CustomResourceOptions);
|
|
112
|
-
mount(destPath: pulumi.Input<string>, srcPath?: pulumi.Input<string>): pulumi.Output<types.VolumeMount>;
|
|
113
|
-
asEnvValue(key: pulumi.Input<string>): pulumi.Output<k8s.types.input.core.v1.EnvVarSource>;
|
|
114
|
-
}
|
package/KubeX/kx/index.js
DELETED
|
@@ -1,423 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// Copyright 2016-2019, Pulumi Corporation.
|
|
3
|
-
//
|
|
4
|
-
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
// you may not use this file except in compliance with the License.
|
|
6
|
-
// You may obtain a copy of the License at
|
|
7
|
-
//
|
|
8
|
-
// http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
//
|
|
10
|
-
// Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
// See the License for the specific language governing permissions and
|
|
14
|
-
// limitations under the License.
|
|
15
|
-
// Copy from https://github.com/pulumi/pulumi-kubernetesx
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.Secret = exports.ConfigMap = exports.PersistentVolumeClaim = exports.Job = exports.StatefulSet = exports.Service = exports.Deployment = exports.Pod = exports.PodBuilder = exports.types = void 0;
|
|
18
|
-
const k8s = require("@pulumi/kubernetes");
|
|
19
|
-
const pulumi = require("@pulumi/pulumi");
|
|
20
|
-
var types;
|
|
21
|
-
(function (types) {
|
|
22
|
-
let ServiceType;
|
|
23
|
-
(function (ServiceType) {
|
|
24
|
-
ServiceType["ClusterIP"] = "ClusterIP";
|
|
25
|
-
ServiceType["LoadBalancer"] = "LoadBalancer";
|
|
26
|
-
})(ServiceType = types.ServiceType || (types.ServiceType = {}));
|
|
27
|
-
})(types || (exports.types = types = {}));
|
|
28
|
-
function buildPodSpec(args) {
|
|
29
|
-
return pulumi.output(args).apply((podSpec) => {
|
|
30
|
-
const volumes = [];
|
|
31
|
-
let initContainers = [];
|
|
32
|
-
if (podSpec.initContainers) {
|
|
33
|
-
initContainers = podSpec.initContainers.map((container) => buildContainer(container, volumes));
|
|
34
|
-
}
|
|
35
|
-
const containers = podSpec.containers.map((container) => buildContainer(container, volumes));
|
|
36
|
-
return pulumi.output({
|
|
37
|
-
...podSpec,
|
|
38
|
-
initContainers: initContainers,
|
|
39
|
-
containers: containers,
|
|
40
|
-
volumes: [...(podSpec.volumes || []), ...volumes],
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
function buildContainer(container, volumes) {
|
|
45
|
-
const isEnvMap = (env) => env.length === undefined;
|
|
46
|
-
const isPortMap = (ports) => ports.length === undefined;
|
|
47
|
-
const isMountObject = (object) => object.hasOwnProperty('volume');
|
|
48
|
-
const c = {
|
|
49
|
-
...container,
|
|
50
|
-
env: [],
|
|
51
|
-
name: '',
|
|
52
|
-
ports: [],
|
|
53
|
-
volumeMounts: [],
|
|
54
|
-
};
|
|
55
|
-
if (container.name) {
|
|
56
|
-
c.name = container.name;
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
const re = /(.*\/|^)(?<image>\w+)(:(?<tag>.*))?/;
|
|
60
|
-
const imageArg = container.image || '';
|
|
61
|
-
const result = re.exec(imageArg);
|
|
62
|
-
if (!result) {
|
|
63
|
-
throw new Error('Failed to parse image name from ' + imageArg);
|
|
64
|
-
}
|
|
65
|
-
c.name = result[2];
|
|
66
|
-
}
|
|
67
|
-
const env = container.env;
|
|
68
|
-
if (env) {
|
|
69
|
-
if (isEnvMap(env)) {
|
|
70
|
-
Object.keys(env).forEach((key) => {
|
|
71
|
-
const value = env[key];
|
|
72
|
-
if (typeof value === 'string') {
|
|
73
|
-
c.env.push({ name: key, value: value });
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
c.env.push({ name: key, valueFrom: value });
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
c.env = env;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
const ports = container.ports;
|
|
85
|
-
if (ports) {
|
|
86
|
-
if (isPortMap(ports)) {
|
|
87
|
-
Object.keys(ports).forEach((key) => {
|
|
88
|
-
const value = ports[key];
|
|
89
|
-
c.ports.push({ name: key, containerPort: value });
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
c.ports = ports;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
const volumeMounts = container.volumeMounts;
|
|
97
|
-
if (volumeMounts) {
|
|
98
|
-
volumeMounts.forEach((mount) => {
|
|
99
|
-
if (isMountObject(mount)) {
|
|
100
|
-
c.volumeMounts.push({
|
|
101
|
-
name: mount.volume.name,
|
|
102
|
-
mountPath: mount.destPath,
|
|
103
|
-
subPath: mount.srcPath,
|
|
104
|
-
});
|
|
105
|
-
volumes.push({
|
|
106
|
-
...mount.volume,
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
c.volumeMounts.push(mount);
|
|
111
|
-
}
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
return c;
|
|
115
|
-
}
|
|
116
|
-
class PodBuilder {
|
|
117
|
-
podSpec;
|
|
118
|
-
podName;
|
|
119
|
-
constructor(args) {
|
|
120
|
-
this.podSpec = buildPodSpec(args);
|
|
121
|
-
this.podName = this.podSpec.containers.apply((containers) => pulumi.output(containers[0].name));
|
|
122
|
-
}
|
|
123
|
-
asDeploymentSpec(args) {
|
|
124
|
-
const appLabels = { app: this.podName };
|
|
125
|
-
const _args = args || {};
|
|
126
|
-
const deploymentSpec = {
|
|
127
|
-
..._args,
|
|
128
|
-
selector: { matchLabels: appLabels },
|
|
129
|
-
replicas: _args.replicas ?? 1,
|
|
130
|
-
template: {
|
|
131
|
-
metadata: { labels: appLabels },
|
|
132
|
-
spec: this.podSpec,
|
|
133
|
-
},
|
|
134
|
-
};
|
|
135
|
-
return pulumi.output(deploymentSpec);
|
|
136
|
-
}
|
|
137
|
-
asStatefulSetSpec(args) {
|
|
138
|
-
const appLabels = { app: this.podName };
|
|
139
|
-
const statefulSetSpec = {
|
|
140
|
-
selector: { matchLabels: appLabels },
|
|
141
|
-
replicas: args?.replicas ?? 1,
|
|
142
|
-
serviceName: '', // This will be auto-generated by kx.StatefulSet.
|
|
143
|
-
template: {
|
|
144
|
-
metadata: { labels: appLabels },
|
|
145
|
-
spec: this.podSpec,
|
|
146
|
-
},
|
|
147
|
-
};
|
|
148
|
-
return pulumi.output(statefulSetSpec);
|
|
149
|
-
}
|
|
150
|
-
asJobSpec(args) {
|
|
151
|
-
const appLabels = { app: this.podName };
|
|
152
|
-
const jobSpec = {
|
|
153
|
-
...args,
|
|
154
|
-
template: {
|
|
155
|
-
metadata: { labels: appLabels },
|
|
156
|
-
spec: this.podSpec,
|
|
157
|
-
},
|
|
158
|
-
};
|
|
159
|
-
return pulumi.output(jobSpec);
|
|
160
|
-
}
|
|
161
|
-
asCronJobSpec({ schedule, concurrencyPolicy, failedJobsHistoryLimit, startingDeadlineSeconds, suspend, successfulJobsHistoryLimit, ...args }) {
|
|
162
|
-
const appLabels = { app: this.podName };
|
|
163
|
-
const jobSpec = {
|
|
164
|
-
schedule,
|
|
165
|
-
concurrencyPolicy,
|
|
166
|
-
failedJobsHistoryLimit,
|
|
167
|
-
startingDeadlineSeconds,
|
|
168
|
-
suspend,
|
|
169
|
-
successfulJobsHistoryLimit,
|
|
170
|
-
jobTemplate: {
|
|
171
|
-
metadata: {
|
|
172
|
-
labels: appLabels,
|
|
173
|
-
annotations: { 'pulumi.com/skipAwait': 'true' },
|
|
174
|
-
},
|
|
175
|
-
spec: this.asJobSpec(args),
|
|
176
|
-
},
|
|
177
|
-
};
|
|
178
|
-
return pulumi.output(jobSpec);
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
exports.PodBuilder = PodBuilder;
|
|
182
|
-
class Pod extends k8s.core.v1.Pod {
|
|
183
|
-
constructor(name, args, opts) {
|
|
184
|
-
const isPodBuilder = (object) => object.hasOwnProperty('podSpec');
|
|
185
|
-
const spec = pulumi
|
|
186
|
-
.output(args.spec)
|
|
187
|
-
.apply((specArg) => {
|
|
188
|
-
if (isPodBuilder(specArg)) {
|
|
189
|
-
return pulumi.output(specArg.podSpec);
|
|
190
|
-
}
|
|
191
|
-
else {
|
|
192
|
-
return buildPodSpec(specArg);
|
|
193
|
-
}
|
|
194
|
-
});
|
|
195
|
-
super(name, {
|
|
196
|
-
...args,
|
|
197
|
-
spec: spec,
|
|
198
|
-
}, opts);
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
exports.Pod = Pod;
|
|
202
|
-
class Deployment extends k8s.apps.v1.Deployment {
|
|
203
|
-
name;
|
|
204
|
-
opts;
|
|
205
|
-
constructor(name, args, opts) {
|
|
206
|
-
const spec = pulumi
|
|
207
|
-
.output(args)
|
|
208
|
-
.apply((args) => {
|
|
209
|
-
const podSpec = buildPodSpec(args.spec.template.spec);
|
|
210
|
-
return pulumi.output({
|
|
211
|
-
...args.spec,
|
|
212
|
-
template: {
|
|
213
|
-
...args.spec.template,
|
|
214
|
-
spec: podSpec,
|
|
215
|
-
},
|
|
216
|
-
});
|
|
217
|
-
});
|
|
218
|
-
super(name, {
|
|
219
|
-
...args,
|
|
220
|
-
spec: spec,
|
|
221
|
-
}, opts);
|
|
222
|
-
this.name = name;
|
|
223
|
-
this.opts = opts;
|
|
224
|
-
}
|
|
225
|
-
createService({ name, ...args } = {}) {
|
|
226
|
-
const serviceSpec = pulumi
|
|
227
|
-
.all([this.spec.template.spec.containers, args])
|
|
228
|
-
.apply(([containers, args]) => {
|
|
229
|
-
// TODO: handle merging ports from args
|
|
230
|
-
const ports = {};
|
|
231
|
-
containers.forEach((container) => {
|
|
232
|
-
if (container.ports) {
|
|
233
|
-
container.ports.forEach((port) => {
|
|
234
|
-
ports[port.name] = port.containerPort;
|
|
235
|
-
});
|
|
236
|
-
}
|
|
237
|
-
});
|
|
238
|
-
return {
|
|
239
|
-
...args,
|
|
240
|
-
ports: args.ports || ports,
|
|
241
|
-
selector: this.spec.selector.matchLabels,
|
|
242
|
-
// TODO: probably need to unwrap args.type in case it's a computed value
|
|
243
|
-
type: args && args.type,
|
|
244
|
-
};
|
|
245
|
-
});
|
|
246
|
-
return new Service(this.name, {
|
|
247
|
-
metadata: {
|
|
248
|
-
name,
|
|
249
|
-
namespace: this.metadata.namespace,
|
|
250
|
-
annotations: { 'pulumi.com/skipAwait': 'true' },
|
|
251
|
-
},
|
|
252
|
-
spec: serviceSpec,
|
|
253
|
-
}, { ...this.opts, parent: this, dependsOn: this, deleteBeforeReplace: true });
|
|
254
|
-
}
|
|
255
|
-
}
|
|
256
|
-
exports.Deployment = Deployment;
|
|
257
|
-
class Service extends k8s.core.v1.Service {
|
|
258
|
-
constructor(name, args, opts) {
|
|
259
|
-
const spec = pulumi
|
|
260
|
-
.output(args)
|
|
261
|
-
.apply((args) => {
|
|
262
|
-
const isPortMap = (ports) => ports.length === undefined;
|
|
263
|
-
let ports = [];
|
|
264
|
-
const portsArg = args.spec.ports;
|
|
265
|
-
if (portsArg) {
|
|
266
|
-
if (isPortMap(portsArg)) {
|
|
267
|
-
Object.keys(portsArg).forEach((key) => {
|
|
268
|
-
const value = portsArg[key];
|
|
269
|
-
ports.push({ name: key, port: value });
|
|
270
|
-
});
|
|
271
|
-
}
|
|
272
|
-
else {
|
|
273
|
-
ports = portsArg;
|
|
274
|
-
}
|
|
275
|
-
}
|
|
276
|
-
return {
|
|
277
|
-
...args.spec,
|
|
278
|
-
ports: ports,
|
|
279
|
-
type: args.spec.type,
|
|
280
|
-
};
|
|
281
|
-
});
|
|
282
|
-
super(name, {
|
|
283
|
-
...args,
|
|
284
|
-
spec: spec,
|
|
285
|
-
}, opts);
|
|
286
|
-
}
|
|
287
|
-
/**
|
|
288
|
-
* Endpoint of the Service. This can be either an IP address or a hostname,
|
|
289
|
-
* depending on the k8s cluster provider.
|
|
290
|
-
*/
|
|
291
|
-
get endpoint() {
|
|
292
|
-
return this.status.loadBalancer.ingress.apply((ingress) => {
|
|
293
|
-
if (ingress.length > 0) {
|
|
294
|
-
return ingress[0].ip || ingress[0].hostname;
|
|
295
|
-
}
|
|
296
|
-
return '';
|
|
297
|
-
});
|
|
298
|
-
}
|
|
299
|
-
}
|
|
300
|
-
exports.Service = Service;
|
|
301
|
-
class StatefulSet extends pulumi.ComponentResource {
|
|
302
|
-
name;
|
|
303
|
-
opts;
|
|
304
|
-
constructor(name, args, opts) {
|
|
305
|
-
const spec = pulumi
|
|
306
|
-
.output(args)
|
|
307
|
-
.apply((args) => {
|
|
308
|
-
const podSpec = buildPodSpec(args.spec.template.spec);
|
|
309
|
-
return pulumi.output({
|
|
310
|
-
...args.spec,
|
|
311
|
-
serviceName: `${name}-service`,
|
|
312
|
-
template: {
|
|
313
|
-
...args.spec.template,
|
|
314
|
-
spec: podSpec,
|
|
315
|
-
},
|
|
316
|
-
});
|
|
317
|
-
});
|
|
318
|
-
super('kubernetesx:StatefulSet', name, { ...args, spec: spec }, opts);
|
|
319
|
-
const statefulSet = new k8s.apps.v1.StatefulSet(name, { ...args, spec: spec }, { ...opts, parent: this });
|
|
320
|
-
this.name = name;
|
|
321
|
-
this.opts = opts;
|
|
322
|
-
}
|
|
323
|
-
}
|
|
324
|
-
exports.StatefulSet = StatefulSet;
|
|
325
|
-
class Job extends k8s.batch.v1.Job {
|
|
326
|
-
name;
|
|
327
|
-
opts;
|
|
328
|
-
constructor(name, args, opts) {
|
|
329
|
-
const spec = pulumi
|
|
330
|
-
.output(args)
|
|
331
|
-
.apply((args) => {
|
|
332
|
-
const podSpec = buildPodSpec(args.spec.template.spec);
|
|
333
|
-
return pulumi.output({
|
|
334
|
-
...args.spec,
|
|
335
|
-
template: {
|
|
336
|
-
...args.spec.template,
|
|
337
|
-
spec: podSpec,
|
|
338
|
-
},
|
|
339
|
-
});
|
|
340
|
-
});
|
|
341
|
-
super(name, {
|
|
342
|
-
...args,
|
|
343
|
-
spec: spec,
|
|
344
|
-
}, opts);
|
|
345
|
-
this.name = name;
|
|
346
|
-
this.opts = opts;
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
exports.Job = Job;
|
|
350
|
-
class PersistentVolumeClaim extends k8s.core.v1.PersistentVolumeClaim {
|
|
351
|
-
constructor(name, args, opts) {
|
|
352
|
-
super(name, args, opts);
|
|
353
|
-
}
|
|
354
|
-
// TODO: define input type?
|
|
355
|
-
mount(destPath, srcPath) {
|
|
356
|
-
return pulumi.output({
|
|
357
|
-
volume: {
|
|
358
|
-
name: this.metadata.name,
|
|
359
|
-
persistentVolumeClaim: {
|
|
360
|
-
claimName: this.metadata.name,
|
|
361
|
-
},
|
|
362
|
-
},
|
|
363
|
-
destPath: destPath,
|
|
364
|
-
srcPath: srcPath,
|
|
365
|
-
});
|
|
366
|
-
}
|
|
367
|
-
}
|
|
368
|
-
exports.PersistentVolumeClaim = PersistentVolumeClaim;
|
|
369
|
-
class ConfigMap extends k8s.core.v1.ConfigMap {
|
|
370
|
-
constructor(name, args, opts) {
|
|
371
|
-
super(name, args, opts);
|
|
372
|
-
}
|
|
373
|
-
mount(destPath, srcPath) {
|
|
374
|
-
return pulumi.output({
|
|
375
|
-
volume: {
|
|
376
|
-
name: this.metadata.name,
|
|
377
|
-
configMap: {
|
|
378
|
-
name: this.metadata.name,
|
|
379
|
-
// TODO: items
|
|
380
|
-
},
|
|
381
|
-
},
|
|
382
|
-
destPath: destPath,
|
|
383
|
-
srcPath: srcPath,
|
|
384
|
-
});
|
|
385
|
-
}
|
|
386
|
-
asEnvValue(key) {
|
|
387
|
-
return pulumi.output({
|
|
388
|
-
configMapKeyRef: {
|
|
389
|
-
name: this.metadata.name,
|
|
390
|
-
key: key,
|
|
391
|
-
},
|
|
392
|
-
});
|
|
393
|
-
}
|
|
394
|
-
}
|
|
395
|
-
exports.ConfigMap = ConfigMap;
|
|
396
|
-
class Secret extends k8s.core.v1.Secret {
|
|
397
|
-
constructor(name, args, opts) {
|
|
398
|
-
super(name, args, opts);
|
|
399
|
-
}
|
|
400
|
-
mount(destPath, srcPath) {
|
|
401
|
-
return pulumi.output({
|
|
402
|
-
volume: {
|
|
403
|
-
name: this.metadata.name,
|
|
404
|
-
secret: {
|
|
405
|
-
secretName: this.metadata.name,
|
|
406
|
-
// TODO: items
|
|
407
|
-
},
|
|
408
|
-
},
|
|
409
|
-
destPath: destPath,
|
|
410
|
-
srcPath: srcPath,
|
|
411
|
-
});
|
|
412
|
-
}
|
|
413
|
-
asEnvValue(key) {
|
|
414
|
-
return pulumi.output({
|
|
415
|
-
secretKeyRef: {
|
|
416
|
-
name: this.metadata.name,
|
|
417
|
-
key: key,
|
|
418
|
-
},
|
|
419
|
-
});
|
|
420
|
-
}
|
|
421
|
-
}
|
|
422
|
-
exports.Secret = Secret;
|
|
423
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvS3ViZVgva3gvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDJDQUEyQztBQUMzQyxFQUFFO0FBQ0Ysa0VBQWtFO0FBQ2xFLG1FQUFtRTtBQUNuRSwwQ0FBMEM7QUFDMUMsRUFBRTtBQUNGLGlEQUFpRDtBQUNqRCxFQUFFO0FBQ0Ysc0VBQXNFO0FBQ3RFLG9FQUFvRTtBQUNwRSwyRUFBMkU7QUFDM0Usc0VBQXNFO0FBQ3RFLGlDQUFpQztBQUNqQyx5REFBeUQ7OztBQUV6RCwwQ0FBMEM7QUFDMUMseUNBQXlDO0FBRXpDLElBQWlCLEtBQUssQ0FzR3JCO0FBdEdELFdBQWlCLEtBQUs7SUFPcEIsSUFBWSxXQUdYO0lBSEQsV0FBWSxXQUFXO1FBQ3JCLHNDQUF1QixDQUFBO1FBQ3ZCLDRDQUE2QixDQUFBO0lBQy9CLENBQUMsRUFIVyxXQUFXLEdBQVgsaUJBQVcsS0FBWCxpQkFBVyxRQUd0QjtBQTRGSCxDQUFDLEVBdEdnQixLQUFLLHFCQUFMLEtBQUssUUFzR3JCO0FBRUQsU0FBUyxZQUFZLENBQ25CLElBQWlDO0lBRWpDLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBZ0IsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7UUFDMUQsTUFBTSxPQUFPLEdBQXFDLEVBQUUsQ0FBQztRQUNyRCxJQUFJLGNBQWMsR0FBd0MsRUFBRSxDQUFDO1FBQzdELElBQUksT0FBTyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQzNCLGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQ3hELGNBQWMsQ0FBQyxTQUFTLEVBQUUsT0FBTyxDQUFDLENBQ25DLENBQUM7UUFDSixDQUFDO1FBQ0QsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxTQUFT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
|