@drunk-pulumi/azure 1.0.21 → 1.0.23
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.js +7 -6
- package/Aks/Identity.d.ts +1 -1
- package/Aks/Identity.js +1 -1
- package/Aks/index.d.ts +2 -3
- package/Aks/index.js +2 -2
- package/AzAd/B2C.d.ts +2 -2
- package/AzAd/B2C.js +13 -14
- package/AzAd/EnvRoles.Consts.d.ts +7 -5
- package/AzAd/EnvRoles.Consts.js +54 -42
- package/AzAd/EnvRoles.js +3 -3
- package/AzAd/Helper.js +14 -8
- package/AzAd/Identities/AzDevOpsIdentity.d.ts +1 -1
- package/AzAd/Identities/AzDevOpsIdentity.js +1 -1
- package/AzAd/Identities/AzUserAdRevertSync.d.ts +1 -1
- package/AzAd/Identity.d.ts +2 -11
- package/AzAd/Identity.js +4 -3
- package/AzAd/UserAssignedIdentity.js +7 -2
- package/Builder/AcrBuilder.d.ts +3 -0
- package/Builder/AcrBuilder.js +143 -0
- package/Builder/ApimApiBuilder.js +2 -3
- package/Builder/ApimBuilder.js +2 -2
- package/Builder/ApimProductBuilder.js +3 -4
- package/Builder/AppCertBuilder.d.ts +3 -0
- package/Builder/AppCertBuilder.js +75 -0
- package/Builder/AppConfigBuilder.d.ts +3 -0
- package/Builder/AppConfigBuilder.js +152 -0
- package/Builder/AutomationBuilder.d.ts +3 -0
- package/Builder/AutomationBuilder.js +106 -0
- package/Builder/IotHubBuilder.d.ts +3 -0
- package/Builder/IotHubBuilder.js +240 -0
- package/Builder/LogicAppBuilder.d.ts +3 -0
- package/Builder/LogicAppBuilder.js +69 -0
- package/Builder/MySqlBuilder.d.ts +3 -0
- package/Builder/MySqlBuilder.js +229 -0
- package/Builder/PostgreSqlBuilder.d.ts +3 -0
- package/Builder/PostgreSqlBuilder.js +235 -0
- package/Builder/RedisCacheBuilder.d.ts +3 -0
- package/Builder/RedisCacheBuilder.js +151 -0
- package/Builder/ResourceBuilder.js +52 -20
- package/Builder/ServiceBusBuilder.d.ts +3 -0
- package/Builder/ServiceBusBuilder.js +330 -0
- package/Builder/SignalRBuilder.d.ts +3 -0
- package/Builder/SignalRBuilder.js +179 -0
- package/Builder/StorageBuilder.js +3 -3
- package/Builder/VdiBuilder.js +2 -2
- package/Builder/index.d.ts +11 -0
- package/Builder/index.js +24 -2
- package/Builder/types/acrBuilder.d.ts +18 -0
- package/Builder/types/acrBuilder.js +3 -0
- package/Builder/types/appCertBuilder.d.ts +14 -0
- package/Builder/types/appCertBuilder.js +3 -0
- package/Builder/types/appConfigBuilder.d.ts +15 -0
- package/Builder/types/appConfigBuilder.js +3 -0
- package/Builder/types/automationBuilder.d.ts +11 -0
- package/Builder/types/automationBuilder.js +3 -0
- package/Builder/types/index.d.ts +12 -0
- package/Builder/types/index.js +13 -1
- package/Builder/types/iotHubBuilder.d.ts +31 -0
- package/Builder/types/iotHubBuilder.js +3 -0
- package/Builder/types/logicAppBuilder.d.ts +10 -0
- package/Builder/types/logicAppBuilder.js +3 -0
- package/Builder/types/mySqlBuilder.d.ts +45 -0
- package/Builder/types/mySqlBuilder.js +3 -0
- package/Builder/types/posgreSqlBuilder.d.ts +45 -0
- package/Builder/types/posgreSqlBuilder.js +3 -0
- package/Builder/types/redisCacheBuilder.d.ts +15 -0
- package/Builder/types/redisCacheBuilder.js +3 -0
- package/Builder/types/resourceBuilder.d.ts +2 -0
- package/Builder/types/serviceBusBuilder.d.ts +23 -0
- package/Builder/types/serviceBusBuilder.js +3 -0
- package/Builder/types/signalRBuilder.d.ts +38 -0
- package/Builder/types/signalRBuilder.js +3 -0
- package/Builder/types/storageBuilder.d.ts +3 -4
- package/Cdn/CdnEndpoint.js +2 -2
- package/Cdn/index.js +2 -2
- package/Common/AzureEnv.js +1 -1
- package/Common/GlobalEnv.js +6 -3
- package/Common/Naming/Rulers.d.ts +288 -0
- package/Common/Naming/Rulers.js +537 -0
- package/Common/Naming/index.d.ts +10 -0
- package/Common/Naming/index.js +112 -0
- package/Common/OpenApi/index.js +37 -0
- package/{Web → Common/OpenApi}/types.js +1 -1
- package/Common/RsInfo/Helper.d.ts +3 -3
- package/Common/RsInfo/Helper.js +12 -34
- package/Common/RsInfo/index.d.ts +24 -24
- package/Common/RsInfo/index.js +14 -14
- package/Common/index.d.ts +2 -4
- package/Common/index.js +8 -6
- package/Core/KeyGenerators.js +2 -2
- package/Core/Random.d.ts +1 -0
- package/Core/Random.js +9 -4
- package/CustomRoles/index.js +4 -4
- package/KeyVault/CustomHelper.js +4 -3
- package/KeyVault/Helper.d.ts +4 -0
- package/KeyVault/Helper.js +30 -4
- package/KeyVault/index.js +2 -2
- package/Logs/AppInsight.js +2 -2
- package/Logs/Helpers.js +7 -4
- package/Logs/LogAnalytics.js +2 -2
- package/Logs/WebTest.js +3 -3
- package/Logs/index.d.ts +1 -1
- package/Sql/Helper.js +3 -3
- package/Sql/SqlDb.js +2 -2
- package/Sql/index.js +3 -4
- package/Storage/Helper.js +6 -6
- package/Storage/ManagementRules.d.ts +2 -2
- package/Storage/ManagementRules.js +4 -4
- package/Storage/index.d.ts +4 -8
- package/Storage/index.js +50 -18
- package/VM/DiskEncryptionSet.js +2 -2
- package/VM/index.js +3 -3
- package/VNet/Bastion.js +2 -2
- package/VNet/Firewall.d.ts +2 -2
- package/VNet/Firewall.js +4 -4
- package/VNet/FirewallPolicy.js +2 -2
- package/VNet/GlobalNetworkPeering.js +4 -4
- package/VNet/IpAddress.js +1 -1
- package/VNet/IpAddressPrefix.js +2 -2
- package/VNet/NSGRules/ApimSecurityRule.d.ts +1 -1
- package/VNet/NSGRules/ApimSecurityRule.js +20 -20
- package/VNet/NatGateway.d.ts +2 -2
- package/VNet/NatGateway.js +3 -3
- package/VNet/NetworkPeering.js +1 -1
- package/VNet/PrivateEndpoint.d.ts +1 -0
- package/VNet/PrivateEndpoint.js +2 -2
- package/VNet/RouteTable.js +4 -5
- package/VNet/SecurityGroup.d.ts +3 -3
- package/VNet/SecurityGroup.js +3 -3
- package/VNet/VPNGateway.js +2 -2
- package/VNet/Vnet.js +2 -2
- package/package.json +3 -3
- package/types.d.ts +29 -3
- package/Apim/ApiProduct/OpenApi.js +0 -3
- package/Apim/ApiProduct/SwaggerHelper.js +0 -37
- package/Apps/LogicApp.d.ts +0 -5
- package/Apps/LogicApp.js +0 -38
- package/Automation/index.d.ts +0 -6
- package/Automation/index.js +0 -78
- package/Common/Naming.d.ts +0 -68
- package/Common/Naming.js +0 -190
- package/Common/ResourceEnv.d.ts +0 -2
- package/Common/ResourceEnv.js +0 -65
- package/ContainerRegistry/Helper.d.ts +0 -15
- package/ContainerRegistry/Helper.js +0 -77
- package/ContainerRegistry/index.d.ts +0 -15
- package/ContainerRegistry/index.js +0 -93
- package/Core/ResourceGroup.d.ts +0 -18
- package/Core/ResourceGroup.js +0 -36
- package/CosmosDb/index.d.ts +0 -28
- package/CosmosDb/index.js +0 -142
- package/IOT/Hub/index.d.ts +0 -26
- package/IOT/Hub/index.js +0 -191
- package/MySql/index.d.ts +0 -16
- package/MySql/index.js +0 -185
- package/Postgresql/index.d.ts +0 -16
- package/Postgresql/index.js +0 -157
- package/RedisCache/index.d.ts +0 -15
- package/RedisCache/index.js +0 -112
- package/ServiceBus/ServiceBusHelper.d.ts +0 -21
- package/ServiceBus/ServiceBusHelper.js +0 -35
- package/ServiceBus/index.d.ts +0 -88
- package/ServiceBus/index.js +0 -405
- package/SignalR/index.d.ts +0 -19
- package/SignalR/index.js +0 -128
- package/Web/AppCertOrder.d.ts +0 -8
- package/Web/AppCertOrder.js +0 -52
- package/Web/AppConfig.d.ts +0 -10
- package/Web/AppConfig.js +0 -93
- package/Web/AppGateway.d.ts +0 -15
- package/Web/AppGateway.js +0 -58
- package/Web/FuncApp.d.ts +0 -11
- package/Web/FuncApp.js +0 -41
- package/Web/WebAppPlan.d.ts +0 -6
- package/Web/WebAppPlan.js +0 -45
- package/Web/types.d.ts +0 -37
- package/z_tests/_tools/Mocks.d.ts +0 -2
- package/z_tests/_tools/Mocks.js +0 -69
- /package/{Apim/ApiProduct/SwaggerHelper.d.ts → Common/OpenApi/index.d.ts} +0 -0
- /package/{Apim/ApiProduct/OpenApi.d.ts → Common/OpenApi/types.d.ts} +0 -0
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const types_1 = require("./types");
|
|
30
|
+
const Common_1 = require("../Common");
|
|
31
|
+
const Random_1 = require("../Core/Random");
|
|
32
|
+
const mysql = __importStar(require("@pulumi/azure-native/dbformysql/v20231230"));
|
|
33
|
+
const Helper_1 = require("../KeyVault/Helper");
|
|
34
|
+
const UserAssignedIdentity_1 = __importDefault(require("../AzAd/UserAssignedIdentity"));
|
|
35
|
+
const pulumi = __importStar(require("@pulumi/pulumi"));
|
|
36
|
+
const Helper_2 = require("../VNet/Helper");
|
|
37
|
+
const PrivateEndpoint_1 = __importDefault(require("../VNet/PrivateEndpoint"));
|
|
38
|
+
class MySqlBuilder extends types_1.Builder {
|
|
39
|
+
args;
|
|
40
|
+
_instanceName;
|
|
41
|
+
_mySqlInstance = undefined;
|
|
42
|
+
_uid = undefined;
|
|
43
|
+
_sku = undefined;
|
|
44
|
+
_loginInfo = undefined;
|
|
45
|
+
_generateLogin = false;
|
|
46
|
+
_network = undefined;
|
|
47
|
+
_options = undefined;
|
|
48
|
+
_databases = new Set();
|
|
49
|
+
constructor(args) {
|
|
50
|
+
super(args);
|
|
51
|
+
this.args = args;
|
|
52
|
+
this._instanceName = Common_1.naming.getMySqlName(args.name);
|
|
53
|
+
}
|
|
54
|
+
withSku(props) {
|
|
55
|
+
this._sku = props;
|
|
56
|
+
return this;
|
|
57
|
+
}
|
|
58
|
+
withLogin(props) {
|
|
59
|
+
this._loginInfo = props;
|
|
60
|
+
return this;
|
|
61
|
+
}
|
|
62
|
+
generateLogin() {
|
|
63
|
+
this._generateLogin = true;
|
|
64
|
+
return this;
|
|
65
|
+
}
|
|
66
|
+
withNetwork(props) {
|
|
67
|
+
this._network = props;
|
|
68
|
+
return this;
|
|
69
|
+
}
|
|
70
|
+
withOptions(props) {
|
|
71
|
+
this._options = props;
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
withDatabases(...props) {
|
|
75
|
+
props.forEach((i) => this._databases.add(i));
|
|
76
|
+
return this;
|
|
77
|
+
}
|
|
78
|
+
buildLogin() {
|
|
79
|
+
if (!this._generateLogin)
|
|
80
|
+
return;
|
|
81
|
+
const { name, vaultInfo } = this.args;
|
|
82
|
+
const login = (0, Random_1.randomLogin)({
|
|
83
|
+
name: this._instanceName,
|
|
84
|
+
loginPrefix: name,
|
|
85
|
+
maxUserNameLength: 15,
|
|
86
|
+
passwordOptions: {
|
|
87
|
+
length: 25,
|
|
88
|
+
policy: 'yearly',
|
|
89
|
+
options: { lower: true, upper: true, special: false, numeric: true },
|
|
90
|
+
},
|
|
91
|
+
vaultInfo,
|
|
92
|
+
});
|
|
93
|
+
this._loginInfo = { adminLogin: login.userName, password: login.password };
|
|
94
|
+
}
|
|
95
|
+
buildUID() {
|
|
96
|
+
const { group, vaultInfo, envRoles, dependsOn } = this.args;
|
|
97
|
+
if (!vaultInfo)
|
|
98
|
+
throw new Error(`${this._instanceName}: The vaultInfo is required.`);
|
|
99
|
+
this._uid = (0, UserAssignedIdentity_1.default)({
|
|
100
|
+
name: this._instanceName,
|
|
101
|
+
group,
|
|
102
|
+
vaultInfo,
|
|
103
|
+
dependsOn,
|
|
104
|
+
});
|
|
105
|
+
//Allows to Read Key Vault
|
|
106
|
+
envRoles?.addMember('readOnly', this._uid.principalId);
|
|
107
|
+
}
|
|
108
|
+
buildMySql() {
|
|
109
|
+
const { group, envUIDInfo, vaultInfo, enableEncryption, dependsOn, ignoreChanges = [], } = this.args;
|
|
110
|
+
const encryptKey = enableEncryption
|
|
111
|
+
? (0, Helper_1.addEncryptKey)(this._instanceName, vaultInfo)
|
|
112
|
+
: undefined;
|
|
113
|
+
this._mySqlInstance = new mysql.Server(this._instanceName, {
|
|
114
|
+
...group,
|
|
115
|
+
serverName: this._instanceName,
|
|
116
|
+
version: this._sku.version,
|
|
117
|
+
sku: this._sku.sku,
|
|
118
|
+
storage: {
|
|
119
|
+
storageSizeGB: this._options?.storageSizeGB ?? 128,
|
|
120
|
+
autoGrow: Common_1.isPrd ? 'Enabled' : 'Disabled',
|
|
121
|
+
autoIoScaling: Common_1.isPrd ? 'Enabled' : 'Disabled',
|
|
122
|
+
},
|
|
123
|
+
identity: {
|
|
124
|
+
type: mysql.ManagedServiceIdentityType.UserAssigned,
|
|
125
|
+
userAssignedIdentities: envUIDInfo
|
|
126
|
+
? [this._uid.id, envUIDInfo.id]
|
|
127
|
+
: [this._uid.id],
|
|
128
|
+
},
|
|
129
|
+
administratorLogin: this._loginInfo.adminLogin,
|
|
130
|
+
administratorLoginPassword: this._loginInfo.password,
|
|
131
|
+
dataEncryption: encryptKey
|
|
132
|
+
? {
|
|
133
|
+
type: mysql.DataEncryptionType.AzureKeyVault,
|
|
134
|
+
primaryUserAssignedIdentityId: envUIDInfo?.id ?? this._uid.id,
|
|
135
|
+
primaryKeyURI: encryptKey.url,
|
|
136
|
+
}
|
|
137
|
+
: { type: mysql.DataEncryptionType.SystemManaged },
|
|
138
|
+
maintenanceWindow: this._options?.maintenanceWindow ?? {
|
|
139
|
+
dayOfWeek: 6,
|
|
140
|
+
startHour: 0,
|
|
141
|
+
startMinute: 0,
|
|
142
|
+
},
|
|
143
|
+
backup: {
|
|
144
|
+
geoRedundantBackup: Common_1.isPrd ? 'Enabled' : 'Disabled',
|
|
145
|
+
backupRetentionDays: Common_1.isPrd ? 7 : 1,
|
|
146
|
+
},
|
|
147
|
+
highAvailability: {
|
|
148
|
+
mode: Common_1.isPrd ? 'ZoneRedundant' : 'Disabled',
|
|
149
|
+
standbyAvailabilityZone: '3',
|
|
150
|
+
},
|
|
151
|
+
availabilityZone: Common_1.isPrd ? '3' : '1',
|
|
152
|
+
}, {
|
|
153
|
+
dependsOn: this._uid?.instance ?? dependsOn,
|
|
154
|
+
ignoreChanges: [...ignoreChanges, 'administratorLogin'],
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
buildAdAdmin() {
|
|
158
|
+
const { group, envRoles } = this.args;
|
|
159
|
+
if (!envRoles)
|
|
160
|
+
return;
|
|
161
|
+
new mysql.AzureADAdministrator(this._instanceName, {
|
|
162
|
+
...group,
|
|
163
|
+
administratorName: this._loginInfo.adminLogin,
|
|
164
|
+
serverName: this._mySqlInstance.name,
|
|
165
|
+
login: this._loginInfo.adminLogin,
|
|
166
|
+
administratorType: 'ActiveDirectory',
|
|
167
|
+
sid: envRoles.contributor.objectId,
|
|
168
|
+
tenantId: Common_1.tenantId,
|
|
169
|
+
}, { dependsOn: this._mySqlInstance, ignoreChanges: ['administratorName'] });
|
|
170
|
+
}
|
|
171
|
+
buildNetwork() {
|
|
172
|
+
const { group } = this.args;
|
|
173
|
+
if (this._network?.ipAddresses) {
|
|
174
|
+
pulumi.output(this._network.ipAddresses).apply((ips) => (0, Helper_2.convertToIpRange)(ips).map((f, i) => new mysql.FirewallRule(`${this._instanceName}-firewall-${i}`, {
|
|
175
|
+
...group,
|
|
176
|
+
firewallRuleName: `${this._instanceName}-firewall-${i}`,
|
|
177
|
+
serverName: this._mySqlInstance.name,
|
|
178
|
+
startIpAddress: f.start,
|
|
179
|
+
endIpAddress: f.end,
|
|
180
|
+
}, { dependsOn: this._mySqlInstance })));
|
|
181
|
+
}
|
|
182
|
+
if (this._network?.allowsPublicAccess)
|
|
183
|
+
new mysql.FirewallRule(`${this._instanceName}-firewall-allow-public`, {
|
|
184
|
+
...group,
|
|
185
|
+
firewallRuleName: `${this._instanceName}-firewall-allow-public`,
|
|
186
|
+
serverName: this._mySqlInstance.name,
|
|
187
|
+
startIpAddress: '0.0.0.0',
|
|
188
|
+
endIpAddress: '255.255.255.255',
|
|
189
|
+
}, { dependsOn: this._mySqlInstance });
|
|
190
|
+
if (this._network?.privateLink) {
|
|
191
|
+
(0, PrivateEndpoint_1.default)({
|
|
192
|
+
...this._network?.privateLink,
|
|
193
|
+
resourceInfo: {
|
|
194
|
+
name: this._instanceName,
|
|
195
|
+
group,
|
|
196
|
+
id: this._mySqlInstance.id,
|
|
197
|
+
},
|
|
198
|
+
privateDnsZoneName: 'mysql.database.azure.com',
|
|
199
|
+
linkServiceGroupIds: this._network.privateLink.type
|
|
200
|
+
? [this._network.privateLink.type]
|
|
201
|
+
: ['mysql'],
|
|
202
|
+
dependsOn: this._mySqlInstance,
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
buildDatabases() {
|
|
207
|
+
const { group } = this.args;
|
|
208
|
+
this._databases.forEach((d) => new mysql.Database(`${this._mySqlInstance}-${d}`, {
|
|
209
|
+
...group,
|
|
210
|
+
serverName: this._mySqlInstance.name,
|
|
211
|
+
databaseName: d,
|
|
212
|
+
}, { dependsOn: this._mySqlInstance }));
|
|
213
|
+
}
|
|
214
|
+
build() {
|
|
215
|
+
this.buildLogin();
|
|
216
|
+
this.buildUID();
|
|
217
|
+
this.buildMySql();
|
|
218
|
+
this.buildAdAdmin();
|
|
219
|
+
this.buildNetwork();
|
|
220
|
+
this.buildDatabases();
|
|
221
|
+
return {
|
|
222
|
+
name: this._instanceName,
|
|
223
|
+
group: this.args.group,
|
|
224
|
+
id: this._mySqlInstance.id,
|
|
225
|
+
};
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
exports.default = (props) => new MySqlBuilder(props);
|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTXlTcWxCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0J1aWxkZXIvTXlTcWxCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxtQ0FTaUI7QUFFakIsc0NBQW9EO0FBQ3BELDJDQUE2QztBQUM3QyxpRkFBbUU7QUFFbkUsK0NBQW1EO0FBQ25ELHdGQUFnRTtBQUNoRSx1REFBeUM7QUFDekMsMkNBQWtEO0FBQ2xELDhFQUFzRDtBQUV0RCxNQUFNLFlBQ0osU0FBUSxlQUFxQjtJQWVUO0lBWkgsYUFBYSxDQUFTO0lBQy9CLGNBQWMsR0FBNkIsU0FBUyxDQUFDO0lBQ3JELElBQUksR0FDVixTQUFTLENBQUM7SUFFSixJQUFJLEdBQW9DLFNBQVMsQ0FBQztJQUNsRCxVQUFVLEdBQTBCLFNBQVMsQ0FBQztJQUM5QyxjQUFjLEdBQVksS0FBSyxDQUFDO0lBQ2hDLFFBQVEsR0FBd0MsU0FBUyxDQUFDO0lBQzFELFFBQVEsR0FBd0MsU0FBUyxDQUFDO0lBQzFELFVBQVUsR0FBRyxJQUFJLEdBQUcsRUFBVSxDQUFDO0lBRXZDLFlBQW9CLElBQXNCO1FBQ3hDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQURNLFNBQUksR0FBSixJQUFJLENBQWtCO1FBRXhDLElBQUksQ0FBQyxhQUFhLEdBQUcsZUFBTSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVNLE9BQU8sQ0FBQyxLQUEwQjtRQUN2QyxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQztRQUNsQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxTQUFTLENBQUMsS0FBZ0I7UUFDL0IsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7UUFDeEIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBQ00sYUFBYTtRQUNsQixJQUFJLENBQUMsY0FB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
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const types_1 = require("./types");
|
|
30
|
+
const Common_1 = require("../Common");
|
|
31
|
+
const Random_1 = require("../Core/Random");
|
|
32
|
+
const postgresql = __importStar(require("@pulumi/azure-native/dbforpostgresql/v20231201preview"));
|
|
33
|
+
const Helper_1 = require("../KeyVault/Helper");
|
|
34
|
+
const UserAssignedIdentity_1 = __importDefault(require("../AzAd/UserAssignedIdentity"));
|
|
35
|
+
const pulumi = __importStar(require("@pulumi/pulumi"));
|
|
36
|
+
const Helper_2 = require("../VNet/Helper");
|
|
37
|
+
const PrivateEndpoint_1 = __importDefault(require("../VNet/PrivateEndpoint"));
|
|
38
|
+
const pulumi_1 = require("@pulumi/pulumi");
|
|
39
|
+
class PostgreSqlBuilder extends types_1.Builder {
|
|
40
|
+
args;
|
|
41
|
+
_instanceName;
|
|
42
|
+
_sqlInstance = undefined;
|
|
43
|
+
_uid = undefined;
|
|
44
|
+
_sku = undefined;
|
|
45
|
+
_loginInfo = undefined;
|
|
46
|
+
_generateLogin = false;
|
|
47
|
+
_network = undefined;
|
|
48
|
+
_options = undefined;
|
|
49
|
+
_databases = new Set();
|
|
50
|
+
constructor(args) {
|
|
51
|
+
super(args);
|
|
52
|
+
this.args = args;
|
|
53
|
+
this._instanceName = Common_1.naming.getPostgresqlName(args.name);
|
|
54
|
+
}
|
|
55
|
+
withSku(props) {
|
|
56
|
+
this._sku = props;
|
|
57
|
+
return this;
|
|
58
|
+
}
|
|
59
|
+
withLogin(props) {
|
|
60
|
+
this._loginInfo = props;
|
|
61
|
+
return this;
|
|
62
|
+
}
|
|
63
|
+
generateLogin() {
|
|
64
|
+
this._generateLogin = true;
|
|
65
|
+
return this;
|
|
66
|
+
}
|
|
67
|
+
withNetwork(props) {
|
|
68
|
+
this._network = props;
|
|
69
|
+
return this;
|
|
70
|
+
}
|
|
71
|
+
withOptions(props) {
|
|
72
|
+
this._options = props;
|
|
73
|
+
return this;
|
|
74
|
+
}
|
|
75
|
+
withDatabases(...props) {
|
|
76
|
+
props.forEach((i) => this._databases.add(i));
|
|
77
|
+
return this;
|
|
78
|
+
}
|
|
79
|
+
buildLogin() {
|
|
80
|
+
if (!this._generateLogin)
|
|
81
|
+
return;
|
|
82
|
+
const { name, vaultInfo } = this.args;
|
|
83
|
+
const login = (0, Random_1.randomLogin)({
|
|
84
|
+
name: this._instanceName,
|
|
85
|
+
loginPrefix: name,
|
|
86
|
+
maxUserNameLength: 15,
|
|
87
|
+
passwordOptions: {
|
|
88
|
+
length: 25,
|
|
89
|
+
policy: 'yearly',
|
|
90
|
+
options: { lower: true, upper: true, special: false, numeric: true },
|
|
91
|
+
},
|
|
92
|
+
vaultInfo,
|
|
93
|
+
});
|
|
94
|
+
this._loginInfo = { adminLogin: login.userName, password: login.password };
|
|
95
|
+
}
|
|
96
|
+
buildUID() {
|
|
97
|
+
const { group, vaultInfo, envRoles, dependsOn } = this.args;
|
|
98
|
+
if (!vaultInfo)
|
|
99
|
+
throw new Error(`${this._instanceName}: The vaultInfo is required.`);
|
|
100
|
+
this._uid = (0, UserAssignedIdentity_1.default)({
|
|
101
|
+
name: this._instanceName,
|
|
102
|
+
group,
|
|
103
|
+
vaultInfo,
|
|
104
|
+
dependsOn,
|
|
105
|
+
});
|
|
106
|
+
//Allows to Read Key Vault
|
|
107
|
+
envRoles?.addMember('readOnly', this._uid.principalId);
|
|
108
|
+
}
|
|
109
|
+
buildPostgreSql() {
|
|
110
|
+
const { group, envUIDInfo, vaultInfo, enableEncryption, dependsOn, ignoreChanges = [], } = this.args;
|
|
111
|
+
const encryptKey = enableEncryption
|
|
112
|
+
? (0, Helper_1.addEncryptKey)(this._instanceName, vaultInfo)
|
|
113
|
+
: undefined;
|
|
114
|
+
this._sqlInstance = new postgresql.Server(this._instanceName, {
|
|
115
|
+
...group,
|
|
116
|
+
serverName: this._instanceName,
|
|
117
|
+
version: this._sku.version,
|
|
118
|
+
sku: this._sku.sku,
|
|
119
|
+
storage: {
|
|
120
|
+
storageSizeGB: this._options?.storageSizeGB ?? 128,
|
|
121
|
+
//autoGrow: isPrd ? 'Enabled' : 'Disabled',
|
|
122
|
+
//autoIoScaling: isPrd ? 'Enabled' : 'Disabled',
|
|
123
|
+
},
|
|
124
|
+
identity: {
|
|
125
|
+
type: postgresql.IdentityType.UserAssigned,
|
|
126
|
+
userAssignedIdentities: (0, pulumi_1.output)([envUIDInfo?.id, this._uid?.id]).apply(([id1, id2]) => {
|
|
127
|
+
const rs = {};
|
|
128
|
+
if (id1) {
|
|
129
|
+
rs[id1] = {
|
|
130
|
+
clientId: envUIDInfo.clientId,
|
|
131
|
+
principalId: envUIDInfo.principalId,
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
if (id2) {
|
|
135
|
+
rs[id2] = {
|
|
136
|
+
clientId: this._uid.clientId,
|
|
137
|
+
principalId: this._uid.principalId,
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
return rs;
|
|
141
|
+
}),
|
|
142
|
+
},
|
|
143
|
+
//TODO: move this options to out of hard code
|
|
144
|
+
authConfig: {
|
|
145
|
+
passwordAuth: 'Enabled',
|
|
146
|
+
activeDirectoryAuth: 'Enabled',
|
|
147
|
+
tenantId: Common_1.tenantId,
|
|
148
|
+
},
|
|
149
|
+
administratorLogin: this._loginInfo.adminLogin,
|
|
150
|
+
administratorLoginPassword: this._loginInfo.password,
|
|
151
|
+
dataEncryption: encryptKey
|
|
152
|
+
? {
|
|
153
|
+
type: 'AzureKeyVault',
|
|
154
|
+
primaryUserAssignedIdentityId: envUIDInfo?.id ?? this._uid.id,
|
|
155
|
+
primaryKeyURI: encryptKey.url,
|
|
156
|
+
}
|
|
157
|
+
: { type: 'SystemManaged' },
|
|
158
|
+
maintenanceWindow: this._options?.maintenanceWindow ?? {
|
|
159
|
+
dayOfWeek: 6,
|
|
160
|
+
startHour: 0,
|
|
161
|
+
startMinute: 0,
|
|
162
|
+
},
|
|
163
|
+
backup: {
|
|
164
|
+
geoRedundantBackup: Common_1.isPrd ? 'Enabled' : 'Disabled',
|
|
165
|
+
backupRetentionDays: Common_1.isPrd ? 7 : 1,
|
|
166
|
+
},
|
|
167
|
+
highAvailability: {
|
|
168
|
+
mode: Common_1.isPrd ? 'ZoneRedundant' : 'Disabled',
|
|
169
|
+
standbyAvailabilityZone: '3',
|
|
170
|
+
},
|
|
171
|
+
availabilityZone: Common_1.isPrd ? '3' : '1',
|
|
172
|
+
}, {
|
|
173
|
+
dependsOn: this._uid?.instance ?? dependsOn,
|
|
174
|
+
ignoreChanges: [...ignoreChanges, 'administratorLogin'],
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
buildNetwork() {
|
|
178
|
+
const { group } = this.args;
|
|
179
|
+
if (this._network?.ipAddresses) {
|
|
180
|
+
pulumi.output(this._network.ipAddresses).apply((ips) => (0, Helper_2.convertToIpRange)(ips).map((f, i) => new postgresql.FirewallRule(`${this._instanceName}-firewall-${i}`, {
|
|
181
|
+
...group,
|
|
182
|
+
firewallRuleName: `${this._instanceName}-firewall-${i}`,
|
|
183
|
+
serverName: this._sqlInstance.name,
|
|
184
|
+
startIpAddress: f.start,
|
|
185
|
+
endIpAddress: f.end,
|
|
186
|
+
}, { dependsOn: this._sqlInstance })));
|
|
187
|
+
}
|
|
188
|
+
if (this._network?.allowsPublicAccess)
|
|
189
|
+
new postgresql.FirewallRule(`${this._instanceName}-firewall-allow-public`, {
|
|
190
|
+
...group,
|
|
191
|
+
firewallRuleName: `${this._instanceName}-firewall-allow-public`,
|
|
192
|
+
serverName: this._sqlInstance.name,
|
|
193
|
+
startIpAddress: '0.0.0.0',
|
|
194
|
+
endIpAddress: '255.255.255.255',
|
|
195
|
+
}, { dependsOn: this._sqlInstance });
|
|
196
|
+
if (this._network?.privateLink) {
|
|
197
|
+
(0, PrivateEndpoint_1.default)({
|
|
198
|
+
...this._network?.privateLink,
|
|
199
|
+
resourceInfo: {
|
|
200
|
+
name: this._instanceName,
|
|
201
|
+
group,
|
|
202
|
+
id: this._sqlInstance.id,
|
|
203
|
+
},
|
|
204
|
+
privateDnsZoneName: 'PostgreSql.database.azure.com',
|
|
205
|
+
linkServiceGroupIds: this._network.privateLink.type
|
|
206
|
+
? [this._network.privateLink.type]
|
|
207
|
+
: ['PostgreSql'],
|
|
208
|
+
dependsOn: this._sqlInstance,
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
buildDatabases() {
|
|
213
|
+
const { group } = this.args;
|
|
214
|
+
this._databases.forEach((d) => new postgresql.Database(`${this._sqlInstance}-${d}`, {
|
|
215
|
+
...group,
|
|
216
|
+
serverName: this._sqlInstance.name,
|
|
217
|
+
databaseName: d,
|
|
218
|
+
}, { dependsOn: this._sqlInstance }));
|
|
219
|
+
}
|
|
220
|
+
build() {
|
|
221
|
+
this.buildLogin();
|
|
222
|
+
this.buildUID();
|
|
223
|
+
this.buildPostgreSql();
|
|
224
|
+
//this.buildAdAdmin();
|
|
225
|
+
this.buildNetwork();
|
|
226
|
+
this.buildDatabases();
|
|
227
|
+
return {
|
|
228
|
+
name: this._instanceName,
|
|
229
|
+
group: this.args.group,
|
|
230
|
+
id: this._sqlInstance.id,
|
|
231
|
+
};
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
exports.default = (props) => new PostgreSqlBuilder(props);
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUG9zdGdyZVNxbEJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQnVpbGRlci9Qb3N0Z3JlU3FsQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsbUNBU2lCO0FBRWpCLHNDQUFvRDtBQUNwRCwyQ0FBNkM7QUFDN0Msa0dBQW9GO0FBRXBGLCtDQUFtRDtBQUNuRCx3RkFBZ0U7QUFDaEUsdURBQXlDO0FBQ3pDLDJDQUFrRDtBQUNsRCw4RUFBc0Q7QUFDdEQsMkNBQXdDO0FBR3hDLE1BQU0saUJBQ0osU0FBUSxlQUFxQjtJQWVUO0lBWkgsYUFBYSxDQUFTO0lBQy9CLFlBQVksR0FBa0MsU0FBUyxDQUFDO0lBQ3hELElBQUksR0FDVixTQUFTLENBQUM7SUFFSixJQUFJLEdBQXlDLFNBQVMsQ0FBQztJQUN2RCxVQUFVLEdBQTBCLFNBQVMsQ0FBQztJQUM5QyxjQUFjLEdBQVksS0FBSyxDQUFDO0lBQ2hDLFFBQVEsR0FBNkMsU0FBUyxDQUFDO0lBQy9ELFFBQVEsR0FBNkMsU0FBUyxDQUFDO0lBQy9ELFVBQVUsR0FBRyxJQUFJLEdBQUcsRUFBVSxDQUFDO0lBRXZDLFlBQW9CLElBQTJCO1FBQzdDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQURNLFNBQUksR0FBSixJQUFJLENBQXVCO1FBRTdDLElBQUksQ0FBQyxhQUFhLEdBQUcsZUFBTSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRU0sT0FBTyxDQUFDLEtBQStCO1FBQzVDLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO1FBQ2xCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUNNLFNBQVMsQ0FBQyxLQUFnQjtRQUMvQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFD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
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
const types_1 = require("./types");
|
|
30
|
+
const Common_1 = require("../Common");
|
|
31
|
+
const cache = __importStar(require("@pulumi/azure-native/cache"));
|
|
32
|
+
const pulumi = __importStar(require("@pulumi/pulumi"));
|
|
33
|
+
const Helper_1 = require("../VNet/Helper");
|
|
34
|
+
const PrivateEndpoint_1 = __importDefault(require("../VNet/PrivateEndpoint"));
|
|
35
|
+
const CustomHelper_1 = require("../KeyVault/CustomHelper");
|
|
36
|
+
const to_words_1 = require("to-words");
|
|
37
|
+
const toWord = new to_words_1.ToWords();
|
|
38
|
+
class RedisCacheBuilder extends types_1.Builder {
|
|
39
|
+
args;
|
|
40
|
+
_instanceName;
|
|
41
|
+
_sku = {
|
|
42
|
+
name: 'Basic',
|
|
43
|
+
family: 'C',
|
|
44
|
+
capacity: 0,
|
|
45
|
+
};
|
|
46
|
+
_network = undefined;
|
|
47
|
+
_redisInstance = undefined;
|
|
48
|
+
constructor(args) {
|
|
49
|
+
super(args);
|
|
50
|
+
this.args = args;
|
|
51
|
+
this._instanceName = Common_1.naming.getRedisCacheName(args.name);
|
|
52
|
+
}
|
|
53
|
+
withSku(props) {
|
|
54
|
+
this._sku = props;
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
withNetwork(props) {
|
|
58
|
+
this._network = props;
|
|
59
|
+
return this;
|
|
60
|
+
}
|
|
61
|
+
buildRedis() {
|
|
62
|
+
const { group, dependsOn, ignoreChanges, importUri } = this.args;
|
|
63
|
+
this._redisInstance = new cache.Redis(this._instanceName, {
|
|
64
|
+
...group,
|
|
65
|
+
name: this._instanceName,
|
|
66
|
+
minimumTlsVersion: '1.2',
|
|
67
|
+
enableNonSslPort: false,
|
|
68
|
+
identity: { type: cache.ManagedServiceIdentityType.SystemAssigned },
|
|
69
|
+
sku: this._sku,
|
|
70
|
+
zones: Common_1.isPrd && this._sku.name === 'Premium' ? ['1', '2', '3'] : undefined,
|
|
71
|
+
subnetId: this._network?.subnetId,
|
|
72
|
+
publicNetworkAccess: this._network?.privateLink
|
|
73
|
+
? 'Disabled'
|
|
74
|
+
: 'Enabled',
|
|
75
|
+
}, { dependsOn, import: importUri, ignoreChanges });
|
|
76
|
+
}
|
|
77
|
+
buildNetwork() {
|
|
78
|
+
//Whitelist IpAddress
|
|
79
|
+
if (this._network?.ipAddresses) {
|
|
80
|
+
pulumi.output(this._network.ipAddresses).apply((ips) => {
|
|
81
|
+
(0, Helper_1.convertToIpRange)(ips).map((range, i) => {
|
|
82
|
+
const n = `allow_Ip_${toWord.convert(i)}`.toLowerCase();
|
|
83
|
+
return new cache.FirewallRule(`${this._instanceName}-${n}`, {
|
|
84
|
+
...this.args.group,
|
|
85
|
+
ruleName: n,
|
|
86
|
+
cacheName: this._redisInstance.name,
|
|
87
|
+
startIP: range.start,
|
|
88
|
+
endIP: range.end,
|
|
89
|
+
}, { dependsOn: this._redisInstance });
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
//Private Link
|
|
94
|
+
if (this._network?.privateLink) {
|
|
95
|
+
(0, PrivateEndpoint_1.default)({
|
|
96
|
+
...this._network.privateLink,
|
|
97
|
+
resourceInfo: {
|
|
98
|
+
name: this._instanceName,
|
|
99
|
+
group: this.args.group,
|
|
100
|
+
id: this._redisInstance.id,
|
|
101
|
+
},
|
|
102
|
+
privateDnsZoneName: 'privatelink.redis.cache.windows.net',
|
|
103
|
+
linkServiceGroupIds: this._network.privateLink.type
|
|
104
|
+
? [this._network.privateLink.type]
|
|
105
|
+
: ['redisCache'],
|
|
106
|
+
dependsOn: this._redisInstance,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
buildSecrets() {
|
|
111
|
+
const { vaultInfo } = this.args;
|
|
112
|
+
if (!vaultInfo)
|
|
113
|
+
return;
|
|
114
|
+
this._redisInstance.hostName.apply(async (h) => {
|
|
115
|
+
if (!h)
|
|
116
|
+
return;
|
|
117
|
+
const keys = await cache.listRedisKeys({
|
|
118
|
+
name: this._instanceName,
|
|
119
|
+
resourceGroupName: this.args.group.resourceGroupName,
|
|
120
|
+
});
|
|
121
|
+
(0, CustomHelper_1.addCustomSecrets)({
|
|
122
|
+
vaultInfo,
|
|
123
|
+
contentType: 'Redis Cache',
|
|
124
|
+
dependsOn: this._redisInstance,
|
|
125
|
+
items: [
|
|
126
|
+
{ name: `${this._instanceName}-host`, value: h },
|
|
127
|
+
{
|
|
128
|
+
name: `${this._instanceName}-primary-conn`,
|
|
129
|
+
value: `${h}:6380,password=${keys.primaryKey},ssl=True,abortConnect=False`,
|
|
130
|
+
},
|
|
131
|
+
{
|
|
132
|
+
name: `${this._instanceName}-secondary-conn`,
|
|
133
|
+
value: `${h}:6380,password=${keys.secondaryKey},ssl=True,abortConnect=False`,
|
|
134
|
+
},
|
|
135
|
+
],
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
build() {
|
|
140
|
+
this.buildRedis();
|
|
141
|
+
this.buildNetwork();
|
|
142
|
+
this.buildSecrets();
|
|
143
|
+
return {
|
|
144
|
+
name: this._instanceName,
|
|
145
|
+
group: this.args.group,
|
|
146
|
+
id: this._redisInstance.id,
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
exports.default = (props) => new RedisCacheBuilder(props);
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVkaXNDYWNoZUJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQnVpbGRlci9SZWRpc0NhY2hlQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsbUNBTWlCO0FBRWpCLHNDQUEwQztBQUMxQyxrRUFBb0Q7QUFDcEQsdURBQXlDO0FBQ3pDLDJDQUFrRDtBQUNsRCw4RUFBNkQ7QUFDN0QsMkRBQTREO0FBQzVELHVDQUFtQztBQUNuQyxNQUFNLE1BQU0sR0FBRyxJQUFJLGtCQUFPLEVBQUUsQ0FBQztBQUU3QixNQUFNLGlCQUNKLFNBQVEsZUFBcUI7SUFZVDtJQVRILGFBQWEsQ0FBUztJQUMvQixJQUFJLEdBQXlCO1FBQ25DLElBQUksRUFBRSxPQUFPO1FBQ2IsTUFBTSxFQUFFLEdBQUc7UUFDWCxRQUFRLEVBQUUsQ0FBQztLQUNaLENBQUM7SUFDTSxRQUFRLEdBQWlDLFNBQVMsQ0FBQztJQUNuRCxjQUFjLEdBQTRCLFNBQVMsQ0FBQztJQUU1RCxZQUFvQixJQUEyQjtRQUM3QyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFETSxTQUFJLEdBQUosSUFBSSxDQUF1QjtRQUU3QyxJQUFJLENBQUMsYUFBYSxHQUFHLGVBQU0sQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVNLE9BQU8sQ0FBQyxLQUEyQjtRQUN4QyxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQztRQUNsQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxXQUFXLENBQUMsS0FBdUI7UUFDeEMsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRU8sVUFBVTtRQUNoQixNQUFNLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLEdB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
|