@drunk-pulumi/azure 1.0.6 → 1.0.8
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 +3 -3
- package/Aks/Helper.js +2 -3
- package/Aks/Identity.js +17 -17
- package/Aks/index.d.ts +13 -15
- package/Aks/index.js +63 -64
- package/Automation/index.d.ts +4 -4
- package/Automation/index.js +13 -9
- package/AzAd/EnvRoles.d.ts +0 -5
- package/AzAd/EnvRoles.js +3 -4
- package/AzAd/Group.d.ts +4 -4
- package/AzAd/Group.js +14 -5
- package/AzAd/Helper.d.ts +3 -8
- package/AzAd/Helper.js +67 -51
- package/AzAd/Identities/AzDevOpsManagedIdentity.d.ts +3 -3
- package/AzAd/Identities/AzDevOpsManagedIdentity.js +4 -4
- package/AzAd/Identities/AzUserAdRevertSync.d.ts +2 -2
- package/AzAd/Identities/EnvUID.d.ts +4 -0
- package/AzAd/Identities/EnvUID.js +21 -0
- package/AzAd/Identities/index.d.ts +1 -1
- package/AzAd/Identities/index.js +3 -3
- package/AzAd/Identity.d.ts +2 -2
- package/AzAd/Identity.js +3 -8
- package/AzAd/RoleAssignment.d.ts +2 -2
- package/AzAd/UserAssignedIdentity.d.ts +4 -3
- package/AzAd/UserAssignedIdentity.js +10 -13
- package/Builder/AksBuilder.d.ts +2 -2
- package/Builder/AksBuilder.js +14 -7
- package/Builder/ApimBuilder.js +8 -10
- package/Builder/CdnBuilder.d.ts +2 -2
- package/Builder/CdnBuilder.js +1 -1
- package/Builder/PrivateDnsZoneBuilder.js +4 -5
- package/Builder/ResourceBuilder.d.ts +2 -2
- package/Builder/ResourceBuilder.js +42 -5
- package/Builder/SqlBuilder.d.ts +2 -2
- package/Builder/SqlBuilder.js +9 -10
- package/Builder/VaultBuilder.d.ts +2 -3
- package/Builder/VaultBuilder.js +16 -15
- package/Builder/VmBuilder.d.ts +2 -2
- package/Builder/VmBuilder.js +12 -3
- package/Builder/VnetBuilder.d.ts +2 -2
- package/Builder/VnetBuilder.js +100 -53
- package/Builder/types/apimBuilder.d.ts +8 -9
- package/Builder/types/apimPolicyBuilder.d.ts +3 -3
- package/Builder/types/apimProductBuilder.d.ts +2 -2
- package/Builder/types/askBuilder.d.ts +8 -3
- package/Builder/types/envRoleBuilder.d.ts +2 -2
- package/Builder/types/genericBuilder.d.ts +2 -8
- package/Builder/types/genericBuilder.js +1 -1
- package/Builder/types/resourceBuilder.d.ts +12 -6
- package/Builder/types/sqlBuilder.d.ts +4 -5
- package/Builder/types/vaultBuilder.d.ts +4 -3
- package/Builder/types/vmBuilder.d.ts +6 -2
- package/Builder/types/vnetBuilder.d.ts +13 -12
- package/Cdn/CdnEndpoint.d.ts +1 -1
- package/Cdn/CdnEndpoint.js +2 -3
- package/Common/AzureEnv.d.ts +0 -7
- package/Common/AzureEnv.js +2 -44
- package/Common/GlobalEnv.d.ts +1 -3
- package/Common/GlobalEnv.js +19 -21
- package/Common/Helpers.d.ts +0 -1
- package/Common/Helpers.js +29 -29
- package/Common/Naming.d.ts +68 -0
- package/Common/Naming.js +189 -0
- package/Common/RsInfo/Helper.d.ts +4 -0
- package/Common/RsInfo/Helper.js +46 -0
- package/Common/RsInfo/index.d.ts +31 -0
- package/Common/RsInfo/index.js +245 -0
- package/Common/index.d.ts +3 -0
- package/Common/index.js +5 -2
- package/ContainerRegistry/Helper.d.ts +2 -9
- package/ContainerRegistry/Helper.js +36 -31
- package/Core/KeyGenerators.js +2 -2
- package/Core/Locker.d.ts +6 -4
- package/Core/Locker.js +23 -2
- package/Core/Random.d.ts +2 -2
- package/Core/Random.js +2 -1
- package/Core/ResourceCreator.js +3 -6
- package/CosmosDb/index.d.ts +3 -3
- package/CosmosDb/index.js +14 -14
- package/IOT/Hub/index.js +2 -1
- package/KeyVault/CustomHelper.d.ts +4 -3
- package/KeyVault/CustomHelper.js +3 -2
- package/KeyVault/Helper.d.ts +5 -1
- package/KeyVault/Helper.js +13 -2
- package/KeyVault/index.d.ts +1 -6
- package/KeyVault/index.js +19 -14
- package/Logs/AppInsight.js +3 -1
- package/Logs/Helpers.d.ts +5 -54
- package/Logs/Helpers.js +41 -64
- package/Logs/LogAnalytics.d.ts +5 -11
- package/Logs/LogAnalytics.js +11 -11
- package/Logs/WebTest.d.ts +2 -2
- package/Logs/WebTest.js +13 -13
- package/Logs/index.d.ts +7 -22
- package/Logs/index.js +33 -52
- package/Postgresql/index.js +3 -3
- package/ServiceBus/index.d.ts +4 -5
- package/ServiceBus/index.js +10 -8
- package/Sql/Helper.js +4 -4
- package/Sql/SqlDb.js +3 -6
- package/Sql/index.d.ts +2 -5
- package/Sql/index.js +12 -21
- package/Storage/Helper.d.ts +2 -28
- package/Storage/Helper.js +58 -77
- package/Storage/index.d.ts +2 -2
- package/Storage/index.js +7 -6
- package/VM/DiskEncryptionSet.d.ts +4 -6
- package/VM/DiskEncryptionSet.js +18 -6
- package/VM/index.d.ts +3 -3
- package/VM/index.js +37 -13
- package/VNet/Firewall.d.ts +8 -6
- package/VNet/Firewall.js +25 -28
- package/VNet/FirewallPolicies/CloudPCFirewallPolicy.js +2 -2
- package/VNet/Helper.d.ts +3 -20
- package/VNet/Helper.js +6 -49
- package/VNet/IpAddress.js +3 -6
- package/VNet/IpAddressPrefix.d.ts +2 -2
- package/VNet/IpAddressPrefix.js +3 -3
- package/VNet/NSGRules/BlockInternetSecurityRule.d.ts +3 -0
- package/VNet/NSGRules/BlockInternetSecurityRule.js +34 -0
- package/VNet/NSGRules/index.d.ts +5 -4
- package/VNet/NSGRules/index.js +4 -2
- package/VNet/NetworkPeering.d.ts +18 -6
- package/VNet/NetworkPeering.js +43 -27
- package/VNet/PrivateEndpoint.js +2 -2
- package/VNet/RuoteRules/RuoteTo.d.ts +4 -0
- package/VNet/RuoteRules/RuoteTo.js +4 -0
- package/VNet/VirtualWAN.js +2 -2
- package/VNet/types.d.ts +3 -8
- package/Web/AppConfig.js +2 -1
- package/package.json +4 -5
- package/types.d.ts +85 -30
- package/Aks/VmSetAutoScale/index.d.ts +0 -14
- package/Aks/VmSetAutoScale/index.js +0 -155
- package/Aks/VmSetMonitor/index.d.ts +0 -10
- package/Aks/VmSetMonitor/index.js +0 -90
- package/Apim/Helpers.d.ts +0 -2
- package/Apim/Helpers.js +0 -18
- package/AzAd/Identities/GlobalUserAssignedIdentity.d.ts +0 -4
- package/AzAd/Identities/GlobalUserAssignedIdentity.js +0 -19
- package/Common/Naming/index.d.ts +0 -67
- package/Common/Naming/index.js +0 -161
- package/Core/Helper.d.ts +0 -18
- package/Core/Helper.js +0 -42
- package/VNet/index.d.ts +0 -65
- package/VNet/index.js +0 -220
- package/Web/Helpers.d.ts +0 -6
- package/Web/Helpers.js +0 -59
package/types.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Input, Output, Resource } from '@pulumi/pulumi';
|
|
1
|
+
import { CustomResourceOptions, Input, Output, Resource } from '@pulumi/pulumi';
|
|
2
2
|
import { EnvRoleKeyTypes } from './AzAd/EnvRoles';
|
|
3
3
|
import { IEnvRoleBuilder } from './Builder';
|
|
4
4
|
export declare namespace NodeJS {
|
|
@@ -18,8 +18,13 @@ export type ResourceGroupInfo = {
|
|
|
18
18
|
resourceGroupName: string;
|
|
19
19
|
location?: Input<string>;
|
|
20
20
|
};
|
|
21
|
-
export type
|
|
21
|
+
export type ResourceGroupWithIdInfo = ResourceGroupInfo & {
|
|
22
|
+
id: Input<string>;
|
|
23
|
+
};
|
|
24
|
+
export type WithDependsOn = {
|
|
22
25
|
dependsOn?: Input<Input<Resource>[]> | Input<Resource>;
|
|
26
|
+
};
|
|
27
|
+
export type OptsArgs = WithDependsOn & {
|
|
23
28
|
importUri?: string;
|
|
24
29
|
ignoreChanges?: string[];
|
|
25
30
|
};
|
|
@@ -27,42 +32,96 @@ export type LoginArgs = {
|
|
|
27
32
|
adminLogin: Input<string>;
|
|
28
33
|
password: Input<string>;
|
|
29
34
|
};
|
|
30
|
-
export type
|
|
35
|
+
export type WithNamedType = {
|
|
36
|
+
name: string;
|
|
37
|
+
};
|
|
38
|
+
export type WithOutputId = {
|
|
39
|
+
id: Output<string>;
|
|
40
|
+
};
|
|
41
|
+
export type WithSubId = {
|
|
42
|
+
subscriptionId?: string;
|
|
43
|
+
};
|
|
44
|
+
export type WithPrincipalId = {
|
|
45
|
+
principalId: Input<string>;
|
|
46
|
+
};
|
|
47
|
+
export type WithEnvRoles = {
|
|
31
48
|
envRoles?: IEnvRoleBuilder;
|
|
49
|
+
envUIDInfo?: IdentityInfo;
|
|
32
50
|
};
|
|
33
|
-
export type
|
|
34
|
-
|
|
51
|
+
export type WithEncryption = {
|
|
52
|
+
enableEncryption?: boolean;
|
|
53
|
+
};
|
|
54
|
+
export type WithDiskEncryption = {
|
|
55
|
+
diskEncryptionSetId?: Input<string>;
|
|
35
56
|
};
|
|
36
|
-
export type
|
|
57
|
+
export type WithVaultInfo = {
|
|
37
58
|
vaultInfo?: KeyVaultInfo;
|
|
38
59
|
};
|
|
39
|
-
export type
|
|
40
|
-
export type NamedWithVaultBasicArgs = NamedWithVaultType & OptsArgs;
|
|
41
|
-
export type ResourceArgs = NamedType & {
|
|
60
|
+
export type WithResourceGroupInfo = {
|
|
42
61
|
group: ResourceGroupInfo;
|
|
43
62
|
};
|
|
44
|
-
export type
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
63
|
+
export type WithLogInfo = {
|
|
64
|
+
logInfo?: LogInfo;
|
|
65
|
+
};
|
|
66
|
+
export type WithEncryptionInfo = WithEnvRoles & WithVaultInfo & WithEncryption;
|
|
67
|
+
export type WithPulumiOpts = {
|
|
68
|
+
opts?: CustomResourceOptions;
|
|
48
69
|
};
|
|
70
|
+
export type LoginWithEnvRolesArgs = LoginArgs & WithEnvRoles;
|
|
71
|
+
export type NamedWithVaultType = WithNamedType & WithVaultInfo;
|
|
72
|
+
export type NamedBasicArgs = WithNamedType & OptsArgs;
|
|
73
|
+
export type NamedWithVaultBasicArgs = NamedWithVaultType & OptsArgs;
|
|
74
|
+
export type ResourceArgs = WithNamedType & WithResourceGroupInfo;
|
|
75
|
+
export type ResourceWithVaultArgs = ResourceArgs & NamedWithVaultType;
|
|
76
|
+
export type EncryptResourceArgs = ResourceWithVaultArgs & WithEncryptionInfo;
|
|
49
77
|
export type BasicResourceArgs = ResourceArgs & OptsArgs;
|
|
50
78
|
export type BasicResourceWithVaultArgs = NamedWithVaultType & BasicResourceArgs;
|
|
51
79
|
export type BasicEncryptResourceArgs = EncryptResourceArgs & OptsArgs;
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
};
|
|
80
|
+
/** Basic vs Info is Basic doesn't require of group info*/
|
|
81
|
+
export type BasicResourceInfo = WithNamedType & WithOutputId;
|
|
55
82
|
export type ResourceInfo = BasicResourceInfo & ResourceArgs;
|
|
83
|
+
/** Resource Info with Subscription ID */
|
|
84
|
+
export type ResourceInfoWithSub = ResourceInfo & WithSubId;
|
|
56
85
|
export type KeyVaultInfo = ResourceInfo;
|
|
57
|
-
export type IdentityInfo =
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
86
|
+
export type IdentityInfo = WithOutputId & WithPrincipalId;
|
|
87
|
+
export type StorageConnectionInfo = {
|
|
88
|
+
primaryConnection?: Output<string>;
|
|
89
|
+
secondaryConnection?: Output<string>;
|
|
90
|
+
primaryKey?: Output<string>;
|
|
91
|
+
secondaryKey?: Output<string>;
|
|
92
|
+
};
|
|
93
|
+
export type StorageInfo = ResourceInfo & StorageConnectionInfo & {
|
|
94
|
+
endpoints: {
|
|
95
|
+
blob: string;
|
|
96
|
+
file: string;
|
|
97
|
+
table: string;
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
export type AppInsightSecretsInfo = {
|
|
101
|
+
instrumentationKey?: Output<string>;
|
|
102
|
+
};
|
|
103
|
+
export type AppInsightInfo = ResourceInfo & AppInsightSecretsInfo;
|
|
104
|
+
export type LogWorkspaceSecretsInfo = {
|
|
105
|
+
primarySharedKey?: Output<string>;
|
|
106
|
+
secondarySharedKey?: Output<string>;
|
|
107
|
+
workspaceId?: Output<string>;
|
|
108
|
+
};
|
|
109
|
+
export type LogWorkspaceInfo = ResourceInfo & LogWorkspaceSecretsInfo;
|
|
110
|
+
export type LogInfo = {
|
|
111
|
+
logWp: LogWorkspaceInfo;
|
|
112
|
+
logStorage: StorageInfo;
|
|
113
|
+
appInsight: AppInsightInfo;
|
|
114
|
+
};
|
|
115
|
+
export interface IdentityInfoWithInstance<InstanceType> extends IdentityInfo, WithInstance<InstanceType> {
|
|
62
116
|
}
|
|
63
|
-
export interface
|
|
117
|
+
export interface WithInstance<InstanceType> {
|
|
64
118
|
instance: InstanceType;
|
|
65
119
|
}
|
|
120
|
+
/** Basic vs Info is Basic doesn't required of group info*/
|
|
121
|
+
export interface BasicResourceInfoWithInstance<InstanceType> extends WithInstance<InstanceType>, BasicResourceInfo {
|
|
122
|
+
}
|
|
123
|
+
export interface ResourceInfoWithInstance<InstanceType> extends WithInstance<InstanceType>, ResourceInfo {
|
|
124
|
+
}
|
|
66
125
|
export type PrivateLinkPropsType = {
|
|
67
126
|
/** The Subnet that private links will be created.*/
|
|
68
127
|
subnetIds: Input<string>[];
|
|
@@ -75,8 +134,7 @@ export type NetworkPropsType = {
|
|
|
75
134
|
ipAddresses?: Input<string>[];
|
|
76
135
|
privateLink?: PrivateLinkPropsType;
|
|
77
136
|
};
|
|
78
|
-
export type IdentityRoleAssignment = {
|
|
79
|
-
vaultInfo?: KeyVaultInfo;
|
|
137
|
+
export type IdentityRoleAssignment = WithVaultInfo & {
|
|
80
138
|
role?: EnvRoleKeyTypes;
|
|
81
139
|
};
|
|
82
140
|
export type ConventionProps = {
|
|
@@ -87,12 +145,9 @@ export type ConventionProps = {
|
|
|
87
145
|
/**Whether include the organization name at the end of the name or not*/
|
|
88
146
|
includeOrgName?: boolean;
|
|
89
147
|
};
|
|
90
|
-
export type
|
|
91
|
-
|
|
92
|
-
logStorageId?: Input<string>;
|
|
93
|
-
};
|
|
94
|
-
export interface DiagnosticProps extends NamedType, BasicMonitorArgs {
|
|
148
|
+
export type DiagnosticProps = WithNamedType & WithDependsOn & {
|
|
149
|
+
logInfo: Partial<Omit<LogInfo, 'appInsight'>>;
|
|
95
150
|
targetResourceId: Input<string>;
|
|
96
151
|
metricsCategories?: string[];
|
|
97
152
|
logsCategories?: string[];
|
|
98
|
-
}
|
|
153
|
+
};
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AzureResourceItem } from '../../Core/Helper';
|
|
2
|
-
import { BasicMonitorArgs, ResourceGroupInfo } from '../../types';
|
|
3
|
-
interface Props extends BasicMonitorArgs {
|
|
4
|
-
group: ResourceGroupInfo;
|
|
5
|
-
getCapacity?: typeof defaultGetCapacity;
|
|
6
|
-
}
|
|
7
|
-
declare const defaultGetCapacity: (vmScaleSet: AzureResourceItem) => {
|
|
8
|
-
nightCapacity?: 0 | 1 | number;
|
|
9
|
-
default: number;
|
|
10
|
-
minimum: number;
|
|
11
|
-
maximum: number;
|
|
12
|
-
};
|
|
13
|
-
declare const _default: ({ group, getCapacity, dependsOn, }: Props) => Promise<import("@pulumi/azure-native/insights/autoscaleSetting").AutoscaleSetting[] | undefined>;
|
|
14
|
-
export default _default;
|
|
@@ -1,155 +0,0 @@
|
|
|
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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
const insights = __importStar(require("@pulumi/azure-native/insights"));
|
|
27
|
-
const Helper_1 = require("../../Core/Helper");
|
|
28
|
-
const defaultGetCapacity = (vmScaleSet) => {
|
|
29
|
-
const mode = vmScaleSet.tags ? vmScaleSet.tags['mode'] : 'System';
|
|
30
|
-
if (mode === 'System')
|
|
31
|
-
return { nightCapacity: 1, default: 1, minimum: 1, maximum: 3 };
|
|
32
|
-
return { nightCapacity: 0, default: 0, minimum: 1, maximum: 3 };
|
|
33
|
-
};
|
|
34
|
-
exports.default = async ({ group, getCapacity = defaultGetCapacity, dependsOn, }) => {
|
|
35
|
-
const vmScaleSets = await (0, Helper_1.findVMScaleSet)(group.resourceGroupName);
|
|
36
|
-
if (!vmScaleSets)
|
|
37
|
-
return;
|
|
38
|
-
return vmScaleSets.map((vm) => {
|
|
39
|
-
const cap = getCapacity(vm);
|
|
40
|
-
const profiles = new Array();
|
|
41
|
-
const timeZone = vm.location === 'southeastasia'
|
|
42
|
-
? 'Singapore Standard Time'
|
|
43
|
-
: 'Singapore Standard Time';
|
|
44
|
-
if (cap.nightCapacity) {
|
|
45
|
-
profiles.push({
|
|
46
|
-
name: 'Scale down at night',
|
|
47
|
-
capacity: {
|
|
48
|
-
default: cap.nightCapacity.toString(),
|
|
49
|
-
minimum: cap.nightCapacity.toString(),
|
|
50
|
-
maximum: cap.nightCapacity > 0 ? cap.nightCapacity.toString() : '1',
|
|
51
|
-
},
|
|
52
|
-
rules: [],
|
|
53
|
-
recurrence: {
|
|
54
|
-
frequency: 'Week',
|
|
55
|
-
schedule: {
|
|
56
|
-
timeZone,
|
|
57
|
-
days: [
|
|
58
|
-
'Monday',
|
|
59
|
-
'Tuesday',
|
|
60
|
-
'Wednesday',
|
|
61
|
-
'Thursday',
|
|
62
|
-
'Friday',
|
|
63
|
-
'Saturday',
|
|
64
|
-
'Sunday',
|
|
65
|
-
],
|
|
66
|
-
hours: [19],
|
|
67
|
-
minutes: [0],
|
|
68
|
-
},
|
|
69
|
-
},
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
profiles.push({
|
|
73
|
-
name: 'auto scale by CPU',
|
|
74
|
-
capacity: {
|
|
75
|
-
default: cap.default.toString(),
|
|
76
|
-
minimum: cap.minimum.toString(),
|
|
77
|
-
maximum: cap.maximum.toString(),
|
|
78
|
-
},
|
|
79
|
-
rules: [
|
|
80
|
-
{
|
|
81
|
-
//Scale Up
|
|
82
|
-
metricTrigger: {
|
|
83
|
-
metricName: 'Percentage CPU',
|
|
84
|
-
metricNamespace: 'microsoft.compute/virtualmachinescalesets',
|
|
85
|
-
metricResourceUri: vm.id,
|
|
86
|
-
timeGrain: 'PT1M',
|
|
87
|
-
statistic: 'Average',
|
|
88
|
-
timeWindow: 'PT15M',
|
|
89
|
-
timeAggregation: 'Average',
|
|
90
|
-
operator: 'GreaterThanOrEqual',
|
|
91
|
-
threshold: 75,
|
|
92
|
-
dimensions: [],
|
|
93
|
-
dividePerInstance: false,
|
|
94
|
-
},
|
|
95
|
-
scaleAction: {
|
|
96
|
-
direction: 'Increase',
|
|
97
|
-
type: 'ChangeCount',
|
|
98
|
-
value: '1',
|
|
99
|
-
cooldown: 'PT30M',
|
|
100
|
-
},
|
|
101
|
-
},
|
|
102
|
-
{
|
|
103
|
-
//Scale down
|
|
104
|
-
metricTrigger: {
|
|
105
|
-
metricName: 'Percentage CPU',
|
|
106
|
-
metricNamespace: 'microsoft.compute/virtualmachinescalesets',
|
|
107
|
-
metricResourceUri: vm.id,
|
|
108
|
-
timeGrain: 'PT1M',
|
|
109
|
-
statistic: 'Average',
|
|
110
|
-
timeWindow: 'PT15M',
|
|
111
|
-
timeAggregation: 'Average',
|
|
112
|
-
operator: 'LessThanOrEqual',
|
|
113
|
-
threshold: 50,
|
|
114
|
-
dimensions: [],
|
|
115
|
-
dividePerInstance: false,
|
|
116
|
-
},
|
|
117
|
-
scaleAction: {
|
|
118
|
-
direction: 'Decrease',
|
|
119
|
-
type: 'ChangeCount',
|
|
120
|
-
value: '1',
|
|
121
|
-
cooldown: 'PT30M',
|
|
122
|
-
},
|
|
123
|
-
},
|
|
124
|
-
],
|
|
125
|
-
recurrence: {
|
|
126
|
-
frequency: 'Week',
|
|
127
|
-
schedule: {
|
|
128
|
-
timeZone,
|
|
129
|
-
days: [
|
|
130
|
-
'Monday',
|
|
131
|
-
'Tuesday',
|
|
132
|
-
'Wednesday',
|
|
133
|
-
'Thursday',
|
|
134
|
-
'Friday',
|
|
135
|
-
//'Saturday',
|
|
136
|
-
//'Sunday',
|
|
137
|
-
],
|
|
138
|
-
hours: [8],
|
|
139
|
-
minutes: [0],
|
|
140
|
-
},
|
|
141
|
-
},
|
|
142
|
-
});
|
|
143
|
-
//LinuxDiagnostic
|
|
144
|
-
const autoScale = new insights.AutoscaleSetting(`${vm.name}-AutoScale`, {
|
|
145
|
-
name: `${vm.name}-AutoScale`,
|
|
146
|
-
autoscaleSettingName: `${vm.name}-AutoScale`,
|
|
147
|
-
resourceGroupName: vm.resourceGroupName,
|
|
148
|
-
targetResourceUri: vm.id,
|
|
149
|
-
enabled: true,
|
|
150
|
-
profiles,
|
|
151
|
-
}, { dependsOn });
|
|
152
|
-
return autoScale;
|
|
153
|
-
});
|
|
154
|
-
};
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQWtzL1ZtU2V0QXV0b1NjYWxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx3RUFBMEQ7QUFFMUQsOENBQXNFO0FBU3RFLE1BQU0sa0JBQWtCLEdBQUcsQ0FDekIsVUFBNkIsRUFNN0IsRUFBRTtJQUNGLE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQztJQUNsRSxJQUFJLElBQUksS0FBSyxRQUFRO1FBQ25CLE9BQU8sRUFBRSxhQUFhLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7SUFDbEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQztBQUNsRSxDQUFDLENBQUM7QUFFRixrQkFBZSxLQUFLLEVBQUUsRUFDcEIsS0FBSyxFQUNMLFdBQVcsR0FBRyxrQkFBa0IsRUFDaEMsU0FBUyxHQUNILEVBQUUsRUFBRTtJQUNWLE1BQU0sV0FBVyxHQUFHLE1BQU0sSUFBQSx1QkFBYyxFQUFDLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ2xFLElBQUksQ0FBQyxXQUFXO1FBQUUsT0FBTztJQUV6QixPQUFPLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRTtRQUM1QixNQUFNLEdBQUcsR0FBRyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDNUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxLQUFLLEVBQXdDLENBQUM7UUFDbkUsTUFBTSxR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
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { BasicMonitorArgs, KeyVaultInfo, ResourceGroupInfo } from '../../types';
|
|
2
|
-
interface Props extends BasicMonitorArgs {
|
|
3
|
-
group: ResourceGroupInfo;
|
|
4
|
-
vaultInfo: KeyVaultInfo;
|
|
5
|
-
}
|
|
6
|
-
declare const _default: ({ group, logWpId, logStorageId, vaultInfo, dependsOn, }: Props) => import("@pulumi/pulumi").Output<{
|
|
7
|
-
diag: import("@pulumi/azure-native/compute/virtualMachineScaleSetExtension").VirtualMachineScaleSetExtension;
|
|
8
|
-
oms: import("@pulumi/azure-native/compute/virtualMachineScaleSetExtension").VirtualMachineScaleSetExtension;
|
|
9
|
-
}[] | undefined>;
|
|
10
|
-
export default _default;
|
|
@@ -1,90 +0,0 @@
|
|
|
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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
const native = __importStar(require("@pulumi/azure-native"));
|
|
27
|
-
const Helper_1 = require("../../Core/Helper");
|
|
28
|
-
const fs = __importStar(require("fs"));
|
|
29
|
-
const pulumi_1 = require("@pulumi/pulumi");
|
|
30
|
-
const Common_1 = require("../../Common");
|
|
31
|
-
const Helpers_1 = require("../../Logs/Helpers");
|
|
32
|
-
const Helper_2 = require("../../Storage/Helper");
|
|
33
|
-
exports.default = ({ group, logWpId, logStorageId, vaultInfo, dependsOn, }) => (0, pulumi_1.all)([logWpId, logStorageId]).apply(async ([lId, sId]) => {
|
|
34
|
-
const vmScaleSets = await (0, Helper_1.findVMScaleSet)(group.resourceGroupName);
|
|
35
|
-
if (!vmScaleSets)
|
|
36
|
-
return;
|
|
37
|
-
const logWp = lId
|
|
38
|
-
? await (0, Helpers_1.getLogWpSecretsById)({ logWpId: lId, vaultInfo })
|
|
39
|
-
: undefined;
|
|
40
|
-
const logStorage = sId
|
|
41
|
-
? await (0, Helper_2.getStorageSecretsById)({
|
|
42
|
-
storageId: sId,
|
|
43
|
-
vaultInfo,
|
|
44
|
-
//globalResource: true,
|
|
45
|
-
})
|
|
46
|
-
: undefined;
|
|
47
|
-
if (!logWp || !logStorage)
|
|
48
|
-
return;
|
|
49
|
-
const logSAS = await (0, Helper_2.getAccountSAS)(logStorage.info);
|
|
50
|
-
const originalSetting = fs.readFileSync(__dirname + '/config.json', 'utf8');
|
|
51
|
-
return vmScaleSets.map((vm) => {
|
|
52
|
-
let settings = originalSetting;
|
|
53
|
-
settings = (0, Common_1.replaceAll)(settings, '__DIAGNOSTIC_STORAGE_ACCOUNT__', logStorage.info.name);
|
|
54
|
-
settings = (0, Common_1.replaceAll)(settings, '__VM_OR_VMSS_RESOURCE_ID__', vm.id);
|
|
55
|
-
//LinuxDiagnostic
|
|
56
|
-
const diag = new native.compute.VirtualMachineScaleSetExtension(`${vm.name}-LinuxDiagnostic`, {
|
|
57
|
-
resourceGroupName: vm.resourceGroupName,
|
|
58
|
-
vmScaleSetName: vm.name,
|
|
59
|
-
name: `LinuxDiagnostic`,
|
|
60
|
-
type: 'LinuxDiagnostic',
|
|
61
|
-
typeHandlerVersion: '3.0',
|
|
62
|
-
publisher: 'Microsoft.Azure.Diagnostics',
|
|
63
|
-
autoUpgradeMinorVersion: true,
|
|
64
|
-
protectedSettings: `{
|
|
65
|
-
"storageAccountName": "${logStorage.info.name}",
|
|
66
|
-
"storageAccountSasToken": "${logSAS.accountSasToken.substring(logSAS.accountSasToken.indexOf('?') + 1)}"
|
|
67
|
-
}`,
|
|
68
|
-
settings,
|
|
69
|
-
},
|
|
70
|
-
//Ignore changes on this field as API never returns it back
|
|
71
|
-
{ ignoreChanges: ['protectedSettings'], dependsOn });
|
|
72
|
-
const oms = new native.compute.VirtualMachineScaleSetExtension(`${vm.name}-OmsAgentForLinux`, {
|
|
73
|
-
name: `OmsAgentForLinux`,
|
|
74
|
-
resourceGroupName: vm.resourceGroupName,
|
|
75
|
-
vmScaleSetName: vm.name,
|
|
76
|
-
type: 'OmsAgentForLinux',
|
|
77
|
-
typeHandlerVersion: '1.0',
|
|
78
|
-
publisher: 'Microsoft.EnterpriseCloud.Monitoring',
|
|
79
|
-
autoUpgradeMinorVersion: true,
|
|
80
|
-
//enableAutomaticUpgrade: true,
|
|
81
|
-
//DefaultWorkspace-63a31b41-eb5d-4160-9fc9-d30fc00286c9-SEA
|
|
82
|
-
protectedSettings: `{"workspaceKey":"${logWp.secrets.primaryKey}"}`,
|
|
83
|
-
settings: `{"workspaceId": "${logWp.info.id}"}`,
|
|
84
|
-
},
|
|
85
|
-
//Ignore changes on this field as API never returns it back
|
|
86
|
-
{ ignoreChanges: ['protectedSettings'], dependsOn });
|
|
87
|
-
return { diag, oms };
|
|
88
|
-
});
|
|
89
|
-
});
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQWtzL1ZtU2V0TW9uaXRvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsNkRBQStDO0FBQy9DLDhDQUFtRDtBQUNuRCx1Q0FBeUI7QUFFekIsMkNBQXNEO0FBQ3RELHlDQUEwQztBQUMxQyxnREFBeUQ7QUFDekQsaURBQTRFO0FBTzVFLGtCQUFlLENBQUMsRUFDZCxLQUFLLEVBQ0wsT0FBTyxFQUNQLFlBQVksRUFDWixTQUFTLEVBQ1QsU0FBUyxHQUNILEVBQUUsRUFBRSxDQUNWLElBQUEsWUFBRyxFQUFDLENBQUMsT0FBTyxFQUFFLFlBQVksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsRUFBRSxFQUFFO0lBQ3RELE1BQU0sV0FBVyxHQUFHLE1BQU0sSUFBQSx1QkFBYyxFQUFDLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ2xFLElBQUksQ0FBQyxXQUFXO1FBQUUsT0FBTztJQUV6QixNQUFNLEtBQUssR0FBRyxHQUFHO1FBQ2YsQ0FBQyxDQUFDLE1BQU0sSUFBQSw2QkFBbUIsRUFBQyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFLENBQUM7UUFDeEQsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUNkLE1BQU0sVUFBVSxHQUFHLEdBQUc7UUFDcEIsQ0FBQyxDQUFDLE1BQU0sSUFBQSw4QkFBcUIsRUFBQztZQUMxQixTQUFTLEVBQUUsR0FBRztZQUNkLFNBQVM7WUFDVCx1QkFBdUI7U0FDeEIsQ0FBQztRQUNKLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFFZCxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsVUFBVTtRQUFFLE9BQU87SUFFbEMsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFBLHNCQUFhLEVBQUMsVUFBVSxDQUFDLElBQUssQ0FBQyxDQUFDO0lBRXJELE1BQU0sZUFBZSxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUMsU0FBUyxHQUFHLGNBQWMsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUU1RSxPQUFPLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRTtRQUM1QixJQUFJLFFBQVEsR0FBRyxlQUFlLENBQUM7UUFDL0IsUUFBUSxHQUFHLElBQUEsbUJBQVUsRUFDbkIsUUFBUSxFQUNSLGdDQUFnQyxFQUNoQyxVQUFVLENBQUMsSUFBSyxDQUFDLElBQUksQ0FDdEIsQ0FBQztRQUNGLFFBQVEsR0FBRyxJQUFBLG1CQUFVLEVBQUMsUUFBUSxFQUFFLDRCQUE0QixFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUVyRSxpQkFBaUI7UUFDakIsTUFBTSxJQUFJLEdBQUcsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLCtCQUErQixDQUM3RCxHQUFHLEVBQUUsQ0FBQyxJQUFJLGtCQUFrQixFQUM1QjtZQUNFLGlCQUFpQixFQUFFLEVBQUUsQ0FBQyxpQkFBaUI7WUFDdkMsY0FBYyxFQUFFLEVBQUUsQ0FBQyxJQUFJO1lBQ3ZCLElBQUksRUFBRSxpQkFBaUI7WUFDdkIsSUFBSSxFQUFFLGlCQUFpQjtZQUN2QixrQkFBa0IsRUFBRSxLQUFLO1lBQ3pCLFNBQVMsRUFBRSw2QkFBNkI7WUFFeEMsdUJBQXVCLEVBQUUsSUFBSTtZQUU3QixpQkFBaUIsRUFBRTttQ0FDTSxVQUFVLENBQUMsSUFBSyxDQUFDLElBQUk7dUNBQ2pCLE1BQU0sQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUMzRCxNQUFNLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQ3hDO1VBQ0Q7WUFDQSxRQUFRO1NBQ1Q7UUFDRCwyREFBMkQ7UUFDM0QsRUFBRSxhQUFhLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLFNBQVMsRUFBRSxDQUNwRCxDQUFDO1FBRUYsTUFBTSxHQUFHLEdBQUcsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLCtCQUErQixDQUM1RCxHQUFHLEVBQUUsQ0FBQyxJQUFJLG1CQUFtQixFQUM3QjtZQUNFLElBQUksRUFBRSxrQkFBa0I7WUFDeEIsaUJBQWlCLEVBQUUsRUFBRSxDQUFDLGlCQUFpQjtZQUN2QyxjQUFjLEVBQUUsRUFBRSxDQUFDLElBQUk7WUFFdkIsSUFBSSxFQUFFLGtCQUFrQjtZQUN4QixrQkFBa0IsRUFBRSxLQUFLO1lBQ3pCLFNBQVMsRUFBRSxzQ0FBc0M7WUFFakQsdUJBQXVCLEVBQUUsSUFBSTtZQUM3QiwrQkFBK0I7WUFFL0IsMkRBQTJEO1lBQzNELGlCQUFpQixFQUFFLG9CQUFvQixLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVcsSUFBSTtZQUNwRSxRQUFRLEVBQUUsb0JBQW9CLEtBQUssQ0FBQyxJQUFLLENBQUMsRUFBRSxJQUFJO1NBQ2pEO1FBQ0QsMkRBQTJEO1FBQzNELEVBQUUsYUFBYSxFQUFFLENBQUMsbUJBQW1CLENBQUMsRUFBRSxTQUFTLEVBQUUsQ0FDcEQsQ0FBQztRQUVGLE9BQU8sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUM7SUFDdkIsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyJ9
|
package/Apim/Helpers.d.ts
DELETED
package/Apim/Helpers.js
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getApimInfo = void 0;
|
|
4
|
-
const Naming_1 = require("../Common/Naming");
|
|
5
|
-
const pulumi_1 = require("@pulumi/pulumi");
|
|
6
|
-
const AzureEnv_1 = require("../Common/AzureEnv");
|
|
7
|
-
const getApimInfo = (nameAndGroup) => {
|
|
8
|
-
const name = (0, Naming_1.getApimName)(nameAndGroup);
|
|
9
|
-
const rgName = (0, Naming_1.getResourceGroupName)(nameAndGroup);
|
|
10
|
-
const id = (0, pulumi_1.interpolate) `/subscriptions/${AzureEnv_1.subscriptionId}/resourceGroups/${rgName}/providers/Microsoft.ApiManagement/service/${name}`;
|
|
11
|
-
return {
|
|
12
|
-
name,
|
|
13
|
-
group: { resourceGroupName: rgName, location: AzureEnv_1.currentRegionName },
|
|
14
|
-
id,
|
|
15
|
-
};
|
|
16
|
-
};
|
|
17
|
-
exports.getApimInfo = getApimInfo;
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9BcGltL0hlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsNkNBQXFFO0FBQ3JFLDJDQUE2QztBQUM3QyxpREFBdUU7QUFFaEUsTUFBTSxXQUFXLEdBQUcsQ0FBQyxZQUFvQixFQUFnQixFQUFFO0lBQ2hFLE1BQU0sSUFBSSxHQUFHLElBQUEsb0JBQVcsRUFBQyxZQUFZLENBQUMsQ0FBQztJQUN2QyxNQUFNLE1BQU0sR0FBRyxJQUFBLDZCQUFvQixFQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2xELE1BQU0sRUFBRSxHQUFHLElBQUEsb0JBQVcsRUFBQSxrQkFBa0IseUJBQWMsbUJBQW1CLE1BQU0sOENBQThDLElBQUksRUFBRSxDQUFDO0lBRXBJLE9BQU87UUFDTCxJQUFJO1FBQ0osS0FBSyxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSw0QkFBaUIsRUFBRTtRQUNqRSxFQUFFO0tBQ0gsQ0FBQztBQUNKLENBQUMsQ0FBQztBQVZXLFFBQUEsV0FBVyxlQVV0QiJ9
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { KeyVaultInfo } from '../../types';
|
|
2
|
-
import { UserAssignedIdentityProps } from '../UserAssignedIdentity';
|
|
3
|
-
export declare const create: (props: Omit<UserAssignedIdentityProps, "name" | "role">) => import("@pulumi/azure-native/managedidentity/userAssignedIdentity").UserAssignedIdentity;
|
|
4
|
-
export declare const get: (vaultInfo: KeyVaultInfo) => import("@pulumi/pulumi").Output<import("@pulumi/pulumi").UnwrappedObject<import("../../types").IdentityInfo>>;
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.get = exports.create = void 0;
|
|
7
|
-
const Helper_1 = require("../Helper");
|
|
8
|
-
const UserAssignedIdentity_1 = __importDefault(require("../UserAssignedIdentity"));
|
|
9
|
-
const create = (props) => {
|
|
10
|
-
return (0, UserAssignedIdentity_1.default)({
|
|
11
|
-
...props,
|
|
12
|
-
name: 'global-user-assigned-identity',
|
|
13
|
-
role: 'readOnly',
|
|
14
|
-
});
|
|
15
|
-
};
|
|
16
|
-
exports.create = create;
|
|
17
|
-
const get = (vaultInfo) => (0, Helper_1.getUserAssignedIdentityInfoOutput)('global-user-assigned-identity', vaultInfo);
|
|
18
|
-
exports.get = get;
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR2xvYmFsVXNlckFzc2lnbmVkSWRlbnRpdHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQXpBZC9JZGVudGl0aWVzL0dsb2JhbFVzZXJBc3NpZ25lZElkZW50aXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLHNDQUE4RDtBQUU5RCxtRkFFaUM7QUFFMUIsTUFBTSxNQUFNLEdBQUcsQ0FDcEIsS0FBdUQsRUFDdkQsRUFBRTtJQUNGLE9BQU8sSUFBQSw4QkFBb0IsRUFBQztRQUMxQixHQUFHLEtBQUs7UUFDUixJQUFJLEVBQUUsK0JBQStCO1FBQ3JDLElBQUksRUFBRSxVQUFVO0tBQ2pCLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQztBQVJXLFFBQUEsTUFBTSxVQVFqQjtBQUVLLE1BQU0sR0FBRyxHQUFHLENBQUMsU0FBdUIsRUFBRSxFQUFFLENBQzdDLElBQUEsMENBQWlDLEVBQUMsK0JBQStCLEVBQUUsU0FBUyxDQUFDLENBQUM7QUFEbkUsUUFBQSxHQUFHLE9BQ2dFIn0=
|
package/Common/Naming/index.d.ts
DELETED
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
import { ConventionProps } from '../../types';
|
|
2
|
-
/** The method to get Resource group Name*/
|
|
3
|
-
export declare const getResourceGroupName: (name: string, convention?: ConventionProps) => string;
|
|
4
|
-
/** Get Azure Storage Account and CosmosDb Name*/
|
|
5
|
-
export declare const getStorageName: (name: string) => string;
|
|
6
|
-
/** Get Vault Secret Name. Remove the stack name and replace all _ with - then lower cases. */
|
|
7
|
-
export declare const getSecretName: (name: string) => string;
|
|
8
|
-
export declare const getAppPlanName: (name: string) => string;
|
|
9
|
-
export declare const getCertName: (name: string) => string;
|
|
10
|
-
export declare const getConnectionName: (name: string, type: "primary" | "secondary") => string;
|
|
11
|
-
export declare const getKeyName: (name: string, type: "primary" | "secondary") => string;
|
|
12
|
-
export declare const getPasswordName: (name: string, type: "primary" | "secondary" | null) => string;
|
|
13
|
-
export declare const getAutomationAccountName: (name: string) => string;
|
|
14
|
-
export declare const getB2cName: (name: string) => string;
|
|
15
|
-
export declare const getCosmosDbName: (name: string) => string;
|
|
16
|
-
export declare const getAppConfigName: (name: string) => string;
|
|
17
|
-
export declare const getApimName: (name: string) => string;
|
|
18
|
-
export declare const getDiskEncryptionName: (name: string) => string;
|
|
19
|
-
export declare const getSshName: (name: string) => string;
|
|
20
|
-
export declare const getIdentityName: (name: string) => string;
|
|
21
|
-
export declare const getManagedIdentityName: (name: string) => string;
|
|
22
|
-
export declare const getAksName: (name: string) => string;
|
|
23
|
-
export declare const getK8sProviderName: (name: string) => string;
|
|
24
|
-
export declare const getAppInsightName: (name: string) => string;
|
|
25
|
-
export declare const getLogWpName: (name: string) => string;
|
|
26
|
-
export declare const getWebAppName: (name: string) => string;
|
|
27
|
-
export declare const getFuncAppName: (name: string) => string;
|
|
28
|
-
export declare const getWebTestName: (name: string) => string;
|
|
29
|
-
export declare const getAlertName: (name: string) => string;
|
|
30
|
-
export declare const getRedisCacheName: (name: string) => string;
|
|
31
|
-
export declare const getServiceBusName: (name: string) => string;
|
|
32
|
-
export declare const getPrivateEndpointName: (name: string) => string;
|
|
33
|
-
export declare const getSignalRName: (name: string) => string;
|
|
34
|
-
export declare const getElasticPoolName: (name: string) => string;
|
|
35
|
-
export declare const getSqlDbName: (name: string) => string;
|
|
36
|
-
export declare const getSqlServerName: (name: string) => string;
|
|
37
|
-
export declare const getPostgresqlName: (name: string) => string;
|
|
38
|
-
export declare const getMySqlName: (name: string) => string;
|
|
39
|
-
export declare const getFirewallName: (name: string) => string;
|
|
40
|
-
export declare const getFirewallPolicyName: (name: string) => string;
|
|
41
|
-
export declare const getFirewallPolicyGroupName: (name: string) => string;
|
|
42
|
-
export declare const getVMName: (name: string) => string;
|
|
43
|
-
export declare const getNICName: (name: string) => string;
|
|
44
|
-
export declare const getVdiName: (name: string) => string;
|
|
45
|
-
export declare const getVpnName: (name: string) => string;
|
|
46
|
-
export declare const getVnetName: (name: string, convention?: ConventionProps) => string;
|
|
47
|
-
export declare const getWanName: (name: string) => string;
|
|
48
|
-
export declare const getHubName: (name: string) => string;
|
|
49
|
-
export declare const getIotHubName: (name: string) => string;
|
|
50
|
-
export declare const getRouteName: (name: string) => string;
|
|
51
|
-
export declare const getRouteItemName: (name: string) => string;
|
|
52
|
-
export declare const getWorkflowName: (name: string) => string;
|
|
53
|
-
export declare const getNetworkSecurityGroupName: (name: string) => string;
|
|
54
|
-
export declare const getIpAddressName: (name: string) => string;
|
|
55
|
-
export declare const getIpAddressPrefixName: (name: string) => string;
|
|
56
|
-
export declare const getAppGatewayName: (name: string) => string;
|
|
57
|
-
export declare const getNatGatewayName: (name: string) => string;
|
|
58
|
-
export declare const getBastionName: (name: string) => string;
|
|
59
|
-
/**Key vault allow to disable or custom the convention. The max length of vault name is 24*/
|
|
60
|
-
export declare const getKeyVaultName: (name: string, convention?: ConventionProps) => string;
|
|
61
|
-
export declare const getCdnEndpointName: (name: string) => string;
|
|
62
|
-
/**The CDN Profile is created to Global group so no prefix*/
|
|
63
|
-
export declare const getCdnProfileName: (name: string) => string;
|
|
64
|
-
/**The Azure Container Registry is created to Global group so no prefix*/
|
|
65
|
-
export declare const getAcrName: (name: string) => string;
|
|
66
|
-
/**The App Cert Order is created to Global group so no prefix*/
|
|
67
|
-
export declare const getCertOrderName: (name: string) => string;
|