@drunk-pulumi/azure 0.0.41 → 0.0.42
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 -3
- package/Aks/Helper.js +19 -17
- package/Builder/DnsZoneBuilder.d.ts +4 -0
- package/Builder/DnsZoneBuilder.js +88 -0
- package/Builder/PrivateDnsZoneBuilder.d.ts +4 -0
- package/Builder/PrivateDnsZoneBuilder.js +75 -0
- package/Builder/SqlBuilder.js +19 -3
- package/Builder/index.d.ts +2 -0
- package/Builder/index.js +6 -2
- package/Builder/types/askBuilder.d.ts +9 -9
- package/Builder/types/dnsZoneBuilder.d.ts +11 -0
- package/Builder/types/dnsZoneBuilder.js +3 -0
- package/Builder/types/genericBuilder.d.ts +4 -4
- package/Builder/types/index.d.ts +1 -0
- package/Builder/types/index.js +2 -1
- package/Builder/types/privateDnsZoneBuilder.d.ts +13 -0
- package/Builder/types/privateDnsZoneBuilder.js +3 -0
- package/Builder/types/resourceBuilder.d.ts +14 -14
- package/Builder/types/sqlBuilder.d.ts +10 -5
- package/Builder/types/vaultBuilder.d.ts +7 -7
- package/Builder/types/vmBuilder.d.ts +5 -5
- package/Builder/types/vnetBuilder.d.ts +17 -17
- package/Common/GlobalEnv.d.ts +0 -1
- package/Common/GlobalEnv.js +1 -12
- package/Logs/Helpers.js +2 -2
- package/Sql/index.d.ts +7 -6
- package/Sql/index.js +17 -16
- package/Storage/Helper.d.ts +4 -4
- package/Storage/Helper.js +1 -1
- package/VM/index.js +2 -1
- package/VNet/PrivateEndpoint.js +8 -26
- package/package.json +1 -1
- package/VNet/PrivateDns.d.ts +0 -31
- package/VNet/PrivateDns.js +0 -68
- package/VNet/PublicDns.d.ts +0 -21
- package/VNet/PublicDns.js +0 -59
package/Aks/Helper.d.ts
CHANGED
|
@@ -15,6 +15,3 @@ export declare const getAksVaultConfig: ({ name, version, vaultInfo, formattedNa
|
|
|
15
15
|
formattedName?: boolean;
|
|
16
16
|
}) => Promise<string>;
|
|
17
17
|
export declare const getAksPrivateDnz: ({ name, groupName, formattedName, }: ResourceType) => Output<ResourceInfo | undefined>;
|
|
18
|
-
export declare const linkAksPrivateDnzVnet: ({ vnetId, name, groupName, formattedName, }: ResourceType & {
|
|
19
|
-
vnetId: Output<string>;
|
|
20
|
-
}) => Output<import("@pulumi/azure-native/network/virtualNetworkLink").VirtualNetworkLink | undefined>;
|
package/Aks/Helper.js
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.getAksPrivateDnz = exports.getAksVaultConfig = exports.getAksConfig = void 0;
|
|
4
4
|
const containerservice = require("@pulumi/azure-native/containerservice");
|
|
5
5
|
const Naming_1 = require("../Common/Naming");
|
|
6
6
|
const Helper_1 = require("../KeyVault/Helper");
|
|
7
7
|
const pulumi_1 = require("@pulumi/pulumi");
|
|
8
8
|
const AzureEnv_1 = require("../Common/AzureEnv");
|
|
9
|
-
const PrivateDns_1 = require("../VNet/PrivateDns");
|
|
10
9
|
/** Get AKS Config from Managed Cluster*/
|
|
11
10
|
const getAksConfig = async ({ name, groupName, formattedName, disableLocalAccounts, }) => {
|
|
12
11
|
const aksName = formattedName ? name : (0, Naming_1.getAksName)(name);
|
|
@@ -55,18 +54,21 @@ const getAksPrivateDnz = ({ name, groupName, formattedName, }) => {
|
|
|
55
54
|
});
|
|
56
55
|
};
|
|
57
56
|
exports.getAksPrivateDnz = getAksPrivateDnz;
|
|
58
|
-
const linkAksPrivateDnzVnet = ({
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
57
|
+
// export const linkAksPrivateDnzVnet = ({
|
|
58
|
+
// vnetId,
|
|
59
|
+
// name,
|
|
60
|
+
// groupName,
|
|
61
|
+
// formattedName,
|
|
62
|
+
// }: ResourceType & { vnetId: Output<string> }) => {
|
|
63
|
+
// const dns = getAksPrivateDnz({ name, groupName, formattedName });
|
|
64
|
+
// return dns.apply((d) => {
|
|
65
|
+
// if (!d) return;
|
|
66
|
+
// return linkVnetToPrivateDns({
|
|
67
|
+
// name,
|
|
68
|
+
// group: d.group,
|
|
69
|
+
// zoneName: d.resourceName,
|
|
70
|
+
// vnetId,
|
|
71
|
+
// });
|
|
72
|
+
// });
|
|
73
|
+
// };
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0Frcy9IZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsMEVBQTBFO0FBQzFFLDZDQUFvRTtBQUVwRSwrQ0FBK0M7QUFDL0MsMkNBQXFEO0FBQ3JELGlEQUF1RTtBQUV2RSx5Q0FBeUM7QUFDbEMsTUFBTSxZQUFZLEdBQUcsS0FBSyxFQUFFLEVBQ2pDLElBQUksRUFDSixTQUFTLEVBQ1QsYUFBYSxFQUNiLG9CQUFvQixHQU1yQixFQUFtQixFQUFFO0lBQ3BCLE1BQU0sT0FBTyxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFBLG1CQUFVLEVBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEQsTUFBTSxLQUFLLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUEsNkJBQW9CLEVBQUMsU0FBUyxDQUFDLENBQUM7SUFFMUUsTUFBTSxHQUFHLEdBQUcsb0JBQW9CO1FBQzlCLENBQUMsQ0FBQyxNQUFNLGdCQUFnQixDQUFDLGlDQUFpQyxDQUFDO1lBQ3ZELFlBQVksRUFBRSxPQUFPO1lBQ3JCLGlCQUFpQixFQUFFLEtBQUs7U0FDekIsQ0FBQztRQUNKLENBQUMsQ0FBQyxNQUFNLGdCQUFnQixDQUFDLGtDQUFrQyxDQUFDO1lBQ3hELFlBQVksRUFBRSxPQUFPO1lBQ3JCLGlCQUFpQixFQUFFLEtBQUs7U0FDekIsQ0FBQyxDQUFDO0lBRVAsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUMxRSxDQUFDLENBQUM7QUF6QlcsUUFBQSxZQUFZLGdCQXlCdkI7QUFFRixtQ0FBbUM7QUFDNUIsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLEVBQUUsRUFDdEMsSUFBSSxFQUNKLE9BQU8sRUFDUCxTQUFTLEVBQ1QsYUFBYSxHQU1kLEVBQW1CLEVBQUU7SUFDcEIsTUFBTSxPQUFPLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUEsbUJBQVUsRUFBQyxJQUFJLENBQUMsQ0FBQztJQUN4RCxNQUFNLEVBQUUsR0FBRyxNQUFNLElBQUEsa0JBQVMsRUFBQztRQUN6QixJQUFJLEVBQUUsR0FBRyxPQUFPLFNBQVM7UUFDekIsT0FBTztRQUNQLFNBQVM7UUFDVCxhQUFhLEVBQUUsS0FBSztLQUNyQixDQUFDLENBQUM7SUFDSCxPQUFPLEVBQUUsRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO0FBQ3pCLENBQUMsQ0FBQztBQW5CVyxRQUFBLGlCQUFpQixxQkFtQjVCO0FBRUssTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEVBQy9CLElBQUksRUFDSixTQUFTLEVBQ1QsYUFBYSxHQUNBLEVBQW9DLEVBQUU7SUFDbkQsSUFBSSxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFBLG1CQUFVLEVBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0MsU0FBUyxHQUFHLGFBQWEsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFBLDZCQUFvQixFQUFDLFNBQVMsQ0FBQyxDQUFDO0lBRXhFLE1BQU0sR0FBRyxHQUFHLGdCQUFnQixDQUFDLHVCQUF1QixDQUFDO1FBQ25ELFlBQVksRUFBRSxJQUFJO1FBQ2xCLGlCQUFpQixFQUFFLFNBQVM7S0FDN0IsQ0FBQyxDQUFDO0lBRUgsT0FBTyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7UUFDckIsSUFBSSxDQUFDLENBQUMsQ0FBQyxXQUFXO1lBQUUsT0FBTyxTQUFTLENBQUM7UUFDckMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1RCxNQUFNLE9BQU8sR0FBRyxDQUFDLENBQUMsaUJBQWtCLENBQUM7UUFFckMsT0FBTztZQUNMLFlBQVksRUFBRSxPQUFPO1lBQ3JCLEtBQUssRUFBRSxFQUFFLGlCQUFpQixFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsNEJBQWlCLEVBQUU7WUFDbEUsRUFBRSxFQUFFLElBQUEsb0JBQVcsRUFBQSxrQkFBa0IseUJBQWMsbUJBQW1CLE9BQU8sZ0RBQWdELE9BQU8sRUFBRTtTQUNuSCxDQUFDO0lBQ3BCLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBeEJXLFFBQUEsZ0JBQWdCLG9CQXdCM0I7QUFFRiwwQ0FBMEM7QUFDMUMsWUFBWTtBQUNaLFVBQVU7QUFDVixlQUFlO0FBQ2YsbUJBQW1CO0FBQ25CLHFEQUFxRDtBQUNyRCxzRUFBc0U7QUFDdEUsOEJBQThCO0FBQzlCLHNCQUFzQjtBQUN0QixvQ0FBb0M7QUFDcEMsY0FBYztBQUNkLHdCQUF3QjtBQUN4QixrQ0FBa0M7QUFDbEMsZ0JBQWdCO0FBQ2hCLFVBQVU7QUFDVixRQUFRO0FBQ1IsS0FBSyJ9
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const network = require("@pulumi/azure-native/network");
|
|
4
|
+
const GlobalEnv_1 = require("../Common/GlobalEnv");
|
|
5
|
+
class DnsZoneBuilder {
|
|
6
|
+
_aRecords = [];
|
|
7
|
+
_children = [];
|
|
8
|
+
commonProps;
|
|
9
|
+
_zoneInstance = undefined;
|
|
10
|
+
_childrenInstances = undefined;
|
|
11
|
+
constructor({ group, ...others }) {
|
|
12
|
+
this.commonProps = {
|
|
13
|
+
...others,
|
|
14
|
+
group: {
|
|
15
|
+
resourceGroupName: group.resourceGroupName,
|
|
16
|
+
location: GlobalEnv_1.globalKeyName,
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
withSubZone(name) {
|
|
21
|
+
this._children.push(name);
|
|
22
|
+
return this;
|
|
23
|
+
}
|
|
24
|
+
withARecord(props) {
|
|
25
|
+
this._aRecords.push(props);
|
|
26
|
+
return this;
|
|
27
|
+
}
|
|
28
|
+
getZoneInstance() {
|
|
29
|
+
return this._zoneInstance;
|
|
30
|
+
}
|
|
31
|
+
buildZone() {
|
|
32
|
+
const { name, group, dependsOn } = this.commonProps;
|
|
33
|
+
this._zoneInstance = new network.Zone(name, {
|
|
34
|
+
zoneName: name,
|
|
35
|
+
zoneType: network.ZoneType.Public,
|
|
36
|
+
...group,
|
|
37
|
+
}, { dependsOn });
|
|
38
|
+
if (this._aRecords) {
|
|
39
|
+
this._aRecords.forEach((a, index) => new network.RecordSet(a.recordName === "*"
|
|
40
|
+
? `All-${index}-ARecord`
|
|
41
|
+
: a.recordName === "@"
|
|
42
|
+
? `Root-${index}-ARecord`
|
|
43
|
+
: `${a.recordName}-ARecord`, {
|
|
44
|
+
zoneName: this._zoneInstance.name,
|
|
45
|
+
...group,
|
|
46
|
+
relativeRecordSetName: a.recordName,
|
|
47
|
+
recordType: "A",
|
|
48
|
+
aRecords: a.ipAddresses.map((i) => ({ ipv4Address: i })),
|
|
49
|
+
ttl: 3600,
|
|
50
|
+
}, { dependsOn: this._zoneInstance, deleteBeforeReplace: true }));
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
buildChildren() {
|
|
54
|
+
if (this._children.length <= 0)
|
|
55
|
+
return;
|
|
56
|
+
const { name, group } = this.commonProps;
|
|
57
|
+
this._childrenInstances = this._children.map((c) => {
|
|
58
|
+
const n = `${c}.${name}`;
|
|
59
|
+
const builder = new DnsZoneBuilder({
|
|
60
|
+
name: n,
|
|
61
|
+
group,
|
|
62
|
+
dependsOn: this._zoneInstance,
|
|
63
|
+
});
|
|
64
|
+
const rs = builder.build();
|
|
65
|
+
const cc = builder.getZoneInstance();
|
|
66
|
+
cc.nameServers.apply((ns) => new network.RecordSet(`${n}-NS`, {
|
|
67
|
+
zoneName: this._zoneInstance.name,
|
|
68
|
+
...group,
|
|
69
|
+
relativeRecordSetName: cc.name,
|
|
70
|
+
recordType: "NS",
|
|
71
|
+
nsRecords: ns.map((s) => ({ nsdname: s })),
|
|
72
|
+
ttl: 3600,
|
|
73
|
+
}, { dependsOn: cc }));
|
|
74
|
+
return rs;
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
build() {
|
|
78
|
+
this.buildZone();
|
|
79
|
+
this.buildChildren();
|
|
80
|
+
return {
|
|
81
|
+
resourceName: this.commonProps.name,
|
|
82
|
+
group: this.commonProps.group,
|
|
83
|
+
id: this._zoneInstance.id,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
exports.default = (props) => new DnsZoneBuilder(props);
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRG5zWm9uZUJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQnVpbGRlci9EbnNab25lQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUVBLHdEQUF3RDtBQUV4RCxtREFBb0Q7QUFFcEQsTUFBTSxjQUFjO0lBQ1YsU0FBUyxHQUF5QixFQUFFLENBQUM7SUFDckMsU0FBUyxHQUFhLEVBQUUsQ0FBQztJQUNoQixXQUFXLENBQW9CO0lBRXhDLGFBQWEsR0FBNkIsU0FBUyxDQUFDO0lBQ3BELGtCQUFrQixHQUErQixTQUFTLENBQUM7SUFFbkUsWUFBbUIsRUFBRSxLQUFLLEVBQUUsR0FBRyxNQUFNLEVBQXFCO1FBQ3hELElBQUksQ0FBQyxXQUFXLEdBQUc7WUFDakIsR0FBRyxNQUFNO1lBQ1QsS0FBSyxFQUFFO2dCQUNMLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxpQkFBaUI7Z0JBQzFDLFFBQVEsRUFBRSx5QkFBYTthQUN4QjtTQUNGLENBQUM7SUFDSixDQUFDO0lBRUQsV0FBVyxDQUFDLElBQVk7UUFDdEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQXlCO1FBQ25DLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVPLGVBQWU7UUFDckIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzVCLENBQUM7SUFFTyxTQUFTO1FBQ2YsTUFBTSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztRQUNwRCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksT0FBTyxDQUFDLElBQUksQ0FDbkMsSUFBSSxFQUNKO1lBQ0UsUUFBUSxFQUFFLElBQUk7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
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const network = require("@pulumi/azure-native/network");
|
|
4
|
+
const native = require("@pulumi/azure-native");
|
|
5
|
+
const pulumi_1 = require("@pulumi/pulumi");
|
|
6
|
+
const Helper_1 = require("../VNet/Helper");
|
|
7
|
+
const GlobalEnv_1 = require("../Common/GlobalEnv");
|
|
8
|
+
class PrivateDnsZoneBuilder {
|
|
9
|
+
_aRecords = [];
|
|
10
|
+
_vnetLinks = [];
|
|
11
|
+
commonProps;
|
|
12
|
+
_zoneInstance = undefined;
|
|
13
|
+
constructor({ group, ...others }) {
|
|
14
|
+
this.commonProps = {
|
|
15
|
+
...others,
|
|
16
|
+
group: {
|
|
17
|
+
resourceGroupName: group.resourceGroupName,
|
|
18
|
+
location: GlobalEnv_1.globalKeyName,
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
linkTo(props) {
|
|
23
|
+
this._vnetLinks.push(props);
|
|
24
|
+
return this;
|
|
25
|
+
}
|
|
26
|
+
withARecord(props) {
|
|
27
|
+
this._aRecords.push(props);
|
|
28
|
+
return this;
|
|
29
|
+
}
|
|
30
|
+
buildZone() {
|
|
31
|
+
const { name, group, dependsOn } = this.commonProps;
|
|
32
|
+
this._zoneInstance = new network.PrivateZone(name, {
|
|
33
|
+
privateZoneName: name,
|
|
34
|
+
...group,
|
|
35
|
+
}, { dependsOn });
|
|
36
|
+
if (this._aRecords) {
|
|
37
|
+
this._aRecords.forEach((a, index) => new network.PrivateRecordSet(a.recordName === "*"
|
|
38
|
+
? `All-${index}-ARecord`
|
|
39
|
+
: a.recordName === "@"
|
|
40
|
+
? `Root-${index}-ARecord`
|
|
41
|
+
: `${a.recordName}-ARecord`, {
|
|
42
|
+
privateZoneName: this._zoneInstance.name,
|
|
43
|
+
...group,
|
|
44
|
+
relativeRecordSetName: a.recordName,
|
|
45
|
+
recordType: "A",
|
|
46
|
+
aRecords: a.ipAddresses.map((i) => ({ ipv4Address: i })),
|
|
47
|
+
ttl: 3600,
|
|
48
|
+
}, { dependsOn: this._zoneInstance, deleteBeforeReplace: true }));
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
buildVnetLinks() {
|
|
52
|
+
if (this._vnetLinks.length <= 0)
|
|
53
|
+
return;
|
|
54
|
+
this._vnetLinks.forEach((lik, index) => [
|
|
55
|
+
...(lik.vnetIds ?? []),
|
|
56
|
+
...(lik.subnetIds ?? []).map((s) => (0, pulumi_1.output)(s).apply(Helper_1.getVnetIdFromSubnetId)),
|
|
57
|
+
].map((v, i) => new native.network.VirtualNetworkLink(`${this.commonProps.name.substring(0, 25)}-${index}-${i}-link`, {
|
|
58
|
+
...this.commonProps.group,
|
|
59
|
+
privateZoneName: this._zoneInstance.name,
|
|
60
|
+
registrationEnabled: lik.registrationEnabled,
|
|
61
|
+
virtualNetwork: { id: v },
|
|
62
|
+
}, { dependsOn: this._zoneInstance, deleteBeforeReplace: true })));
|
|
63
|
+
}
|
|
64
|
+
build() {
|
|
65
|
+
this.buildZone();
|
|
66
|
+
this.buildVnetLinks();
|
|
67
|
+
return {
|
|
68
|
+
resourceName: this.commonProps.name,
|
|
69
|
+
group: this.commonProps.group,
|
|
70
|
+
id: this._zoneInstance.id,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
exports.default = (props) => new PrivateDnsZoneBuilder(props);
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHJpdmF0ZURuc1pvbmVCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0J1aWxkZXIvUHJpdmF0ZURuc1pvbmVCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsd0RBQXdEO0FBS3hELCtDQUErQztBQUMvQywyQ0FBd0M7QUFDeEMsMkNBQXVEO0FBQ3ZELG1EQUFvRDtBQUVwRCxNQUFNLHFCQUFxQjtJQUNqQixTQUFTLEdBQXlCLEVBQUUsQ0FBQztJQUNyQyxVQUFVLEdBQW9DLEVBQUUsQ0FBQztJQUN4QyxXQUFXLENBQW9CO0lBRXhDLGFBQWEsR0FBb0MsU0FBUyxDQUFDO0lBRW5FLFlBQW1CLEVBQUUsS0FBSyxFQUFFLEdBQUcsTUFBTSxFQUFxQjtRQUN4RCxJQUFJLENBQUMsV0FBVyxHQUFHO1lBQ2pCLEdBQUcsTUFBTTtZQUNULEtBQUssRUFBRTtnQkFDTCxpQkFBaUIsRUFBRSxLQUFLLENBQUMsaUJBQWlCO2dCQUMxQyxRQUFRLEVBQUUseUJBQWE7YUFDeEI7U0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFvQztRQUN6QyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBeUI7UUFDbkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDM0IsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRU8sU0FBUztRQUNmLE1BQU0sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7UUFDcEQsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLE9BQU8sQ0FBQyxXQUFXLENBQzFDLElBQUksRUFDSjtZQUNFLGVBQWUsRUFBRSxJQUFJO1lBQ3JCLEdBQUcsS0FBSztTQUNULEVB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
|
package/Builder/SqlBuilder.js
CHANGED
|
@@ -10,10 +10,15 @@ class SqlBuilder extends types_1.Builder {
|
|
|
10
10
|
_networkProps = undefined;
|
|
11
11
|
_elasticPoolProps = undefined;
|
|
12
12
|
_databasesProps = {};
|
|
13
|
+
_vulnerabilityAssessment = undefined;
|
|
13
14
|
_sqlInstance = undefined;
|
|
14
15
|
constructor(props) {
|
|
15
16
|
super(props);
|
|
16
17
|
}
|
|
18
|
+
withVulnerabilityAssessment(props) {
|
|
19
|
+
this._vulnerabilityAssessment = props;
|
|
20
|
+
return this;
|
|
21
|
+
}
|
|
17
22
|
withElasticPool(props) {
|
|
18
23
|
this._elasticPoolProps = props;
|
|
19
24
|
return this;
|
|
@@ -56,9 +61,12 @@ class SqlBuilder extends types_1.Builder {
|
|
|
56
61
|
}
|
|
57
62
|
buildSql() {
|
|
58
63
|
if (!this._loginInfo)
|
|
59
|
-
throw new Error("LoginInfo is required.");
|
|
64
|
+
throw new Error("The LoginInfo is required.");
|
|
60
65
|
if (!this.commonProps.vaultInfo)
|
|
61
|
-
throw new Error("VaultInfo is required.");
|
|
66
|
+
throw new Error("The VaultInfo is required.");
|
|
67
|
+
if (this._vulnerabilityAssessment &&
|
|
68
|
+
!this._vulnerabilityAssessment.logInfo.secrets)
|
|
69
|
+
throw new Error("The LogInfo's secrets are required to enable the vulnerability assessment.");
|
|
62
70
|
this._sqlInstance = (0, Sql_1.default)({
|
|
63
71
|
...this.commonProps,
|
|
64
72
|
auth: {
|
|
@@ -66,6 +74,14 @@ class SqlBuilder extends types_1.Builder {
|
|
|
66
74
|
...this._loginInfo,
|
|
67
75
|
envRoles: this.commonProps.envRoles,
|
|
68
76
|
},
|
|
77
|
+
vulnerabilityAssessment: this._vulnerabilityAssessment
|
|
78
|
+
? {
|
|
79
|
+
logStorageId: this._vulnerabilityAssessment.logInfo.id,
|
|
80
|
+
alertEmails: this._vulnerabilityAssessment.alertEmails,
|
|
81
|
+
storageAccessKey: this._vulnerabilityAssessment.logInfo.secrets.primaryKey,
|
|
82
|
+
storageEndpoint: this._vulnerabilityAssessment.logInfo.secrets.endpoints.blob,
|
|
83
|
+
}
|
|
84
|
+
: undefined,
|
|
69
85
|
network: this._networkProps,
|
|
70
86
|
elasticPool: this._elasticPoolProps,
|
|
71
87
|
databases: this._databasesProps,
|
|
@@ -78,4 +94,4 @@ class SqlBuilder extends types_1.Builder {
|
|
|
78
94
|
}
|
|
79
95
|
}
|
|
80
96
|
exports.default = (props) => new SqlBuilder(props);
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3FsQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CdWlsZGVyL1NxbEJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxnQ0FLZ0I7QUFDaEIsbUNBV2lCO0FBQ2pCLDJDQUE2QztBQUU3QyxNQUFNLFVBQ0osU0FBUSxlQUFtQjtJQUduQixjQUFjLEdBQVksS0FBSyxDQUFDO0lBQ2hDLFVBQVUsR0FBa0MsU0FBUyxDQUFDO0lBQ3RELFlBQVksR0FBOEIsRUFBRSxDQUFDO0lBQzdDLGFBQWEsR0FBK0IsU0FBUyxDQUFDO0lBQ3RELGlCQUFpQixHQUFtQyxTQUFTLENBQUM7SUFDOUQsZUFBZSxHQUFxQixFQUFFLENBQUM7SUFDdkMsd0JBQXdCLEdBRWhCLFNBQVMsQ0FBQztJQUVsQixZQUFZLEdBQTJCLFNBQVMsQ0FBQztJQUV6RCxZQUFZLEtBQW1CO1FBQzdCLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNmLENBQUM7SUFFRCwyQkFBMkIsQ0FDekIsS0FBNEM7UUFFNUMsSUFBSSxDQUFDLHdCQUF3QixHQUFHLEtBQUssQ0FBQztRQUN0QyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFTSxlQUFlLENBQUMsS0FBeUI7UUFDOUMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLEtBQUssQ0FBQztRQUMvQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxhQUFhLENBQUMsS0FBdUI7UUFDMUMsSUFBSSxDQUFDLGVBQWUsR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLGVBQWUsRUFBRSxHQUFHLEtBQUssRUFBRSxDQUFDO1FBQzdELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUNNLFdBQVcsQ0FBQyxLQUFxQjtRQUN0QyxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztRQUMzQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxlQUFlLENBQUMsS0FBZ0M7UUFDckQsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7UUFDMUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBQ00sYUFBYTtRQUNsQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQztRQUMzQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxhQUFhLENBQUMsS0FBd0I7UUFDM0MsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7UUFDeEIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRU8sVUFBVTtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWM7WUFBRSxPQUFPO1FBRWpDLE1BQU0sS0FBSyxHQUFHLElBQUEsb0JBQVcsRUFBQztZQUN4QixJQUFJLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJO1lBQzNCLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUk7WUFDbEMsaUJBQWlCLEVBQUUsRUFBRTtZQUNyQixlQUFlLEVBQUU7Z0JBQ2YsTUFBTSxFQUFFLEVBQUU7Z0JBQ1YsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLE9BQU8sRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUU7YUFDckU7WUFDRCxTQUFTLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTO1NBQ3RDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxVQUFVLEdBQUcsRUFBRSxVQUFVLEVBQUUsS0FBSyxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzdFLENBQUM7SUFFTyxRQUFRO1FBQ2QsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVO1lBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQ3BFLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVM7WUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1FBQ2hELElBQ0UsSUFBSSxDQUFDLHdCQUF3QjtZQUM3QixDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLENBQUMsT0FBTztZQUU5QyxNQUFNLElBQUksS0FBSyxDQUNiLDRFQUE0RSxDQUM3RSxDQUFDO1FBRUosSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFBLGFBQUcsRUFBQztZQUN0QixHQUFHLElBQUksQ0FBQyxXQUFXO1lBQ25CLElBQUksRUFBRTtnQkFDSixHQUFHLElBQUksQ0FBQyxZQUFZO2dCQUNwQixHQUFHLElBQUksQ0FBQyxVQUFXO2dCQUNuQixRQUFRLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRO2FBQ3BDO1lBQ0QsdUJBQXVCLEVBQUUsSUFBSSxDQUFDLHdCQUF3QjtnQkFDcEQsQ0FBQyxDQUFDO29CQUNFLFlBQVksRUFBRSxJQUFJLENBQUMsd0JBQXdCLENBQUMsT0FBTyxDQUFDLEVBQUU7b0JBQ3RELFdBQVcsRUFBRSxJQUFJLENBQUMsd0JBQXdCLENBQUMsV0FBVztvQkFDdEQsZ0JBQWdCLEVBQ2QsSUFBSSxDQUFDLHdCQUF3QixDQUFDLE9BQU8sQ0FBQyxPQUFRLENBQUMsVUFBVztvQkFDNUQsZUFBZSxFQUNiLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLENBQUMsT0FBUSxDQUFDLFNBQVMsQ0FBQyxJQUFLO2lCQUNqRTtnQkFDSCxDQUFDLENBQUMsU0FBUztZQUNiLE9BQU8sRUFBRSxJQUFJLENBQUMsYUFBYTtZQUMzQixXQUFXLEVBQUUsSUFBSSxDQUFDLGlCQUFpQjtZQUNuQyxTQUFTLEVBQUUsSUFBSSxDQUFDLGVBQWU7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLEtBQUs7UUFDVixJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBRWhCLE9BQU8sSUFBSSxDQUFDLFlBQWEsQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUFFRCxrQkFBZSxDQUFDLEtBQW1CLEVBQUUsRUFBRSxDQUNyQyxJQUFJLFVBQVUsQ0FBQyxLQUFLLENBQXFCLENBQUMifQ==
|
package/Builder/index.d.ts
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
export { default as AksBuilder } from "./AksBuilder";
|
|
2
|
+
export { default as DnsZoneBuilder } from "./DnsZoneBuilder";
|
|
3
|
+
export { default as PrivateDnsZoneBuilder } from "./PrivateDnsZoneBuilder";
|
|
2
4
|
export { default as ResourceBuilder } from "./ResourceBuilder";
|
|
3
5
|
export { default as SqlBuilder } from "./SqlBuilder";
|
|
4
6
|
export { default as VaultBuilder } from "./VaultBuilder";
|
package/Builder/index.js
CHANGED
|
@@ -14,9 +14,13 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.VnetBuilder = exports.VmBuilder = exports.VaultBuilder = exports.SqlBuilder = exports.ResourceBuilder = exports.AksBuilder = void 0;
|
|
17
|
+
exports.VnetBuilder = exports.VmBuilder = exports.VaultBuilder = exports.SqlBuilder = exports.ResourceBuilder = exports.PrivateDnsZoneBuilder = exports.DnsZoneBuilder = exports.AksBuilder = void 0;
|
|
18
18
|
var AksBuilder_1 = require("./AksBuilder");
|
|
19
19
|
Object.defineProperty(exports, "AksBuilder", { enumerable: true, get: function () { return AksBuilder_1.default; } });
|
|
20
|
+
var DnsZoneBuilder_1 = require("./DnsZoneBuilder");
|
|
21
|
+
Object.defineProperty(exports, "DnsZoneBuilder", { enumerable: true, get: function () { return DnsZoneBuilder_1.default; } });
|
|
22
|
+
var PrivateDnsZoneBuilder_1 = require("./PrivateDnsZoneBuilder");
|
|
23
|
+
Object.defineProperty(exports, "PrivateDnsZoneBuilder", { enumerable: true, get: function () { return PrivateDnsZoneBuilder_1.default; } });
|
|
20
24
|
var ResourceBuilder_1 = require("./ResourceBuilder");
|
|
21
25
|
Object.defineProperty(exports, "ResourceBuilder", { enumerable: true, get: function () { return ResourceBuilder_1.default; } });
|
|
22
26
|
var SqlBuilder_1 = require("./SqlBuilder");
|
|
@@ -28,4 +32,4 @@ Object.defineProperty(exports, "VmBuilder", { enumerable: true, get: function ()
|
|
|
28
32
|
var VnetBuilder_1 = require("./VnetBuilder");
|
|
29
33
|
Object.defineProperty(exports, "VnetBuilder", { enumerable: true, get: function () { return VnetBuilder_1.default; } });
|
|
30
34
|
__exportStar(require("./types"), exports);
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQnVpbGRlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUFxRDtBQUE1Qyx3R0FBQSxPQUFPLE9BQWM7QUFDOUIsbURBQTZEO0FBQXBELGdIQUFBLE9BQU8sT0FBa0I7QUFDbEMsaUVBQTJFO0FBQWxFLDhIQUFBLE9BQU8sT0FBeUI7QUFDekMscURBQStEO0FBQXRELGtIQUFBLE9BQU8sT0FBbUI7QUFDbkMsMkNBQXFEO0FBQTVDLHdHQUFBLE9BQU8sT0FBYztBQUM5QiwrQ0FBeUQ7QUFBaEQsNEdBQUEsT0FBTyxPQUFnQjtBQUNoQyx5Q0FBbUQ7QUFBMUMsc0dBQUEsT0FBTyxPQUFhO0FBQzdCLDZDQUF1RDtBQUE5QywwR0FBQSxPQUFPLE9BQWU7QUFFL0IsMENBQXdCIn0=
|
|
@@ -12,19 +12,19 @@ export type AksImportProps = {
|
|
|
12
12
|
ignoreChanges?: string[];
|
|
13
13
|
};
|
|
14
14
|
export interface ISshBuilder {
|
|
15
|
-
withNewSsh
|
|
15
|
+
withNewSsh(props: SshBuilderProps): IAksNetworkBuilder;
|
|
16
16
|
}
|
|
17
17
|
export interface IAksNetworkBuilder {
|
|
18
|
-
withNetwork
|
|
18
|
+
withNetwork(props: AksNetworkProps): IAksDefaultNodePoolBuilder;
|
|
19
19
|
}
|
|
20
20
|
export interface IAksDefaultNodePoolBuilder {
|
|
21
|
-
withDefaultNodePool
|
|
21
|
+
withDefaultNodePool(props: DefaultAksNodePoolProps): IAksBuilder;
|
|
22
22
|
}
|
|
23
23
|
export interface IAksBuilder extends IBuilderAsync<AskBuilderResults> {
|
|
24
|
-
withAuth
|
|
25
|
-
withNodePool
|
|
26
|
-
withAddon
|
|
27
|
-
withFeature
|
|
28
|
-
withTier
|
|
29
|
-
import
|
|
24
|
+
withAuth(props: Omit<AksAccessProps, "envRoles">): IAksBuilder;
|
|
25
|
+
withNodePool(props: AksNodePoolProps): IAksBuilder;
|
|
26
|
+
withAddon(props: AskAddonProps): IAksBuilder;
|
|
27
|
+
withFeature(props: AskFeatureProps): IAksBuilder;
|
|
28
|
+
withTier(tier: native.containerservice.ManagedClusterSKUTier): IAksBuilder;
|
|
29
|
+
import(props: AksImportProps): IAksBuilder;
|
|
30
30
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Input } from "@pulumi/pulumi";
|
|
2
|
+
import { ResourceInfo } from "../../types";
|
|
3
|
+
export type DnsZoneARecordType = {
|
|
4
|
+
recordName: string;
|
|
5
|
+
ipAddresses: Input<string>[];
|
|
6
|
+
};
|
|
7
|
+
export interface IDnsZoneBuilder {
|
|
8
|
+
withARecord(props: DnsZoneARecordType): IDnsZoneBuilder;
|
|
9
|
+
withSubZone(name: string): IDnsZoneBuilder;
|
|
10
|
+
build(): ResourceInfo;
|
|
11
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG5zWm9uZUJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQnVpbGRlci90eXBlcy9kbnNab25lQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIn0=
|
|
@@ -14,12 +14,12 @@ export type LoginBuilderProps = {
|
|
|
14
14
|
password: Input<string>;
|
|
15
15
|
};
|
|
16
16
|
export interface ILoginBuilder<IReturnInterface> {
|
|
17
|
-
generateLogin
|
|
18
|
-
withLoginInfo
|
|
17
|
+
generateLogin(): IReturnInterface;
|
|
18
|
+
withLoginInfo(props: LoginBuilderProps): IReturnInterface;
|
|
19
19
|
}
|
|
20
20
|
export interface IBuilder<TResults> {
|
|
21
21
|
commonProps: BuilderProps;
|
|
22
|
-
build
|
|
22
|
+
build(): TResults;
|
|
23
23
|
}
|
|
24
24
|
export declare abstract class Builder<TResults> implements IBuilder<TResults> {
|
|
25
25
|
commonProps: BuilderProps;
|
|
@@ -27,7 +27,7 @@ export declare abstract class Builder<TResults> implements IBuilder<TResults> {
|
|
|
27
27
|
abstract build(): TResults;
|
|
28
28
|
}
|
|
29
29
|
export interface IBuilderAsync<TResults> extends Omit<IBuilder<TResults>, "build"> {
|
|
30
|
-
build
|
|
30
|
+
build(): Promise<TResults>;
|
|
31
31
|
}
|
|
32
32
|
export declare abstract class BuilderAsync<TResults> implements IBuilderAsync<TResults> {
|
|
33
33
|
commonProps: BuilderProps;
|
package/Builder/types/index.d.ts
CHANGED
package/Builder/types/index.js
CHANGED
|
@@ -15,9 +15,10 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./askBuilder"), exports);
|
|
18
|
+
__exportStar(require("./dnsZoneBuilder"), exports);
|
|
18
19
|
__exportStar(require("./genericBuilder"), exports);
|
|
19
20
|
__exportStar(require("./resourceBuilder"), exports);
|
|
20
21
|
__exportStar(require("./sqlBuilder"), exports);
|
|
21
22
|
__exportStar(require("./vmBuilder"), exports);
|
|
22
23
|
__exportStar(require("./vnetBuilder"), exports);
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQnVpbGRlci90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTZCO0FBQzdCLG1EQUFpQztBQUNqQyxtREFBaUM7QUFDakMsb0RBQWtDO0FBQ2xDLCtDQUE2QjtBQUM3Qiw4Q0FBNEI7QUFDNUIsZ0RBQThCIn0=
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Input } from "@pulumi/pulumi";
|
|
2
|
+
import { ResourceInfo } from "../../types";
|
|
3
|
+
import { DnsZoneARecordType } from "./dnsZoneBuilder";
|
|
4
|
+
export type PrivateDnsZoneVnetLinkingType = {
|
|
5
|
+
vnetIds?: Input<string>[];
|
|
6
|
+
subnetIds?: Input<string>[];
|
|
7
|
+
registrationEnabled?: boolean;
|
|
8
|
+
};
|
|
9
|
+
export interface IPrivateDnsZoneBuilder {
|
|
10
|
+
withARecord(props: DnsZoneARecordType): IPrivateDnsZoneBuilder;
|
|
11
|
+
linkTo(props: PrivateDnsZoneVnetLinkingType): IPrivateDnsZoneBuilder;
|
|
12
|
+
build(): ResourceInfo;
|
|
13
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZURuc1pvbmVCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0J1aWxkZXIvdHlwZXMvcHJpdmF0ZURuc1pvbmVCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
|
|
@@ -19,28 +19,28 @@ export type ResourceVaultLinkingBuilderType = {
|
|
|
19
19
|
asPrivateLink?: boolean;
|
|
20
20
|
};
|
|
21
21
|
export interface IResourceRoleBuilder {
|
|
22
|
-
createRoles
|
|
23
|
-
withRoles
|
|
24
|
-
withRolesFromVault
|
|
22
|
+
createRoles(): IResourceGroupBuilder;
|
|
23
|
+
withRoles(props: EnvRolesResults): IResourceGroupBuilder;
|
|
24
|
+
withRolesFromVault(): IResourceGroupBuilder;
|
|
25
25
|
}
|
|
26
26
|
export interface IResourceGroupBuilder {
|
|
27
|
-
createRG
|
|
28
|
-
withRG
|
|
27
|
+
createRG(props: ResourceGroupBuilderType): IResourceVaultBuilder;
|
|
28
|
+
withRG(props: ResourceGroupInfo): IResourceVaultBuilder;
|
|
29
29
|
}
|
|
30
30
|
export interface IResourceVaultBuilder {
|
|
31
|
-
createVault
|
|
32
|
-
withVault
|
|
31
|
+
createVault(): IResourceBuilder;
|
|
32
|
+
withVault(props: KeyVaultInfo): IResourceBuilder;
|
|
33
33
|
}
|
|
34
34
|
export interface IResourceVaultItemsBuilder {
|
|
35
|
-
addSecrets
|
|
35
|
+
addSecrets(items: Record<string, Input<string>>): IResourceBuilder;
|
|
36
36
|
}
|
|
37
37
|
export interface IResourceVnetBuilder {
|
|
38
|
-
withVnet
|
|
39
|
-
linkVaultTo
|
|
38
|
+
withVnet(props: ResourceVnetBuilderType): IResourceBuilder;
|
|
39
|
+
linkVaultTo(props: ResourceVaultLinkingBuilderType): IResourceBuilder;
|
|
40
40
|
}
|
|
41
41
|
export interface IResourceBuilder extends IResourceVnetBuilder, IResourceVaultItemsBuilder {
|
|
42
|
-
lock
|
|
43
|
-
withBuilder
|
|
44
|
-
withBuilderAsync
|
|
45
|
-
build
|
|
42
|
+
lock(): IResourceBuilder;
|
|
43
|
+
withBuilder(props: BuilderFunctionType): IResourceBuilder;
|
|
44
|
+
withBuilderAsync(props: BuilderAsyncFunctionType): IResourceBuilder;
|
|
45
|
+
build(): Promise<ResourceBuilderResults>;
|
|
46
46
|
}
|
|
@@ -1,20 +1,25 @@
|
|
|
1
1
|
import { IBuilder, ILoginBuilder } from "./genericBuilder";
|
|
2
|
-
import { SqlAuthType, SqlElasticPoolType, SqlNetworkType, SqlResults } from "../../Sql";
|
|
2
|
+
import { SqlAuthType, SqlElasticPoolType, SqlNetworkType, SqlResults, SqlVulnerabilityAssessmentType } from "../../Sql";
|
|
3
3
|
import { SqlDbSku } from "../../Sql/SqlDb";
|
|
4
|
+
import { LogStorageInfo } from "../../Logs/Helpers";
|
|
4
5
|
export type SqlBuilderAuthOptionsType = Pick<SqlAuthType, "azureAdOnlyAuthentication">;
|
|
5
6
|
export type SqlDbBuilderType = Record<string, {
|
|
6
7
|
name?: string;
|
|
7
8
|
sku?: SqlDbSku;
|
|
8
9
|
}>;
|
|
10
|
+
export type SqlBuilderVulnerabilityAssessmentType = {
|
|
11
|
+
logInfo: LogStorageInfo;
|
|
12
|
+
} & Pick<SqlVulnerabilityAssessmentType, "alertEmails">;
|
|
9
13
|
export interface ISqlLoginBuilder extends ILoginBuilder<ISqlAuthBuilder> {
|
|
10
14
|
}
|
|
11
15
|
export interface ISqlAuthBuilder {
|
|
12
|
-
withAuthOptions
|
|
16
|
+
withAuthOptions(props: SqlBuilderAuthOptionsType): ISqlNetworkBuilder;
|
|
13
17
|
}
|
|
14
18
|
export interface ISqlNetworkBuilder {
|
|
15
|
-
withNetwork
|
|
19
|
+
withNetwork(props: SqlNetworkType): ISqlBuilder;
|
|
16
20
|
}
|
|
17
21
|
export interface ISqlBuilder extends IBuilder<SqlResults> {
|
|
18
|
-
withElasticPool
|
|
19
|
-
withDatabases
|
|
22
|
+
withElasticPool(props: SqlElasticPoolType): ISqlBuilder;
|
|
23
|
+
withDatabases(props: SqlDbBuilderType): ISqlBuilder;
|
|
24
|
+
withVulnerabilityAssessment(props: SqlBuilderVulnerabilityAssessmentType): ISqlBuilder;
|
|
20
25
|
}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { BasicMonitorArgs, KeyVaultInfo } from "../../types";
|
|
2
2
|
import { Input } from "@pulumi/pulumi";
|
|
3
3
|
export interface IVaultBuilderResults {
|
|
4
|
-
info
|
|
5
|
-
addSecrets
|
|
6
|
-
privateLinkTo
|
|
7
|
-
linkTo
|
|
4
|
+
info(): KeyVaultInfo;
|
|
5
|
+
addSecrets(items: Record<string, Input<string>>): IVaultBuilderResults;
|
|
6
|
+
privateLinkTo(subnetIds: Input<string>[]): IVaultBuilderResults;
|
|
7
|
+
linkTo(props: {
|
|
8
8
|
subnetIds: Input<string>[];
|
|
9
9
|
ipAddresses: Input<string>[];
|
|
10
|
-
})
|
|
10
|
+
}): IVaultBuilderResults;
|
|
11
11
|
}
|
|
12
12
|
export interface IVaultBuilder {
|
|
13
13
|
name: string;
|
|
14
|
-
withDiagnostic
|
|
15
|
-
build
|
|
14
|
+
withDiagnostic(logInfo: BasicMonitorArgs): IVaultBuilder;
|
|
15
|
+
build(): IVaultBuilderResults;
|
|
16
16
|
}
|
|
@@ -13,17 +13,17 @@ export type VmOsBuilderLinuxProps = {
|
|
|
13
13
|
};
|
|
14
14
|
export type VmSizeTypes = "Standard_D2a_v4" | "Standard_D4a_v4" | "Standard_D8a_v4" | "Standard_D16a_v4" | "Standard_D32a_v4" | "Standard_D48a_v4" | "Standard_D64a_v4" | "Standard_D96a_v4" | "Standard_D2as_v4" | "Standard_D4as_v4" | "Standard_D8as_v4" | "Standard_D16as_v4" | "Standard_D32as_v4" | "Standard_D48as_v4" | "Standard_D64as_v4" | "Standard_D96as_v4" | "Standard_E2_v4" | "Standard_E4_v4" | "Standard_E8_v4" | "Standard_E16_v4" | "Standard_E20_v4" | "Standard_E32_v4" | "Standard_E48_v4" | "Standard_E64_v4" | "Standard_E8-4ads_v5" | "Standard_E16-4ads_v5" | "Standard_E32-8ads_v5" | "Standard_E64-16ads_v5" | "Standard_E96-24ads_v5" | string;
|
|
15
15
|
export interface IVmOsBuilder {
|
|
16
|
-
withWindowsImage
|
|
17
|
-
withLinuxImage
|
|
16
|
+
withWindowsImage(props: VmOsBuilderWindowsProps): IVmSizeBuilder;
|
|
17
|
+
withLinuxImage(props: VmOsBuilderLinuxProps): IVmSizeBuilder;
|
|
18
18
|
}
|
|
19
19
|
export interface IVmSizeBuilder {
|
|
20
|
-
withSize
|
|
20
|
+
withSize(props: VmSizeTypes): IVmLoginBuilder;
|
|
21
21
|
}
|
|
22
22
|
export interface IVmLoginBuilder extends ILoginBuilder<IVmVnetBuilder> {
|
|
23
23
|
}
|
|
24
24
|
export interface IVmVnetBuilder {
|
|
25
|
-
withSubnetId
|
|
25
|
+
withSubnetId(props: Input<string>): IVmBuilder;
|
|
26
26
|
}
|
|
27
27
|
export interface IVmBuilder extends IBuilder<VirtualMachine> {
|
|
28
|
-
withTags
|
|
28
|
+
withTags(props: Record<string, Input<string>>): IVmBuilder;
|
|
29
29
|
}
|
|
@@ -10,6 +10,12 @@ import { VpnGatewayProps } from "../../VNet/VPNGateway";
|
|
|
10
10
|
import { CustomSecurityRuleArgs, RouteArgs } from "../../VNet/types";
|
|
11
11
|
import { LogInfoResults } from "../../Logs/Helpers";
|
|
12
12
|
import { PublicIpAddressPrefixResult } from "../../VNet/IpAddressPrefix";
|
|
13
|
+
export type VnetBuilderResults = VnetResult & {
|
|
14
|
+
publicIpAddress: PublicIpAddressPrefixResult | undefined;
|
|
15
|
+
firewall: FirewallResult | undefined;
|
|
16
|
+
natGateway: network.NatGateway | undefined;
|
|
17
|
+
vnpGateway: network.VirtualNetworkGateway | undefined;
|
|
18
|
+
};
|
|
13
19
|
export type VnetBuilderProps = {
|
|
14
20
|
subnets?: SubnetCreationProps;
|
|
15
21
|
} & Pick<VnetProps, "addressSpaces" | "dnsServers">;
|
|
@@ -36,29 +42,23 @@ export type VpnGatewayCreationProps = Pick<VpnGatewayProps, "sku" | "vpnClientAd
|
|
|
36
42
|
subnetSpace: string;
|
|
37
43
|
};
|
|
38
44
|
export interface IVnetBuilderStart {
|
|
39
|
-
asHub
|
|
40
|
-
asSpoke
|
|
45
|
+
asHub(props?: VnetBuilderProps): IPublicIpBuilder;
|
|
46
|
+
asSpoke(props?: VnetBuilderProps): IVnetBuilder;
|
|
41
47
|
}
|
|
42
48
|
export interface IPublicIpBuilder {
|
|
43
|
-
withPublicIpAddress
|
|
49
|
+
withPublicIpAddress(type: "prefix" | "individual"): IGatewayFireWallBuilder;
|
|
44
50
|
}
|
|
45
51
|
export interface IFireWallOrVnetBuilder extends IBuilder<VnetBuilderResults> {
|
|
46
|
-
withFirewall
|
|
52
|
+
withFirewall(props: FirewallCreationProps): IVnetBuilder;
|
|
47
53
|
}
|
|
48
54
|
export interface IGatewayFireWallBuilder extends IFireWallOrVnetBuilder {
|
|
49
|
-
withNatGateway
|
|
55
|
+
withNatGateway(): IFireWallOrVnetBuilder;
|
|
50
56
|
}
|
|
51
57
|
export interface IVnetBuilder extends IBuilder<VnetBuilderResults> {
|
|
52
|
-
withBastion
|
|
53
|
-
peeringTo
|
|
54
|
-
withSecurityRules
|
|
55
|
-
withRouteRules
|
|
56
|
-
withLogInfo
|
|
57
|
-
withVpnGateway
|
|
58
|
+
withBastion(props: BastionCreationProps): IVnetBuilder;
|
|
59
|
+
peeringTo(props: PeeringProps): IVnetBuilder;
|
|
60
|
+
withSecurityRules(rules: CustomSecurityRuleArgs[]): IVnetBuilder;
|
|
61
|
+
withRouteRules(rules: RouteArgs[]): IVnetBuilder;
|
|
62
|
+
withLogInfo(info: LogInfoResults): IVnetBuilder;
|
|
63
|
+
withVpnGateway(props: VpnGatewayCreationProps): IVnetBuilder;
|
|
58
64
|
}
|
|
59
|
-
export type VnetBuilderResults = VnetResult & {
|
|
60
|
-
publicIpAddress: PublicIpAddressPrefixResult | undefined;
|
|
61
|
-
firewall: FirewallResult | undefined;
|
|
62
|
-
natGateway: network.NatGateway | undefined;
|
|
63
|
-
vnpGateway: network.VirtualNetworkGateway | undefined;
|
|
64
|
-
};
|
package/Common/GlobalEnv.d.ts
CHANGED
package/Common/GlobalEnv.js
CHANGED
|
@@ -14,9 +14,6 @@ exports.globalConvention = {
|
|
|
14
14
|
exports.groupInfo = {
|
|
15
15
|
resourceGroupName: (0, ResourceEnv_1.getResourceName)(exports.globalKeyName, exports.globalConvention),
|
|
16
16
|
};
|
|
17
|
-
// export const logGroupInfo: ResourceGroupInfo = {
|
|
18
|
-
// resourceGroupName: getResourceName('logs', globalConvention),
|
|
19
|
-
// };
|
|
20
17
|
exports.cdnProfileInfo = {
|
|
21
18
|
profileName: `${exports.globalKeyName}-${StackEnv_1.organization}-cdn-pfl`,
|
|
22
19
|
...exports.groupInfo,
|
|
@@ -27,12 +24,4 @@ exports.keyVaultInfo = {
|
|
|
27
24
|
group: exports.groupInfo,
|
|
28
25
|
id: (0, pulumi_1.interpolate) `/subscriptions/${AzureEnv_1.subscriptionId}/resourceGroups/${exports.groupInfo.resourceGroupName}/providers/Microsoft.KeyVault/vaults/${exports.globalKeyName}-${StackEnv_1.organization}-vlt`,
|
|
29
26
|
};
|
|
30
|
-
|
|
31
|
-
// export const logWpInfo: BasicMonitorArgs = {
|
|
32
|
-
// logWpId: interpolate`/subscriptions/${subscriptionId}/resourcegroups/${logGroupInfo.resourceGroupName}/providers/microsoft.operationalinsights/workspaces/${globalKeyName}-${organization}-logs-log`,
|
|
33
|
-
// };
|
|
34
|
-
//
|
|
35
|
-
// export const logStorageInfo: BasicMonitorArgs = {
|
|
36
|
-
// logStorageId: interpolate`/subscriptions/${subscriptionId}/resourceGroups/${logGroupInfo.resourceGroupName}/providers/Microsoft.Storage/storageAccounts/${globalKeyName}${organization}logsstg`,
|
|
37
|
-
// };
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR2xvYmFsRW52LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0NvbW1vbi9HbG9iYWxFbnYudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EseUNBQTRDO0FBQzVDLCtDQUFnRDtBQUNoRCwyQ0FBNkM7QUFDN0MseUNBQTBDO0FBRTdCLFFBQUEsYUFBYSxHQUFHLFFBQVEsQ0FBQztBQUV0QyxvQ0FBb0M7QUFDdkIsUUFBQSxnQkFBZ0IsR0FBb0I7SUFDL0MsTUFBTSxFQUFFLHFCQUFhO0lBQ3JCLE1BQU0sRUFBRSx1QkFBWSxDQUFDLENBQUMsQ0FBQyxPQUFPLHVCQUFZLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSztDQUNyRCxDQUFDO0FBRVcsUUFBQSxTQUFTLEdBQXNCO0lBQzFDLGlCQUFpQixFQUFFLElBQUEsNkJBQWUsRUFBQyxxQkFBYSxFQUFFLHdCQUFnQixDQUFDO0NBQ3BFLENBQUM7QUFFRixtREFBbUQ7QUFDbkQsa0VBQWtFO0FBQ2xFLEtBQUs7QUFFUSxRQUFBLGNBQWMsR0FBRztJQUM1QixXQUFXLEVBQUUsR0FBRyxxQkFBYSxJQUFJLHVCQUFZLFVBQVU7SUFDdkQsR0FBRyxpQkFBUztDQUNiLENBQUM7QUFFRiw0QkFBNEI7QUFDZixRQUFBLFlBQVksR0FBaUI7SUFDeEMsSUFBSSxFQUFFLEdBQUcscUJBQWEsSUFBSSx1QkFBWSxNQUFNO0lBQzVDLEtBQUssRUFBRSxpQkFBUztJQUNoQixFQUFFLEVBQUUsSUFBQSxvQkFBVyxFQUFBLGtCQUFrQix5QkFBYyxtQkFBbUIsaUJBQVMsQ0FBQyxpQkFBaUIsd0NBQXdDLHFCQUFhLElBQUksdUJBQVksTUFBTTtDQUN6SyxDQUFDO0FBRUYsNkhBQTZIO0FBQzdILCtDQUErQztBQUMvQywwTUFBME07QUFDMU0sS0FBSztBQUNMLEVBQUU7QUFDRixvREFBb0Q7QUFDcEQscU1BQXFNO0FBQ3JNLEtBQUsifQ==
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR2xvYmFsRW52LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0NvbW1vbi9HbG9iYWxFbnYudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EseUNBQTRDO0FBQzVDLCtDQUFnRDtBQUNoRCwyQ0FBNkM7QUFDN0MseUNBQTBDO0FBRTdCLFFBQUEsYUFBYSxHQUFHLFFBQVEsQ0FBQztBQUV0QyxvQ0FBb0M7QUFDdkIsUUFBQSxnQkFBZ0IsR0FBb0I7SUFDL0MsTUFBTSxFQUFFLHFCQUFhO0lBQ3JCLE1BQU0sRUFBRSx1QkFBWSxDQUFDLENBQUMsQ0FBQyxPQUFPLHVCQUFZLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSztDQUNyRCxDQUFDO0FBRVcsUUFBQSxTQUFTLEdBQXNCO0lBQzFDLGlCQUFpQixFQUFFLElBQUEsNkJBQWUsRUFBQyxxQkFBYSxFQUFFLHdCQUFnQixDQUFDO0NBQ3BFLENBQUM7QUFFVyxRQUFBLGNBQWMsR0FBRztJQUM1QixXQUFXLEVBQUUsR0FBRyxxQkFBYSxJQUFJLHVCQUFZLFVBQVU7SUFDdkQsR0FBRyxpQkFBUztDQUNiLENBQUM7QUFFRiw0QkFBNEI7QUFDZixRQUFBLFlBQVksR0FBaUI7SUFDeEMsSUFBSSxFQUFFLEdBQUcscUJBQWEsSUFBSSx1QkFBWSxNQUFNO0lBQzVDLEtBQUssRUFBRSxpQkFBUztJQUNoQixFQUFFLEVBQUUsSUFBQSxvQkFBVyxFQUFBLGtCQUFrQix5QkFBYyxtQkFBbUIsaUJBQVMsQ0FBQyxpQkFBaUIsd0NBQXdDLHFCQUFhLElBQUksdUJBQVksTUFBTTtDQUN6SyxDQUFDIn0=
|
package/Logs/Helpers.js
CHANGED
|
@@ -84,7 +84,7 @@ const getLogStorageInfo = ({ storageName, group, vaultInfo, }) => {
|
|
|
84
84
|
const name = (0, Naming_1.getStorageName)(storageName);
|
|
85
85
|
const id = (0, pulumi_1.interpolate) `/subscriptions/${AzureEnv_1.subscriptionId}/resourcegroups/${group.resourceGroupName}/providers/Microsoft.Storage/storageAccounts/${name}`;
|
|
86
86
|
const secrets = vaultInfo
|
|
87
|
-
? (0, pulumi_1.output)((0, Helper_2.getStorageSecrets)({ name, vaultInfo }))
|
|
87
|
+
? (0, pulumi_1.output)((0, Helper_2.getStorageSecrets)({ name, nameFormatted: true, vaultInfo }))
|
|
88
88
|
: undefined;
|
|
89
89
|
return { name, group, id, secrets };
|
|
90
90
|
};
|
|
@@ -105,4 +105,4 @@ const getLogInfo = (groupName, vaultInfo = undefined) => {
|
|
|
105
105
|
return { logWp, logStorage };
|
|
106
106
|
};
|
|
107
107
|
exports.getLogInfo = getLogInfo;
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Mb2dzL0hlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQStDO0FBQy9DLDJDQUFvRTtBQUNwRSxpREFJNEI7QUFDNUIsNkNBSzBCO0FBQzFCLCtDQUErQztBQUMvQyw4Q0FBNkU7QUFFN0UsdURBQXdEO0FBRWpELE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxFQUMvQixJQUFJLEVBQ0osZ0JBQWdCLEVBQ2hCLE9BQU8sRUFDUCxZQUFZLEVBQ1osaUJBQWlCLEdBQUcsQ0FBQyxZQUFZLENBQUMsRUFDbEMsY0FBYyxFQUNkLFNBQVMsR0FDTyxFQUFFLEVBQUU7SUFDcEIsNENBQTRDO0lBQzVDLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUM5QixPQUFPLENBQUMsS0FBSyxDQUNYLG1CQUFtQixJQUFJLG1EQUFtRCxDQUMzRSxDQUFDO1FBQ0YsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELGtDQUFrQztJQUNsQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztRQUN0QixPQUFPLENBQUMsS0FBSyxDQUFDLHVCQUF1QixJQUFJLHFCQUFxQixDQUFDLENBQUM7UUFDaEUsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELE1BQU0sQ0FBQyxHQUFHLEdBQUcsSUFBSSxPQUFPLENBQUM7SUFDekIsT0FBTyxJQUFJLE1BQU0sQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQzFDLENBQUMsRUFDRDtRQUNFLElBQUksRUFBRSxDQUFDO1FBQ1AsV0FBVyxFQUFFLGdCQUFnQjtRQUM3QiwyQkFBMkIsRUFBRSxrQkFBa0I7UUFFL0MsV0FBVyxFQUFFLE9BQU87UUFDcEIsZ0JBQWdCLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVk7UUFFcEQsUUFBUTtRQUNSLE9BQU8sRUFBRSxp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
|
package/Sql/index.d.ts
CHANGED
|
@@ -27,6 +27,12 @@ export type SqlResults = {
|
|
|
27
27
|
elasticPool?: BasicResourceResultProps<sql.ElasticPool>;
|
|
28
28
|
databases?: Record<string, BasicResourceResultProps<sql.Database>>;
|
|
29
29
|
};
|
|
30
|
+
export type SqlVulnerabilityAssessmentType = {
|
|
31
|
+
alertEmails: Array<string>;
|
|
32
|
+
logStorageId: Input<string>;
|
|
33
|
+
storageAccessKey: Input<string>;
|
|
34
|
+
storageEndpoint: Input<string>;
|
|
35
|
+
};
|
|
30
36
|
interface Props extends BasicResourceArgs {
|
|
31
37
|
vaultInfo: KeyVaultInfo;
|
|
32
38
|
enableEncryption?: boolean;
|
|
@@ -38,12 +44,7 @@ interface Props extends BasicResourceArgs {
|
|
|
38
44
|
sku?: SqlDbSku;
|
|
39
45
|
}>;
|
|
40
46
|
network?: SqlNetworkType;
|
|
41
|
-
vulnerabilityAssessment?:
|
|
42
|
-
alertEmails: Array<string>;
|
|
43
|
-
logStorageId?: Input<string>;
|
|
44
|
-
storageAccessKey: Input<string>;
|
|
45
|
-
storageEndpoint: Input<string>;
|
|
46
|
-
};
|
|
47
|
+
vulnerabilityAssessment?: SqlVulnerabilityAssessmentType;
|
|
47
48
|
}
|
|
48
49
|
declare const _default: ({ name, auth, group, enableEncryption, elasticPool, databases, vaultInfo, network, vulnerabilityAssessment, ignoreChanges, }: Props) => SqlResults;
|
|
49
50
|
export default _default;
|
package/Sql/index.js
CHANGED
|
@@ -138,6 +138,19 @@ exports.default = ({ name, auth, group, enableEncryption, elasticPool, databases
|
|
|
138
138
|
scope: vulnerabilityAssessment.logStorageId,
|
|
139
139
|
});
|
|
140
140
|
}
|
|
141
|
+
//Default Alert Policy
|
|
142
|
+
//ServerSecurityAlertPolicy
|
|
143
|
+
const alertPolicy = new sql.ServerSecurityAlertPolicy(name, {
|
|
144
|
+
securityAlertPolicyName: "default",
|
|
145
|
+
...group,
|
|
146
|
+
serverName: sqlServer.name,
|
|
147
|
+
emailAccountAdmins: !vulnerabilityAssessment.alertEmails,
|
|
148
|
+
emailAddresses: vulnerabilityAssessment.alertEmails,
|
|
149
|
+
retentionDays: 7,
|
|
150
|
+
storageAccountAccessKey: vulnerabilityAssessment.storageAccessKey,
|
|
151
|
+
storageEndpoint: vulnerabilityAssessment.storageEndpoint,
|
|
152
|
+
state: "Enabled",
|
|
153
|
+
}, { dependsOn: sqlServer });
|
|
141
154
|
//Server Audit
|
|
142
155
|
new sql.ExtendedServerBlobAuditingPolicy(name, {
|
|
143
156
|
auditActionsAndGroups: [
|
|
@@ -158,19 +171,7 @@ exports.default = ({ name, auth, group, enableEncryption, elasticPool, databases
|
|
|
158
171
|
storageAccountAccessKey: vulnerabilityAssessment.storageAccessKey,
|
|
159
172
|
storageAccountSubscriptionId: AzureEnv_1.subscriptionId,
|
|
160
173
|
storageEndpoint: vulnerabilityAssessment.storageEndpoint,
|
|
161
|
-
});
|
|
162
|
-
//ServerSecurityAlertPolicy
|
|
163
|
-
new sql.ServerSecurityAlertPolicy(name, {
|
|
164
|
-
securityAlertPolicyName: name,
|
|
165
|
-
...group,
|
|
166
|
-
serverName: sqlServer.name,
|
|
167
|
-
emailAccountAdmins: !vulnerabilityAssessment.alertEmails,
|
|
168
|
-
emailAddresses: vulnerabilityAssessment.alertEmails,
|
|
169
|
-
retentionDays: 7,
|
|
170
|
-
storageAccountAccessKey: vulnerabilityAssessment.storageAccessKey,
|
|
171
|
-
storageEndpoint: vulnerabilityAssessment.storageEndpoint,
|
|
172
|
-
state: "Enabled",
|
|
173
|
-
});
|
|
174
|
+
}, { dependsOn: alertPolicy });
|
|
174
175
|
//ServerVulnerabilityAssessment
|
|
175
176
|
new sql.ServerVulnerabilityAssessment(name, {
|
|
176
177
|
vulnerabilityAssessmentName: name,
|
|
@@ -183,7 +184,7 @@ exports.default = ({ name, auth, group, enableEncryption, elasticPool, databases
|
|
|
183
184
|
},
|
|
184
185
|
storageContainerPath: (0, pulumi_1.interpolate) `${vulnerabilityAssessment.storageEndpoint}/${sqlName}`,
|
|
185
186
|
storageAccountAccessKey: vulnerabilityAssessment.storageAccessKey,
|
|
186
|
-
});
|
|
187
|
+
}, { dependsOn: alertPolicy });
|
|
187
188
|
}
|
|
188
189
|
if (encryptKey) {
|
|
189
190
|
// Enable a server key in the SQL Server with reference to the Key Vault Key
|
|
@@ -193,7 +194,7 @@ exports.default = ({ name, auth, group, enableEncryption, elasticPool, databases
|
|
|
193
194
|
serverKeyType: "AzureKeyVault",
|
|
194
195
|
keyName: encryptKey.keyName,
|
|
195
196
|
uri: encryptKey.url,
|
|
196
|
-
}, { ignoreChanges: ["keyName", "uri"] });
|
|
197
|
+
}, { dependsOn: sqlServer, ignoreChanges: ["keyName", "uri"] });
|
|
197
198
|
new sql.EncryptionProtector(`${sqlName}-encryptionProtector`, {
|
|
198
199
|
encryptionProtectorName: "current",
|
|
199
200
|
resourceGroupName: group.resourceGroupName,
|
|
@@ -247,4 +248,4 @@ exports.default = ({ name, auth, group, enableEncryption, elasticPool, databases
|
|
|
247
248
|
databases: dbs,
|
|
248
249
|
};
|
|
249
250
|
};
|
|
250
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
251
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvU3FsL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsZ0RBQWdEO0FBQ2hELDJDQUFpRTtBQUNqRSwrQ0FBNEQ7QUFFNUQsMkRBQXdEO0FBQ3hELGlEQUFxRTtBQUNyRSw2Q0FBd0U7QUFNeEUsMkNBQWtEO0FBQ2xELDZEQUE2RDtBQUM3RCxtQ0FBNkQ7QUFDN0QsMkRBQTJEO0FBQzNELDJDQUEwRDtBQVcxRCxNQUFNLGlCQUFpQixHQUFHLENBQUMsRUFDekIsS0FBSyxFQUNMLElBQUksRUFDSixPQUFPO0FBQ1Asa0JBQWtCO0FBQ2xCLGNBQWMsR0FBRyxFQUFFLEVBQ25CLEdBQUcsR0FBRyxFQUFFLElBQUksRUFBRSxnQkFBSyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEdBQ3pDLEVBQTZDLEVBQUU7SUFDaEUsb0JBQW9CO0lBQ3BCLE1BQU0sV0FBVyxHQUFHLElBQUEsMkJBQWtCLEVBQUMsSUFBSSxDQUFDLENBQUM7SUFFN0MsTUFBTSxFQUFFLEdBQUcsSUFBSSxHQUFHLENBQUMsV0FBVyxDQUFDLFdBQVcsRUFBRTtRQUMxQyxlQUFlLEVBQUUsV0FBVztRQUM1QixVQUFVLEVBQUUsT0FBTztRQUNuQixHQUFHLEtBQUs7UUFFUixZQUFZLEVBQUUsZ0JBQUssQ0FBQyxDQUFDLENBQUMsY0FBYyxHQUFHLElBQUksR0FBRyxJQUFJLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTO1FBQ3JFLEdBQUcsRUFBRTtZQUNILElBQUksRUFBRSxHQUFHLEdBQUcsQ0FBQyxJQUFJLE1BQU07WUFDdkIsSUFBSSxFQUFFLEdBQUcsQ0FBQyxJQUFJO1lBQ2QsUUFBUSxFQUFFLEdBQUcsQ0FBQyxRQUFRO1NBQ3ZCO1FBQ0QsbUJBQW1CLEVBQUU7WUFDbkIsV0FBVyxFQUFFLENBQUM7WUFDZCxX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
|
package/Storage/Helper.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import * as storage from "@pulumi/azure-native/storage";
|
|
2
2
|
import { BasicResourceArgs, KeyVaultInfo } from "../types";
|
|
3
3
|
export type StorageConnectionInfo = {
|
|
4
|
-
primaryConnection
|
|
5
|
-
secondaryConnection
|
|
6
|
-
primaryKey
|
|
7
|
-
secondaryKey
|
|
4
|
+
primaryConnection: string;
|
|
5
|
+
secondaryConnection: string;
|
|
6
|
+
primaryKey: string;
|
|
7
|
+
secondaryKey: string;
|
|
8
8
|
endpoints: {
|
|
9
9
|
blob: string;
|
|
10
10
|
file: string;
|
package/Storage/Helper.js
CHANGED
|
@@ -63,4 +63,4 @@ const getAccountSAS = ({ group, name }) => {
|
|
|
63
63
|
});
|
|
64
64
|
};
|
|
65
65
|
exports.getAccountSAS = getAccountSAS;
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL1N0b3JhZ2UvSGVscGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHdEQUF3RDtBQUV4RCw2Q0FLMEI7QUFDMUIsK0NBQStDO0FBRS9DLGlEQUE2RDtBQWlCdEQsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLEVBQUUsRUFDdEMsSUFBSSxFQUNKLGFBQWEsRUFDYixTQUFTLEdBS1YsRUFBa0MsRUFBRTtJQUNuQyxJQUFJLEdBQUcsYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUEsdUJBQWMsRUFBQyxJQUFJLENBQUMsQ0FBQztJQUNuRCxNQUFNLGNBQWMsR0FBRyxJQUFBLG1CQUFVLEVBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELE1BQU0sZ0JBQWdCLEdBQUcsSUFBQSxtQkFBVSxFQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztJQUN2RCxNQUFNLHdCQUF3QixHQUFHLElBQUEsMEJBQWlCLEVBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ3BFLE1BQU0sdUJBQXVCLEdBQUcsSUFBQSwwQkFBaUIsRUFBQyxJQUFJLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFFckUsTUFBTSxDQUFDLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxZQUFZLENBQUMsR0FDdEUsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUNmO1FBQ0Usd0JBQXdCO1FBQ3hCLHVCQUF1QjtRQUN2QixjQUFjO1FBQ2QsZ0JBQWdCO0tBQ2pCLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7UUFDVixNQUFNLENBQUMsR0FBRyxJQUFBLHNCQUFhLEVBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0IsT0FBTyxJQUFBLGtCQUFTLEVBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNoRSxDQUFDLENBQUMsQ0FDSCxDQUFDO0lBRUosT0FBTztRQUNMLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLEtBQU07UUFDNUMsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsS0FBTTtRQUNoRCxVQUFVLEVBQUUsVUFBVSxFQUFFLEtBQU07UUFDOUIsWUFBWSxFQUFFLFlBQVksRUFBRSxLQUFNO1FBRWxDLFNBQVMsRUFBRTtZQUNULElBQUksRUFBRSxXQUFXLElBQUksd0JBQXdCO1lBQzdDLElBQUksRUFBRSxXQUFXLElBQUksd0JBQXdCO1lBQzdDLEtBQUssRUFBRSxXQUFXLElBQUkseUJBQXlCO1lBQy9DLFVBQVUsRUFBRSxXQUFXLElBQUksMkJBQTJCO1lBQ3RELFFBQVEsRUFBRSxXQUFXLElBQUksdUJBQXVCO1NBQ2pEO0tBQ0YsQ0FBQztBQUNKLENBQUMsQ0FBQztBQTFDVyxRQUFBLGlCQUFpQixxQkEwQzVCO0FBRUssTUFBTSxxQkFBcUIsR0FBRyxLQUFLLEVBQUUsRUFDMUMsU0FBUyxFQUNULFNBQVMsR0FJVixFQUFFLEVBQUU7SUFDSCxNQUFNLElBQUksR0FBRyxJQUFBLGtDQUF1QixFQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2hELE1BQU0sT0FBTyxHQUFHLElBQUk7UUFDbEIsQ0FBQyxDQUFDLE1BQU0sSUFBQSx5QkFBaUIsRUFBQztZQUN0QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7WUFDZixhQUFhLEVBQUUsSUFBSTtZQUNuQixTQUFTO1NBQ1YsQ0FBQztRQUNKLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFFZCxPQUFPLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztBQUNqRCxDQUFDLENBQUM7QUFqQlcsUUFBQSxxQkFBcUIseUJBaUJoQztBQUVLLE1BQU0sYUFBYSxHQUFHLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFxQixFQUFFLEVBQUU7SUFDbEUsTUFBTSxHQUFHLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztJQUN2QixNQUFNLFVBQVUsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO0lBQzlCLFVBQVUsQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBRS9DLE9BQU8sT0FBTyxDQUFDLHFCQUFxQixDQUFDO1FBQ25DLFdBQVcsRUFBRSxJQUFJO1FBQ2pCLEdBQUcsS0FBSztRQUNSLGFBQWEsRUFBRSxPQUFPLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUM1QyxRQUFRLEVBQUUsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzVCLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbEMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxZQUFZLENBQUMsS0FBSztRQUNyQyxxQkFBcUIsRUFBRSxHQUFHLENBQUMsV0FBVyxFQUFFO1FBQ3hDLHNCQUFzQixFQUFFLFVBQVUsQ0FBQyxXQUFXLEVBQUU7S0FDakQsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBZlcsUUFBQSxhQUFhLGlCQWV4QiJ9
|
package/VM/index.js
CHANGED
|
@@ -132,6 +132,7 @@ exports.default = ({ name, group, subnetId, osType = "Windows", vmSize = "Standa
|
|
|
132
132
|
ignoreChanges: [
|
|
133
133
|
"storageProfile.osDisk.managedDisk.storageAccountType",
|
|
134
134
|
"storageProfile.osDisk.managedDisk.id",
|
|
135
|
+
"osDisk.osType",
|
|
135
136
|
],
|
|
136
137
|
});
|
|
137
138
|
if (extensions) {
|
|
@@ -171,4 +172,4 @@ exports.default = ({ name, group, subnetId, osType = "Windows", vmSize = "Standa
|
|
|
171
172
|
// }
|
|
172
173
|
return vm;
|
|
173
174
|
};
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvVk0vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSx3REFBd0Q7QUFDeEQsd0RBQXdEO0FBRXhELDZDQUF5RDtBQUN6RCwyQ0FBb0M7QUFDcEMsK0NBQTREO0FBQzVELHFEQUE4QztBQUM5QywyQ0FBMEQ7QUEyQzFELGtCQUFlLENBQUMsRUFDZCxJQUFJLEVBQ0osS0FBSyxFQUNMLFFBQVEsRUFDUixNQUFNLEdBQUcsU0FBUyxFQUNsQixNQUFNLEdBQUcsY0FBYyxFQUN2QixVQUFVLEVBQ1Ysa0JBQWtCLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixDQUFDLFdBQVcsRUFDNUQsWUFBWSxHQUFHLEdBQUcsRUFDbEIsY0FBYyxFQUNkLGdCQUFnQixFQUNoQixTQUFTLEVBQ1QsUUFBUSxHQUFHLEVBQUUsUUFBUSxFQUFFLHlCQUF5QixFQUFFLEVBQ2xELEtBQUssRUFDTCxLQUFLLEVBQ0wsSUFBSSxHQUFHLElBQUksRUFDWCxJQUFJLEdBQUcsRUFBRSxFQUNULFNBQVMsRUFDVCxHQUFHLE1BQU0sRUFDSCxFQUFFLEVBQUU7SUFDVixNQUFNLE1BQU0sR0FBRyxJQUFBLGtCQUFTLEVBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsTUFBTSxPQUFPLEdBQUcsSUFBQSxtQkFBVSxFQUFDLElBQUksQ0FBQyxDQUFDO0lBRWpDLE1BQU0sR0FBRyxHQUFHLElBQUksT0FBTyxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRTtRQUNoRCxvQkFBb0IsRUFBRSxPQUFPO1FBQzdCLEdBQUcsS0FBSztRQUNSLGdCQUFnQixFQUFFO1lBQ2hCLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRTtTQUM5RDtRQUNELE9BQU8sRUFBRSxPQUFPLENBQUMsdUJBQXVCLENBQUMsUUFBUTtLQUNs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
|
package/VNet/PrivateEndpoint.js
CHANGED
|
@@ -2,10 +2,9 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const network = require("@pulumi/azure-native/network");
|
|
4
4
|
const pulumi_1 = require("@pulumi/pulumi");
|
|
5
|
-
const Helper_1 = require("./Helper");
|
|
6
|
-
const PrivateDns_1 = require("./PrivateDns");
|
|
7
5
|
const AzureEnv_1 = require("../Common/AzureEnv");
|
|
8
6
|
const Naming_1 = require("../Common/Naming");
|
|
7
|
+
const Builder_1 = require("../Builder");
|
|
9
8
|
exports.default = ({ name, group, resourceId, subnetIds, privateDnsZoneName, linkServiceGroupIds, }) => {
|
|
10
9
|
name = (0, Naming_1.getPrivateEndpointName)(name);
|
|
11
10
|
const endpoints = subnetIds.map((s, index) => new network.PrivateEndpoint(`${name}-${index}`, {
|
|
@@ -22,33 +21,16 @@ exports.default = ({ name, group, resourceId, subnetIds, privateDnsZoneName, lin
|
|
|
22
21
|
}));
|
|
23
22
|
//Get IpAddress in
|
|
24
23
|
const ipAddresses = (0, pulumi_1.output)(endpoints.map((e) => e.customDnsConfigs.apply((c) => c.flatMap((i) => i.ipAddresses)))).apply((a) => a.flatMap((i) => i));
|
|
25
|
-
(0, pulumi_1.output)(resourceId).apply((id) => {
|
|
24
|
+
(0, pulumi_1.output)([resourceId, ipAddresses]).apply(([id, ip]) => {
|
|
26
25
|
const resourceInfo = (0, AzureEnv_1.parseResourceInfoFromId)(id);
|
|
27
|
-
|
|
28
|
-
const zone = (0, PrivateDns_1.default)({
|
|
26
|
+
return (0, Builder_1.PrivateDnsZoneBuilder)({
|
|
29
27
|
name: `${resourceInfo.name}.${privateDnsZoneName}`,
|
|
30
28
|
group,
|
|
31
|
-
})
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
recordName: "@",
|
|
36
|
-
dnsInfo: zone.toDnsInfo(),
|
|
37
|
-
dependsOn: zone.resource,
|
|
38
|
-
});
|
|
39
|
-
//Link to Vnet
|
|
40
|
-
subnetIds.map((s, index) => (0, pulumi_1.output)(s).apply((id) => {
|
|
41
|
-
const vnetId = (0, Helper_1.getVnetIdFromSubnetId)(id);
|
|
42
|
-
(0, PrivateDns_1.linkVnetToPrivateDns)({
|
|
43
|
-
name: `${name}-${index}`,
|
|
44
|
-
zoneName: zone.name,
|
|
45
|
-
vnetId,
|
|
46
|
-
group,
|
|
47
|
-
dependsOn: zone.resource,
|
|
48
|
-
});
|
|
49
|
-
}));
|
|
50
|
-
//}
|
|
29
|
+
})
|
|
30
|
+
.withARecord({ ipAddresses: ip, recordName: "@" })
|
|
31
|
+
.linkTo({ subnetIds })
|
|
32
|
+
.build();
|
|
51
33
|
});
|
|
52
34
|
return endpoints;
|
|
53
35
|
};
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHJpdmF0ZUVuZHBvaW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL1ZOZXQvUHJpdmF0ZUVuZHBvaW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsd0RBQXdEO0FBQ3hELDJDQUErQztBQUcvQyxpREFBNkQ7QUFDN0QsNkNBQTBEO0FBQzFELHdDQUFtRDtBQVFuRCxrQkFBZSxDQUFDLEVBQ2QsSUFBSSxFQUNKLEtBQUssRUFDTCxVQUFVLEVBQ1YsU0FBUyxFQUNULGtCQUFrQixFQUNsQixtQkFBbUIsR0FDYixFQUFFLEVBQUU7SUFDVixJQUFJLEdBQUcsSUFBQSwrQkFBc0IsRUFBQyxJQUFJLENBQUMsQ0FBQztJQUVwQyxNQUFNLFNBQVMsR0FBRyxTQUFTLENBQUMsR0FBRyxDQUM3QixDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUNYLElBQUksT0FBTyxDQUFDLGVBQWUsQ0FBQyxHQUFHLElBQUksSUFBSSxLQUFLLEVBQUUsRUFBRTtRQUM5QyxtQkFBbUIsRUFBRSxHQUFHLElBQUksSUFBSSxLQUFLLEVBQUU7UUFDdkMsR0FBRyxLQUFLO1FBRVIsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRTtRQUNqQiw2QkFBNkIsRUFBRTtZQUM3QjtnQkFDRSxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixJQUFJLEVBQUUsR0FBRyxJQUFJLE9BQU87Z0JBQ3BCLG9CQUFvQixFQUFFLFVBQVU7YUFDakM7U0FDRjtLQUNGLENBQUMsQ0FDTCxDQUFDO0lBRUYsa0JBQWtCO0lBQ2xCLE1BQU0sV0FBVyxHQUFHLElBQUEsZUFBTSxFQUN4QixTQUFTLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FDbEIsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFdBQVksQ0FBQyxDQUFDLENBQ25FLENBQ0YsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUUsQ0FBQyxDQUFDLENBQUM7SUFFckMsSUFBQSxlQUFNLEVBQUMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxFQUFFO1FBQ25ELE1BQU0sWUFBWSxHQUFHLElBQUEsa0NBQXVCLEVBQUMsRUFBWSxDQUFDLENBQUM7UUFDM0QsT0FBTyxJQUFBLCtCQUFxQixFQUFDO1lBQzNCLElBQUksRUFBRSxHQUFHLFlBQWEsQ0FBQyxJQUFJLElBQUksa0JBQWtCLEVBQUU7WUFDbkQsS0FBSztTQUNOLENBQUM7YUFDQyxXQUFXLENBQUMsRUFBRSxXQUFXLEVBQUUsRUFBYyxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQzthQUM3RCxNQUFNLENBQUMsRUFBRSxTQUFTLEVBQUUsQ0FBQzthQUNyQixLQUFLLEVBQUUsQ0FBQztJQUNiLENBQUMsQ0FBQyxDQUFDO0lBRUgsT0FBTyxTQUFTLENBQUM7QUFDbkIsQ0FBQyxDQUFDIn0=
|
package/package.json
CHANGED
package/VNet/PrivateDns.d.ts
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import * as native from "@pulumi/azure-native";
|
|
2
|
-
import { Input, Resource } from "@pulumi/pulumi";
|
|
3
|
-
import { BasicResourceArgs, BasicResourceResultProps, ResourceGroupInfo, ResourceInfo } from "../types";
|
|
4
|
-
interface RecordProps {
|
|
5
|
-
recordName: string;
|
|
6
|
-
dnsInfo: ResourceInfo;
|
|
7
|
-
ipAddresses: Input<string>[] | Input<string[]>;
|
|
8
|
-
dependsOn?: Input<Input<Resource>[]> | Input<Resource>;
|
|
9
|
-
}
|
|
10
|
-
export declare const addARecord: ({ recordName, dnsInfo, ipAddresses, dependsOn, }: RecordProps) => import("@pulumi/azure-native/network/privateRecordSet").PrivateRecordSet;
|
|
11
|
-
interface VnetToPrivateDnsProps extends BasicResourceArgs {
|
|
12
|
-
zoneName: Input<string>;
|
|
13
|
-
vnetId: Input<string>;
|
|
14
|
-
registrationEnabled?: boolean;
|
|
15
|
-
}
|
|
16
|
-
export declare const linkVnetToPrivateDns: ({ name, group, zoneName, vnetId, registrationEnabled, ...others }: VnetToPrivateDnsProps) => import("@pulumi/azure-native/network/virtualNetworkLink").VirtualNetworkLink;
|
|
17
|
-
interface Props {
|
|
18
|
-
name: string;
|
|
19
|
-
vnetIds?: Input<string>[];
|
|
20
|
-
group?: ResourceGroupInfo;
|
|
21
|
-
records?: {
|
|
22
|
-
aRecords: Array<Pick<RecordProps, "recordName" | "ipAddresses">>;
|
|
23
|
-
};
|
|
24
|
-
dependsOn?: Input<Input<Resource>[]> | Input<Resource>;
|
|
25
|
-
}
|
|
26
|
-
/** Create Private DNS zone. This should be created in the Global resource group. */
|
|
27
|
-
declare const _default: ({ name, group, vnetIds, records, dependsOn, }: Props) => BasicResourceResultProps<native.network.PrivateZone> & {
|
|
28
|
-
toDnsInfo: () => ResourceInfo;
|
|
29
|
-
};
|
|
30
|
-
export default _default;
|
|
31
|
-
export declare const getPrivateZone: ({ name, group, }: Omit<Props, "vnetIds">) => Promise<native.network.GetPrivateZoneResult>;
|
package/VNet/PrivateDns.js
DELETED
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getPrivateZone = exports.linkVnetToPrivateDns = exports.addARecord = void 0;
|
|
4
|
-
const native = require("@pulumi/azure-native");
|
|
5
|
-
const pulumi_1 = require("@pulumi/pulumi");
|
|
6
|
-
const global = require("../Common/GlobalEnv");
|
|
7
|
-
const addARecord = ({ recordName, dnsInfo, ipAddresses, dependsOn, }) => {
|
|
8
|
-
recordName = recordName.replace("https://", "").replace("http://", "");
|
|
9
|
-
//.replace(`.${zoneName}`, "");
|
|
10
|
-
return new native.network.PrivateRecordSet(recordName === "*"
|
|
11
|
-
? "All-ARecord"
|
|
12
|
-
: recordName === "@"
|
|
13
|
-
? "Root-ARecord"
|
|
14
|
-
: `${recordName}-ARecord`, {
|
|
15
|
-
privateZoneName: dnsInfo.resourceName,
|
|
16
|
-
...dnsInfo.group,
|
|
17
|
-
relativeRecordSetName: recordName,
|
|
18
|
-
recordType: "A",
|
|
19
|
-
aRecords: (0, pulumi_1.output)(ipAddresses).apply((ips) => ips.map((i) => ({ ipv4Address: i }))),
|
|
20
|
-
ttl: 3600,
|
|
21
|
-
}, { dependsOn });
|
|
22
|
-
};
|
|
23
|
-
exports.addARecord = addARecord;
|
|
24
|
-
const linkVnetToPrivateDns = ({ name, group, zoneName, vnetId, registrationEnabled = false, ...others }) => {
|
|
25
|
-
return new native.network.VirtualNetworkLink(`${name}-link`, {
|
|
26
|
-
...group,
|
|
27
|
-
location: "global",
|
|
28
|
-
privateZoneName: zoneName,
|
|
29
|
-
registrationEnabled,
|
|
30
|
-
virtualNetwork: { id: vnetId },
|
|
31
|
-
}, others);
|
|
32
|
-
};
|
|
33
|
-
exports.linkVnetToPrivateDns = linkVnetToPrivateDns;
|
|
34
|
-
/** Create Private DNS zone. This should be created in the Global resource group. */
|
|
35
|
-
exports.default = ({ name, group = global.groupInfo, vnetIds, records, dependsOn, }) => {
|
|
36
|
-
const zone = new native.network.PrivateZone(name, {
|
|
37
|
-
privateZoneName: name,
|
|
38
|
-
...group,
|
|
39
|
-
location: "global",
|
|
40
|
-
}, { dependsOn });
|
|
41
|
-
const toDnsInfo = () => ({ resourceName: name, group, id: zone.id });
|
|
42
|
-
if (vnetIds) {
|
|
43
|
-
vnetIds.map((id) => (0, exports.linkVnetToPrivateDns)({
|
|
44
|
-
name,
|
|
45
|
-
vnetId: id,
|
|
46
|
-
zoneName: name,
|
|
47
|
-
group,
|
|
48
|
-
registrationEnabled: false,
|
|
49
|
-
dependsOn: zone,
|
|
50
|
-
}));
|
|
51
|
-
}
|
|
52
|
-
if (records) {
|
|
53
|
-
if (records.aRecords) {
|
|
54
|
-
records.aRecords.map((a) => (0, exports.addARecord)({ ...a, dnsInfo: toDnsInfo(), dependsOn: zone }));
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
return {
|
|
58
|
-
name,
|
|
59
|
-
resource: zone,
|
|
60
|
-
toDnsInfo,
|
|
61
|
-
};
|
|
62
|
-
};
|
|
63
|
-
const getPrivateZone = ({ name, group = global.groupInfo, }) => native.network.getPrivateZone({
|
|
64
|
-
privateZoneName: name,
|
|
65
|
-
resourceGroupName: group.resourceGroupName,
|
|
66
|
-
});
|
|
67
|
-
exports.getPrivateZone = getPrivateZone;
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHJpdmF0ZURucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9WTmV0L1ByaXZhdGVEbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQStDO0FBQy9DLDJDQUE4RDtBQUM5RCw4Q0FBOEM7QUFldkMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxFQUN6QixVQUFVLEVBQ1YsT0FBTyxFQUNQLFdBQVcsRUFDWCxTQUFTLEdBQ0csRUFBRSxFQUFFO0lBQ2hCLFVBQVUsR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZFLCtCQUErQjtJQUUvQixPQUFPLElBQUksTUFBTSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FDeEMsVUFBVSxLQUFLLEdBQUc7UUFDaEIsQ0FBQyxDQUFDLGFBQWE7UUFDZixDQUFDLENBQUMsVUFBVSxLQUFLLEdBQUc7WUFDbEIsQ0FBQyxDQUFDLGNBQWM7WUFDaEIsQ0FBQyxDQUFDLEdBQUcsVUFBVSxVQUFVLEVBQzdCO1FBQ0UsZUFBZSxFQUFFLE9BQU8sQ0FBQyxZQUFZO1FBQ3JDLEdBQUcsT0FBTyxDQUFDLEtBQUs7UUFDaEIscUJBQXFCLEVBQUUsVUFBVTtRQUNqQyxVQUFVLEVBQUUsR0FBRztRQUNmLFFBQVEsRUFBRSxJQUFBLGVBQU0sRUFBQyxXQUFXLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUMxQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsV0FBVyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FDckM7UUFDRCxHQUFHLEVBQUUsSUFBSTtLQUNWLEVBQ0QsRUFBRSxTQUFTLEVBQUUsQ0FDZCxDQUFDO0FBQ0osQ0FBQyxDQUFDO0FBM0JXLFFBQUEsVUFBVSxjQTJCckI7QUFRSyxNQUFNLG9C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
|
package/VNet/PublicDns.d.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Input } from "@pulumi/pulumi";
|
|
2
|
-
interface RecordProps {
|
|
3
|
-
zoneName: Input<string>;
|
|
4
|
-
recordName: string;
|
|
5
|
-
ipAddresses: string[];
|
|
6
|
-
}
|
|
7
|
-
export declare const addARecord: ({ zoneName, recordName, ipAddresses, }: RecordProps) => import("@pulumi/azure-native/network/recordSet").RecordSet;
|
|
8
|
-
interface ZoneProps {
|
|
9
|
-
name: string;
|
|
10
|
-
defaultIpAddress?: string;
|
|
11
|
-
}
|
|
12
|
-
interface Props extends ZoneProps {
|
|
13
|
-
name: string;
|
|
14
|
-
childZones?: Array<ZoneProps>;
|
|
15
|
-
}
|
|
16
|
-
/** Create Private DNS zone. */
|
|
17
|
-
declare const _default: ({ name, defaultIpAddress, childZones }: Props) => {
|
|
18
|
-
zone: import("@pulumi/azure-native/network/zone").Zone;
|
|
19
|
-
child: import("@pulumi/azure-native/network/zone").Zone[] | undefined;
|
|
20
|
-
};
|
|
21
|
-
export default _default;
|
package/VNet/PublicDns.js
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.addARecord = void 0;
|
|
4
|
-
const network = require("@pulumi/azure-native/network");
|
|
5
|
-
const Common_1 = require("../Common");
|
|
6
|
-
const addARecord = ({ zoneName, recordName, ipAddresses, }) => new network.RecordSet(recordName === "*"
|
|
7
|
-
? "All-ARecord"
|
|
8
|
-
: recordName === "@"
|
|
9
|
-
? "Root-ARecord"
|
|
10
|
-
: `${recordName}-ARecord`, {
|
|
11
|
-
zoneName,
|
|
12
|
-
...Common_1.global.groupInfo,
|
|
13
|
-
relativeRecordSetName: recordName,
|
|
14
|
-
recordType: "A",
|
|
15
|
-
aRecords: ipAddresses.map((i) => ({ ipv4Address: i })),
|
|
16
|
-
ttl: 3600,
|
|
17
|
-
});
|
|
18
|
-
exports.addARecord = addARecord;
|
|
19
|
-
/** Create Private DNS zone. This should be created in the GLobal resource group. */
|
|
20
|
-
const zoneCreator = ({ name, defaultIpAddress }) => {
|
|
21
|
-
const zone = new network.Zone(name, {
|
|
22
|
-
zoneName: name,
|
|
23
|
-
zoneType: network.ZoneType.Public,
|
|
24
|
-
location: Common_1.global.globalKeyName,
|
|
25
|
-
...Common_1.global.groupInfo,
|
|
26
|
-
});
|
|
27
|
-
if (defaultIpAddress) {
|
|
28
|
-
(0, exports.addARecord)({
|
|
29
|
-
ipAddresses: [defaultIpAddress],
|
|
30
|
-
zoneName: name,
|
|
31
|
-
recordName: "@",
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
return zone;
|
|
35
|
-
};
|
|
36
|
-
/** Create Private DNS zone. */
|
|
37
|
-
exports.default = ({ name, defaultIpAddress, childZones }) => {
|
|
38
|
-
const zone = zoneCreator({ name, defaultIpAddress });
|
|
39
|
-
let child = undefined;
|
|
40
|
-
if (childZones) {
|
|
41
|
-
child = childZones.map((z) => {
|
|
42
|
-
const c = zoneCreator({ ...z, name: `${z.name}.${name}` });
|
|
43
|
-
c.nameServers.apply((ns) => {
|
|
44
|
-
//Add NS and Other Record to the Parent Zone
|
|
45
|
-
new network.RecordSet(`${z.name}.${name}-NS`, {
|
|
46
|
-
zoneName: zone.name,
|
|
47
|
-
...Common_1.global.groupInfo,
|
|
48
|
-
relativeRecordSetName: z.name,
|
|
49
|
-
recordType: "NS",
|
|
50
|
-
nsRecords: ns.map((s) => ({ nsdname: s })),
|
|
51
|
-
ttl: 3600,
|
|
52
|
-
}, { dependsOn: c });
|
|
53
|
-
});
|
|
54
|
-
return c;
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
return { zone, child };
|
|
58
|
-
};
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHVibGljRG5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL1ZOZXQvUHVibGljRG5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHdEQUF3RDtBQUV4RCxzQ0FBbUM7QUFRNUIsTUFBTSxVQUFVLEdBQUcsQ0FBQyxFQUN6QixRQUFRLEVBQ1IsVUFBVSxFQUNWLFdBQVcsR0FDQyxFQUFFLEVBQUUsQ0FDaEIsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUNuQixVQUFVLEtBQUssR0FBRztJQUNoQixDQUFDLENBQUMsYUFBYTtJQUNmLENBQUMsQ0FBQyxVQUFVLEtBQUssR0FBRztRQUNwQixDQUFDLENBQUMsY0FBYztRQUNoQixDQUFDLENBQUMsR0FBRyxVQUFVLFVBQVUsRUFDM0I7SUFDRSxRQUFRO0lBQ1IsR0FBRyxlQUFNLENBQUMsU0FBUztJQUNuQixxQkFBcUIsRUFBRSxVQUFVO0lBQ2pDLFVBQVUsRUFBRSxHQUFHO0lBQ2YsUUFBUSxFQUFFLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxXQUFXLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUN0RCxHQUFHLEVBQUUsSUFBSTtDQUNWLENBQ0YsQ0FBQztBQW5CUyxRQUFBLFVBQVUsY0FtQm5CO0FBT0osb0ZBQW9GO0FBQ3BGLE1BQU0sV0FBVyxHQUFHLENBQUMsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQVMsRUFBRSxFQUFFO0lBQ3hELE1BQU0sSUFBSSxHQUFHLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUU7UUFDbEMsUUFBUSxFQUFFLElBQUk7UUFDZCxRQUFRLEVBQUUsT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNO1FBQ2pDLFFBQVEsRUFBRSxlQUFNLENBQUMsYUFBYTtRQUM5QixHQUFHLGVBQU0sQ0FBQyxTQUFTO0tBQ3BCLENBQUMsQ0FBQztJQUVILElBQUksZ0JBQWdCLEVBQUUsQ0FBQztRQUNyQixJQUFBLGtCQUFVLEVBQUM7WUFDVCxXQUFXLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztZQUMvQixRQUFRLEVBQUUsSUFBSTtZQUNkLFVBQVUsRUFBRSxHQUFHO1NBQ2hCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMsQ0FBQztBQU9GLCtCQUErQjtBQUMvQixrQkFBZSxDQUFDLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLFVBQVUsRUFBUyxFQUFFLEVBQUU7SUFDL0QsTUFBTSxJQUFJLEdBQUcsV0FBVyxDQUFDLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLENBQUMsQ0FBQztJQUVyRCxJQUFJLEtBQUssR0FBb0MsU0FBUyxDQUFDO0lBQ3ZELElBQUksVUFBVSxFQUFFLENBQUM7UUFDZixLQUFLLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQzNCLE1BQU0sQ0FBQyxHQUFHLFdBQVcsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBRTNELENBQUMsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUU7Z0JBQ3pCLDRDQUE0QztnQkFDNUMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUNuQixHQUFHLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxLQUFLLEVBQ3RCO29CQUNFLFFBQVEsRUFBRSxJQUFJLENBQUMsSUFBSTtvQkFDbkIsR0FBRyxlQUFNLENBQUMsU0FBUztvQkFDbkIscUJBQXFCLEVBQUUsQ0FBQyxDQUFDLElBQUk7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixTQUFTLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO29CQUMxQyxHQUFHLEVBQUUsSUFBSTtpQkFDVixFQUNELEVBQUUsU0FBUyxFQUFFLENBQUMsRUFBRSxDQUNqQixDQUFDO1lBQ0osQ0FBQyxDQUFDLENBQUM7WUFFSCxPQUFPLENBQUMsQ0FBQztRQUNYLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLENBQUM7QUFDekIsQ0FBQyxDQUFDIn0=
|