@drunk-pulumi/azure 0.0.38 → 0.0.40
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 +2 -2
- package/Aks/Helper.js +2 -2
- package/Aks/index.d.ts +2 -1
- package/Aks/index.js +39 -46
- package/Apim/index.d.ts +4 -4
- package/Apim/index.js +2 -3
- package/AzAd/B2C.d.ts +3 -4
- package/AzAd/B2C.js +11 -15
- package/AzAd/EnvRoles.d.ts +2 -1
- package/AzAd/EnvRoles.js +2 -2
- package/AzAd/Helper.js +9 -5
- package/AzAd/Identities/AzDevOpsManagedIdentity.d.ts +0 -1
- package/AzAd/Identities/AzDevOpsManagedIdentity.js +1 -2
- package/AzAd/RoleDefinitions/JustInTimeRequestRole.js +1 -2
- package/AzAd/UserAssignedIdentity.d.ts +1 -2
- package/AzAd/UserAssignedIdentity.js +2 -8
- package/Builder/AksBuilder.d.ts +2 -2
- package/Builder/AksBuilder.js +6 -7
- package/Builder/ResourceBuilder.d.ts +3 -0
- package/Builder/ResourceBuilder.js +198 -0
- package/Builder/SqlBuilder.d.ts +3 -0
- package/Builder/SqlBuilder.js +81 -0
- package/Builder/VaultBuilder.d.ts +18 -0
- package/Builder/VaultBuilder.js +74 -0
- package/Builder/VmBuilder.d.ts +3 -0
- package/Builder/VmBuilder.js +83 -0
- package/Builder/VnetBuilder.d.ts +2 -2
- package/Builder/VnetBuilder.js +17 -9
- package/Builder/index.d.ts +5 -0
- package/Builder/index.js +25 -2
- package/Builder/types/askBuilder.d.ts +30 -0
- package/Builder/types/askBuilder.js +3 -0
- package/Builder/types/genericBuilder.d.ts +36 -0
- package/Builder/types/genericBuilder.js +18 -0
- package/Builder/types/index.d.ts +6 -0
- package/Builder/types/index.js +23 -0
- package/Builder/types/resourceBuilder.d.ts +46 -0
- package/Builder/types/resourceBuilder.js +3 -0
- package/Builder/types/sqlBuilder.d.ts +20 -0
- package/Builder/types/sqlBuilder.js +3 -0
- package/Builder/types/vaultBuilder.d.ts +16 -0
- package/Builder/types/vaultBuilder.js +3 -0
- package/Builder/types/vmBuilder.d.ts +29 -0
- package/Builder/types/vmBuilder.js +3 -0
- package/Builder/types/vnetBuilder.d.ts +64 -0
- package/Builder/types/vnetBuilder.js +3 -0
- package/Certificate/p12.js +2 -3
- package/Common/GlobalEnv.d.ts +1 -1
- package/Common/Helpers.js +3 -3
- package/ContainerRegistry/index.d.ts +4 -5
- package/ContainerRegistry/index.js +14 -16
- package/Core/Random.d.ts +1 -1
- package/Core/Random.js +6 -2
- package/Core/ResourceCreator.d.ts +7 -4
- package/Core/ResourceCreator.js +5 -5
- package/Core/ResourceGroup.d.ts +10 -8
- package/Core/ResourceGroup.js +2 -2
- package/IOT/Hub/index.d.ts +1 -2
- package/IOT/Hub/index.js +2 -6
- package/KeyVault/CustomHelper.d.ts +5 -5
- package/KeyVault/CustomHelper.js +8 -9
- package/KeyVault/index.d.ts +15 -6
- package/KeyVault/index.js +45 -36
- package/MySql/index.d.ts +1 -2
- package/MySql/index.js +3 -8
- package/Postgresql/index.js +2 -2
- package/ServiceBus/index.d.ts +12 -15
- package/ServiceBus/index.js +20 -32
- package/SignalR/index.d.ts +6 -9
- package/SignalR/index.js +16 -17
- package/Sql/SqlDb.d.ts +5 -6
- package/Sql/SqlDb.js +4 -18
- package/Sql/index.d.ts +37 -38
- package/Sql/index.js +43 -55
- package/VM/index.js +2 -2
- package/VNet/Bastion.js +1 -2
- package/VNet/FirewallPolicies/AksFirewallPolicy.js +6 -21
- package/VNet/FirewallPolicies/CFTunnelFirewallPolicy.d.ts +9 -0
- package/VNet/FirewallPolicies/CFTunnelFirewallPolicy.js +59 -0
- package/VNet/FirewallPolicies/CloudPCFirewallPolicy.js +2 -2
- package/VNet/FirewallPolicies/index.d.ts +4 -4
- package/VNet/FirewallPolicies/index.js +10 -8
- package/VNet/IpAddressPrefix.js +1 -1
- package/VNet/PrivateDns.d.ts +7 -7
- package/VNet/PrivateDns.js +11 -6
- package/VNet/PrivateEndpoint.d.ts +1 -1
- package/VNet/PrivateEndpoint.js +29 -49
- package/VNet/index.d.ts +3 -3
- package/Web/FuncApp.d.ts +5 -6
- package/Web/FuncApp.js +2 -6
- package/Web/WebAppPlan.d.ts +3 -4
- package/Web/WebAppPlan.js +5 -9
- package/package.json +5 -5
- package/types.d.ts +2 -4
- package/Builder/types.d.ts +0 -120
- package/Builder/types.js +0 -18
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import * as native from "@pulumi/azure-native";
|
|
2
|
+
import { SshGenerationProps, SshResults } from "../../Core/KeyGenetators";
|
|
3
|
+
import { IBuilderAsync } from "./genericBuilder";
|
|
4
|
+
import { AksAccessProps, AksNetworkProps, AksNodePoolProps, AksResults, AskAddonProps, AskFeatureProps, DefaultAksNodePoolProps } from "../../Aks";
|
|
5
|
+
export type AskBuilderResults = {
|
|
6
|
+
ssh: SshResults;
|
|
7
|
+
aks: AksResults;
|
|
8
|
+
};
|
|
9
|
+
export type SshBuilderProps = Omit<SshGenerationProps, "vaultInfo" | "name">;
|
|
10
|
+
export type AksImportProps = {
|
|
11
|
+
id: string;
|
|
12
|
+
ignoreChanges?: string[];
|
|
13
|
+
};
|
|
14
|
+
export interface ISshBuilder {
|
|
15
|
+
withNewSsh: (props: SshBuilderProps) => IAksNetworkBuilder;
|
|
16
|
+
}
|
|
17
|
+
export interface IAksNetworkBuilder {
|
|
18
|
+
withNetwork: (props: AksNetworkProps) => IAksDefaultNodePoolBuilder;
|
|
19
|
+
}
|
|
20
|
+
export interface IAksDefaultNodePoolBuilder {
|
|
21
|
+
withDefaultNodePool: (props: DefaultAksNodePoolProps) => IAksBuilder;
|
|
22
|
+
}
|
|
23
|
+
export interface IAksBuilder extends IBuilderAsync<AskBuilderResults> {
|
|
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
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNrQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CdWlsZGVyL3R5cGVzL2Fza0J1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Input, Resource } from "@pulumi/pulumi";
|
|
2
|
+
import { KeyVaultInfo, ResourceGroupInfo } from "../../types";
|
|
3
|
+
import { EnvRolesResults } from "../../AzAd/EnvRoles";
|
|
4
|
+
export type BuilderProps = {
|
|
5
|
+
name: string;
|
|
6
|
+
group: ResourceGroupInfo;
|
|
7
|
+
envRoles: EnvRolesResults;
|
|
8
|
+
vaultInfo: KeyVaultInfo;
|
|
9
|
+
dependsOn?: Input<Input<Resource>[]> | Input<Resource>;
|
|
10
|
+
};
|
|
11
|
+
export type CommonOmit<T> = Omit<T, keyof BuilderProps>;
|
|
12
|
+
export type LoginBuilderProps = {
|
|
13
|
+
adminLogin: Input<string>;
|
|
14
|
+
password: Input<string>;
|
|
15
|
+
};
|
|
16
|
+
export interface ILoginBuilder<IReturnInterface> {
|
|
17
|
+
generateLogin: () => IReturnInterface;
|
|
18
|
+
withLoginInfo: (props: LoginBuilderProps) => IReturnInterface;
|
|
19
|
+
}
|
|
20
|
+
export interface IBuilder<TResults> {
|
|
21
|
+
commonProps: BuilderProps;
|
|
22
|
+
build: () => TResults;
|
|
23
|
+
}
|
|
24
|
+
export declare abstract class Builder<TResults> implements IBuilder<TResults> {
|
|
25
|
+
commonProps: BuilderProps;
|
|
26
|
+
protected constructor(commonProps: BuilderProps);
|
|
27
|
+
abstract build(): TResults;
|
|
28
|
+
}
|
|
29
|
+
export interface IBuilderAsync<TResults> extends Omit<IBuilder<TResults>, "build"> {
|
|
30
|
+
build: () => Promise<TResults>;
|
|
31
|
+
}
|
|
32
|
+
export declare abstract class BuilderAsync<TResults> implements IBuilderAsync<TResults> {
|
|
33
|
+
commonProps: BuilderProps;
|
|
34
|
+
protected constructor(commonProps: BuilderProps);
|
|
35
|
+
abstract build(): Promise<TResults>;
|
|
36
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BuilderAsync = exports.Builder = void 0;
|
|
4
|
+
class Builder {
|
|
5
|
+
commonProps;
|
|
6
|
+
constructor(commonProps) {
|
|
7
|
+
this.commonProps = commonProps;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
exports.Builder = Builder;
|
|
11
|
+
class BuilderAsync {
|
|
12
|
+
commonProps;
|
|
13
|
+
constructor(commonProps) {
|
|
14
|
+
this.commonProps = commonProps;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.BuilderAsync = BuilderAsync;
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpY0J1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQnVpbGRlci90eXBlcy9nZW5lcmljQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUE2QkEsTUFBc0IsT0FBTztJQUNFO0lBQTdCLFlBQTZCLFdBQXlCO1FBQXpCLGdCQUFXLEdBQVgsV0FBVyxDQUFjO0lBQUcsQ0FBQztDQUUzRDtBQUhELDBCQUdDO0FBUUQsTUFBc0IsWUFBWTtJQUdIO0lBQTdCLFlBQTZCLFdBQXlCO1FBQXpCLGdCQUFXLEdBQVgsV0FBVyxDQUFjO0lBQUcsQ0FBQztDQUUzRDtBQUxELG9DQUtDIn0=
|
|
@@ -0,0 +1,23 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./askBuilder"), exports);
|
|
18
|
+
__exportStar(require("./genericBuilder"), exports);
|
|
19
|
+
__exportStar(require("./resourceBuilder"), exports);
|
|
20
|
+
__exportStar(require("./sqlBuilder"), exports);
|
|
21
|
+
__exportStar(require("./vmBuilder"), exports);
|
|
22
|
+
__exportStar(require("./vnetBuilder"), exports);
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQnVpbGRlci90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTZCO0FBQzdCLG1EQUFpQztBQUNqQyxvREFBa0M7QUFDbEMsK0NBQTZCO0FBQzdCLDhDQUE0QjtBQUM1QixnREFBOEIifQ==
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { EnvRolesResults } from "../../AzAd/EnvRoles";
|
|
2
|
+
import { RGPermissionType } from "../../Core/ResourceGroup";
|
|
3
|
+
import { KeyVaultInfo, ResourceGroupInfo } from "../../types";
|
|
4
|
+
import { IBuilder, IBuilderAsync, BuilderProps } from "./genericBuilder";
|
|
5
|
+
import { IVnetBuilder, IVnetBuilderStart, VnetBuilderResults } from "./vnetBuilder";
|
|
6
|
+
import { Input } from "@pulumi/pulumi";
|
|
7
|
+
export type ResourceBuilderResults = BuilderProps & {
|
|
8
|
+
envRoles: EnvRolesResults;
|
|
9
|
+
vnetInstance?: VnetBuilderResults;
|
|
10
|
+
otherInstances: Record<string, any>;
|
|
11
|
+
};
|
|
12
|
+
export type ResourceGroupBuilderType = Omit<RGPermissionType, "envRoles">;
|
|
13
|
+
export type BuilderFunctionType = (props: ResourceBuilderResults) => IBuilder<any>;
|
|
14
|
+
export type BuilderAsyncFunctionType = (props: ResourceBuilderResults) => IBuilderAsync<any>;
|
|
15
|
+
export type ResourceVnetBuilderType = (builder: IVnetBuilderStart) => IVnetBuilder;
|
|
16
|
+
export type ResourceVaultLinkingBuilderType = {
|
|
17
|
+
subnetNames?: string[];
|
|
18
|
+
ipAddresses?: Input<string>[];
|
|
19
|
+
asPrivateLink?: boolean;
|
|
20
|
+
};
|
|
21
|
+
export interface IResourceRoleBuilder {
|
|
22
|
+
createRoles: () => IResourceGroupBuilder;
|
|
23
|
+
withRoles: (props: EnvRolesResults) => IResourceGroupBuilder;
|
|
24
|
+
withRolesFromVault: () => IResourceGroupBuilder;
|
|
25
|
+
}
|
|
26
|
+
export interface IResourceGroupBuilder {
|
|
27
|
+
createRG: (props: ResourceGroupBuilderType) => IResourceVaultBuilder;
|
|
28
|
+
withRG: (props: ResourceGroupInfo) => IResourceVaultBuilder;
|
|
29
|
+
}
|
|
30
|
+
export interface IResourceVaultBuilder {
|
|
31
|
+
createVault: () => IResourceBuilder;
|
|
32
|
+
withVault: (props: KeyVaultInfo) => IResourceBuilder;
|
|
33
|
+
}
|
|
34
|
+
export interface IResourceVaultItemsBuilder {
|
|
35
|
+
addSecrets: (items: Record<string, Input<string>>) => IResourceBuilder;
|
|
36
|
+
}
|
|
37
|
+
export interface IResourceVnetBuilder {
|
|
38
|
+
withVnet: (props: ResourceVnetBuilderType) => IResourceBuilder;
|
|
39
|
+
linkVaultTo: (props: ResourceVaultLinkingBuilderType) => IResourceBuilder;
|
|
40
|
+
}
|
|
41
|
+
export interface IResourceBuilder extends IResourceVnetBuilder, IResourceVaultItemsBuilder {
|
|
42
|
+
lock: () => IResourceBuilder;
|
|
43
|
+
withBuilder: (props: BuilderFunctionType) => IResourceBuilder;
|
|
44
|
+
withBuilderAsync: (props: BuilderAsyncFunctionType) => IResourceBuilder;
|
|
45
|
+
build: () => Promise<ResourceBuilderResults>;
|
|
46
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2VCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0J1aWxkZXIvdHlwZXMvcmVzb3VyY2VCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { IBuilder, ILoginBuilder } from "./genericBuilder";
|
|
2
|
+
import { SqlAuthType, SqlElasticPoolType, SqlNetworkType, SqlResults } from "../../Sql";
|
|
3
|
+
import { SqlDbSku } from "../../Sql/SqlDb";
|
|
4
|
+
export type SqlBuilderAuthOptionsType = Pick<SqlAuthType, "enableAdAdministrator" | "azureAdOnlyAuthentication">;
|
|
5
|
+
export type SqlDbBuilderType = Record<string, {
|
|
6
|
+
name?: string;
|
|
7
|
+
sku?: SqlDbSku;
|
|
8
|
+
}>;
|
|
9
|
+
export interface ISqlLoginBuilder extends ILoginBuilder<ISqlAuthBuilder> {
|
|
10
|
+
}
|
|
11
|
+
export interface ISqlAuthBuilder {
|
|
12
|
+
withAuthOptions: (props: SqlBuilderAuthOptionsType) => ISqlNetworkBuilder;
|
|
13
|
+
}
|
|
14
|
+
export interface ISqlNetworkBuilder {
|
|
15
|
+
withNetwork: (props: SqlNetworkType) => ISqlBuilder;
|
|
16
|
+
}
|
|
17
|
+
export interface ISqlBuilder extends IBuilder<SqlResults> {
|
|
18
|
+
withElasticPool: (props: SqlElasticPoolType) => ISqlBuilder;
|
|
19
|
+
withDatabases: (props: SqlDbBuilderType) => ISqlBuilder;
|
|
20
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3FsQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CdWlsZGVyL3R5cGVzL3NxbEJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BasicMonitorArgs, KeyVaultInfo } from "../../types";
|
|
2
|
+
import { Input } from "@pulumi/pulumi";
|
|
3
|
+
export interface IVaultBuilderResults {
|
|
4
|
+
info: () => KeyVaultInfo;
|
|
5
|
+
addSecrets: (items: Record<string, Input<string>>) => IVaultBuilderResults;
|
|
6
|
+
privateLinkTo: (subnetIds: Input<string>[]) => IVaultBuilderResults;
|
|
7
|
+
linkTo: (props: {
|
|
8
|
+
subnetIds: Input<string>[];
|
|
9
|
+
ipAddresses: Input<string>[];
|
|
10
|
+
}) => IVaultBuilderResults;
|
|
11
|
+
}
|
|
12
|
+
export interface IVaultBuilder {
|
|
13
|
+
name: string;
|
|
14
|
+
withDiagnostic: (logInfo: BasicMonitorArgs) => IVaultBuilder;
|
|
15
|
+
build: () => IVaultBuilderResults;
|
|
16
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmF1bHRCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0J1aWxkZXIvdHlwZXMvdmF1bHRCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { IBuilder, ILoginBuilder } from "./genericBuilder";
|
|
2
|
+
import { Input } from "@pulumi/pulumi";
|
|
3
|
+
import { VirtualMachine } from "@pulumi/azure-native/compute";
|
|
4
|
+
export type VmOsBuilderWindowsProps = {
|
|
5
|
+
offer: "WindowsServer" | "CentOS" | "Windows-10" | "windows-11" | string;
|
|
6
|
+
publisher: "MicrosoftWindowsServer" | "MicrosoftWindowsDesktop" | string;
|
|
7
|
+
sku: "2019-Datacenter" | "21h1-pro" | "win11-23h2-pro" | string;
|
|
8
|
+
};
|
|
9
|
+
export type VmOsBuilderLinuxProps = {
|
|
10
|
+
offer: "CentOS" | "0001-com-ubuntu-server-jammy" | string;
|
|
11
|
+
publisher: "Canonical" | string;
|
|
12
|
+
sku: "22_04-lts" | string;
|
|
13
|
+
};
|
|
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
|
+
export interface IVmOsBuilder {
|
|
16
|
+
withWindowsImage: (props: VmOsBuilderWindowsProps) => IVmSizeBuilder;
|
|
17
|
+
withLinuxImage: (props: VmOsBuilderLinuxProps) => IVmSizeBuilder;
|
|
18
|
+
}
|
|
19
|
+
export interface IVmSizeBuilder {
|
|
20
|
+
withSize: (props: VmSizeTypes) => IVmLoginBuilder;
|
|
21
|
+
}
|
|
22
|
+
export interface IVmLoginBuilder extends ILoginBuilder<IVmVnetBuilder> {
|
|
23
|
+
}
|
|
24
|
+
export interface IVmVnetBuilder {
|
|
25
|
+
withSubnetId: (props: Input<string>) => IVmBuilder;
|
|
26
|
+
}
|
|
27
|
+
export interface IVmBuilder extends IBuilder<VirtualMachine> {
|
|
28
|
+
withTags: (props: Record<string, Input<string>>) => IVmBuilder;
|
|
29
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm1CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL0J1aWxkZXIvdHlwZXMvdm1CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { Input } from "@pulumi/pulumi";
|
|
2
|
+
import * as network from "@pulumi/azure-native/network";
|
|
3
|
+
import { CommonOmit, IBuilder } from "./genericBuilder";
|
|
4
|
+
import { VnetProps, VnetResult } from "../../VNet/Vnet";
|
|
5
|
+
import { SubnetProps } from "../../VNet/Subnet";
|
|
6
|
+
import { BasicResourceArgs } from "../../types";
|
|
7
|
+
import { PeeringDirectionType } from "../../VNet/NetworkPeering";
|
|
8
|
+
import { FirewallProps, FirewallResult } from "../../VNet/Firewall";
|
|
9
|
+
import { VpnGatewayProps } from "../../VNet/VPNGateway";
|
|
10
|
+
import { CustomSecurityRuleArgs, RouteArgs } from "../../VNet/types";
|
|
11
|
+
import { LogInfoResults } from "../../Logs/Helpers";
|
|
12
|
+
import { PublicIpAddressPrefixResult } from "../../VNet/IpAddressPrefix";
|
|
13
|
+
export type VnetBuilderProps = {
|
|
14
|
+
subnets?: SubnetCreationProps;
|
|
15
|
+
} & Pick<VnetProps, "addressSpaces" | "dnsServers">;
|
|
16
|
+
export type SubnetCreationProps = Record<string, Omit<SubnetProps, "name">>;
|
|
17
|
+
export type SubnetPrefixCreationProps = {
|
|
18
|
+
addressPrefix: string;
|
|
19
|
+
};
|
|
20
|
+
export type BastionCreationProps = {
|
|
21
|
+
subnet: SubnetPrefixCreationProps;
|
|
22
|
+
} & Pick<BasicResourceArgs, "importUri" | "ignoreChanges">;
|
|
23
|
+
export type PeeringProps = {
|
|
24
|
+
groupName: string;
|
|
25
|
+
direction?: PeeringDirectionType;
|
|
26
|
+
} | {
|
|
27
|
+
vnetId: Input<string>;
|
|
28
|
+
direction?: PeeringDirectionType;
|
|
29
|
+
};
|
|
30
|
+
export type FirewallCreationProps = {
|
|
31
|
+
subnet: SubnetPrefixCreationProps & {
|
|
32
|
+
managementAddressPrefix: string;
|
|
33
|
+
};
|
|
34
|
+
} & CommonOmit<Omit<FirewallProps, "outbound" | "management">>;
|
|
35
|
+
export type VpnGatewayCreationProps = Pick<VpnGatewayProps, "sku" | "vpnClientAddressPools"> & {
|
|
36
|
+
subnetSpace: string;
|
|
37
|
+
};
|
|
38
|
+
export interface IVnetBuilderStart {
|
|
39
|
+
asHub: (props?: VnetBuilderProps) => IPublicIpBuilder;
|
|
40
|
+
asSpoke: (props?: VnetBuilderProps) => IVnetBuilder;
|
|
41
|
+
}
|
|
42
|
+
export interface IPublicIpBuilder {
|
|
43
|
+
withPublicIpAddress: (type: "prefix" | "individual") => IGatewayFireWallBuilder;
|
|
44
|
+
}
|
|
45
|
+
export interface IFireWallOrVnetBuilder extends IBuilder<VnetBuilderResults> {
|
|
46
|
+
withFirewall: (props: FirewallCreationProps) => IVnetBuilder;
|
|
47
|
+
}
|
|
48
|
+
export interface IGatewayFireWallBuilder extends IFireWallOrVnetBuilder {
|
|
49
|
+
withNatGateway: () => IFireWallOrVnetBuilder;
|
|
50
|
+
}
|
|
51
|
+
export interface IVnetBuilder extends IBuilder<VnetBuilderResults> {
|
|
52
|
+
withBastion: (props: BastionCreationProps) => IVnetBuilder;
|
|
53
|
+
peeringTo: (props: PeeringProps) => IVnetBuilder;
|
|
54
|
+
withSecurityRules: (rules: CustomSecurityRuleArgs[]) => IVnetBuilder;
|
|
55
|
+
withRouteRules: (rules: RouteArgs[]) => IVnetBuilder;
|
|
56
|
+
withLogInfo: (info: LogInfoResults) => IVnetBuilder;
|
|
57
|
+
withVpnGateway: (props: VpnGatewayCreationProps) => IVnetBuilder;
|
|
58
|
+
}
|
|
59
|
+
export type VnetBuilderResults = VnetResult & {
|
|
60
|
+
publicIpAddress: PublicIpAddressPrefixResult | undefined;
|
|
61
|
+
firewall: FirewallResult | undefined;
|
|
62
|
+
natGateway: network.NatGateway | undefined;
|
|
63
|
+
vnpGateway: network.VirtualNetworkGateway | undefined;
|
|
64
|
+
};
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm5ldEJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvQnVpbGRlci90eXBlcy92bmV0QnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIn0=
|
package/Certificate/p12.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
4
4
|
/* eslint-disable @typescript-eslint/no-unsafe-argument */
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.convertToPem =
|
|
6
|
+
exports.convertToPem = convertToPem;
|
|
7
7
|
const forge = require("node-forge");
|
|
8
8
|
function convertToPem(p12base64, password) {
|
|
9
9
|
const p12Asn1 = forge.asn1.fromDer(p12base64);
|
|
@@ -12,7 +12,6 @@ function convertToPem(p12base64, password) {
|
|
|
12
12
|
const cert = getCertificateFromP12(p12);
|
|
13
13
|
return { pemKey, pemCertificate: cert.pemCertificate };
|
|
14
14
|
}
|
|
15
|
-
exports.convertToPem = convertToPem;
|
|
16
15
|
function getKeyFromP12(p12, password) {
|
|
17
16
|
const keyData = p12.getBags({ bagType: forge.pki.oids.pkcs8ShroudedKeyBag }, password);
|
|
18
17
|
let pkcs8Key = keyData[forge.pki.oids.pkcs8ShroudedKeyBag][0];
|
|
@@ -34,4 +33,4 @@ function getCertificateFromP12(p12) {
|
|
|
34
33
|
//const commonName = certificate.cert.subject.attributes[0].value;
|
|
35
34
|
return { pemCertificate };
|
|
36
35
|
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicDEyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0NlcnRpZmljYXRlL3AxMi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsd0RBQXdEO0FBQ3hELHVEQUF1RDtBQUN2RCwyREFBMkQ7O0FBSzNELG9DQVdDO0FBZEQsb0NBQW9DO0FBR3BDLFNBQWdCLFlBQVksQ0FDMUIsU0FBbUMsRUFDbkMsUUFBNEI7SUFFNUIsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDOUMsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztJQUVsRSxNQUFNLE1BQU0sR0FBRyxhQUFhLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzVDLE1BQU0sSUFBSSxHQUFHLHFCQUFxQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXhDLE9BQU8sRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztBQUN6RCxDQUFDO0FBRUQsU0FBUyxhQUFhLENBQUMsR0FBUSxFQUFFLFFBQTRCO0lBQzNELE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxPQUFPLENBQ3pCLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLG1CQUFtQixFQUFFLEVBQy9DLFFBQVEsQ0FDVCxDQUFDO0lBRUYsSUFBSSxRQUFRLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDL0QsSUFBSSxPQUFPLFFBQVEsS0FBSyxXQUFXLEVBQUUsQ0FBQztRQUNwQyxRQUFRLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFRCxJQUFJLE9BQU8sUUFBUSxLQUFLLFdBQVcsRUFBRSxDQUFDO1FBQ3BDLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRUQsSUFBSSxNQUFNLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3JELE1BQU0sR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUVyQyxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQsU0FBUyxxQkFBcUIsQ0FBQyxHQUEyQjtJQUN4RCxNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDbEUsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXpELElBQUksY0FBYyxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLElBQUssQ0FBQyxDQUFDO0lBQ25FLGNBQWMsR0FBRyxjQUFjLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNyRCxrRUFBa0U7SUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxDQUFDO0FBQzVCLENBQUMifQ==
|
package/Common/GlobalEnv.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ export declare const globalConvention: ConventionProps;
|
|
|
5
5
|
export declare const groupInfo: ResourceGroupInfo;
|
|
6
6
|
export declare const cdnProfileInfo: {
|
|
7
7
|
resourceGroupName: string;
|
|
8
|
-
location?: import("@pulumi/pulumi").Input<string
|
|
8
|
+
location?: import("@pulumi/pulumi").Input<string>;
|
|
9
9
|
profileName: string;
|
|
10
10
|
};
|
|
11
11
|
/** Global Key Vault Info */
|
package/Common/Helpers.js
CHANGED
|
@@ -2,14 +2,14 @@
|
|
|
2
2
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
3
3
|
/* eslint-disable @typescript-eslint/no-unsafe-argument */
|
|
4
4
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
-
exports.RangeOf = exports.getRootDomainFromUrl = exports.getDomainFromUrl = exports.shallowEquals = exports.toBase64 =
|
|
5
|
+
exports.RangeOf = exports.getRootDomainFromUrl = exports.getDomainFromUrl = exports.shallowEquals = exports.toBase64 = void 0;
|
|
6
|
+
exports.replaceAll = replaceAll;
|
|
6
7
|
/** Replace all characters in string*/
|
|
7
8
|
function replaceAll(value, search, replace) {
|
|
8
9
|
if (!value)
|
|
9
10
|
return value;
|
|
10
11
|
return value.split(search).join(replace);
|
|
11
12
|
}
|
|
12
|
-
exports.replaceAll = replaceAll;
|
|
13
13
|
const toBase64 = (value) => Buffer.from(value).toString('base64');
|
|
14
14
|
exports.toBase64 = toBase64;
|
|
15
15
|
const shallowEquals = (obj1, obj2) => Object.keys(obj1).length === Object.keys(obj2).length &&
|
|
@@ -27,4 +27,4 @@ exports.getRootDomainFromUrl = getRootDomainFromUrl;
|
|
|
27
27
|
/** Create Range*/
|
|
28
28
|
const RangeOf = (length) => Array.from({ length: length }, (v, k) => k);
|
|
29
29
|
exports.RangeOf = RangeOf;
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9Db21tb24vSGVscGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsd0RBQXdEO0FBQ3hELDJEQUEyRDs7O0FBRzNELGdDQUdDO0FBSkQsc0NBQXNDO0FBQ3RDLFNBQWdCLFVBQVUsQ0FBQyxLQUFhLEVBQUUsTUFBYyxFQUFFLE9BQWU7SUFDdkUsSUFBSSxDQUFDLEtBQUs7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUN6QixPQUFPLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQzNDLENBQUM7QUFFTSxNQUFNLFFBQVEsR0FBRyxDQUFDLEtBQWEsRUFBRSxFQUFFLENBQ3hDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRDNCLFFBQUEsUUFBUSxZQUNtQjtBQUVqQyxNQUFNLGFBQWEsR0FBRyxDQUFDLElBQVMsRUFBRSxJQUFTLEVBQUUsRUFBRSxDQUNwRCxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLE1BQU07SUFDckQsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUYvQyxRQUFBLGFBQWEsaUJBRWtDO0FBRTVELHlCQUF5QjtBQUNsQixNQUFNLGdCQUFnQixHQUFHLENBQUMsR0FBVyxFQUFFLEVBQUUsQ0FDOUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFEdEQsUUFBQSxnQkFBZ0Isb0JBQ3NDO0FBRW5FLDRDQUE0QztBQUNyQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsR0FBVyxFQUFFLEVBQUU7SUFDbEQsTUFBTSxLQUFLLEdBQUcsSUFBQSx3QkFBZ0IsRUFBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDL0MsT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDOUQsQ0FBQyxDQUFDO0FBSFcsUUFBQSxvQkFBb0Isd0JBRy9CO0FBRUYsa0JBQWtCO0FBQ1gsTUFBTSxPQUFPLEdBQUcsQ0FBQyxNQUFjLEVBQUUsRUFBRSxDQUN4QyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFEakMsUUFBQSxPQUFPLFdBQzBCIn0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import * as containerregistry from
|
|
2
|
-
import { DefaultResourceArgs, KeyVaultInfo, NetworkRulesProps, ResourceGroupInfo } from
|
|
1
|
+
import * as containerregistry from "@pulumi/azure-native/containerregistry";
|
|
2
|
+
import { DefaultResourceArgs, KeyVaultInfo, NetworkRulesProps, ResourceGroupInfo } from "../types";
|
|
3
3
|
interface Props extends DefaultResourceArgs {
|
|
4
4
|
name: string;
|
|
5
5
|
group?: ResourceGroupInfo;
|
|
@@ -13,16 +13,15 @@ interface Props extends DefaultResourceArgs {
|
|
|
13
13
|
/** The Azure Container Registry will be created at the GLobal Group.
|
|
14
14
|
* Follow ReadMe file to setup the cleaning tasks for this Registry
|
|
15
15
|
*/
|
|
16
|
-
declare const _default: ({ name, group, sku, adminUserEnabled,
|
|
16
|
+
declare const _default: ({ name, group, sku, adminUserEnabled, vaultInfo, network, ...others }: Props) => {
|
|
17
17
|
name: string;
|
|
18
|
-
registry:
|
|
18
|
+
registry: containerregistry.Registry;
|
|
19
19
|
vaultKeyNames: {
|
|
20
20
|
userNameKey: string;
|
|
21
21
|
primaryPasswordKey: string;
|
|
22
22
|
secondaryPasswordKey: string;
|
|
23
23
|
urlKey: string;
|
|
24
24
|
};
|
|
25
|
-
locker: import("@pulumi/azure-native/authorization/managementLockByScope").ManagementLockByScope | undefined;
|
|
26
25
|
diagnostic: import("@pulumi/azure-native/aadiam/diagnosticSetting").DiagnosticSetting | undefined;
|
|
27
26
|
};
|
|
28
27
|
export default _default;
|
|
@@ -9,19 +9,18 @@ const CustomHelper_1 = require("../KeyVault/CustomHelper");
|
|
|
9
9
|
/** The Azure Container Registry will be created at the GLobal Group.
|
|
10
10
|
* Follow ReadMe file to setup the cleaning tasks for this Registry
|
|
11
11
|
*/
|
|
12
|
-
exports.default = ({ name, group = global.groupInfo, sku = containerregistry.SkuName.Basic, adminUserEnabled = true,
|
|
12
|
+
exports.default = ({ name, group = global.groupInfo, sku = containerregistry.SkuName.Basic, adminUserEnabled = true, vaultInfo, network, ...others }) => {
|
|
13
13
|
name = (0, Naming_1.getAcrName)(name);
|
|
14
14
|
const urlKey = `${name}-url`;
|
|
15
15
|
const userNameKey = `${name}-user-name`;
|
|
16
|
-
const primaryPasswordKey = (0, Naming_1.getPasswordName)(name,
|
|
17
|
-
const secondaryPasswordKey = (0, Naming_1.getPasswordName)(name,
|
|
18
|
-
const { resource, diagnostic
|
|
16
|
+
const primaryPasswordKey = (0, Naming_1.getPasswordName)(name, "primary");
|
|
17
|
+
const secondaryPasswordKey = (0, Naming_1.getPasswordName)(name, "secondary");
|
|
18
|
+
const { resource, diagnostic } = (0, ResourceCreator_1.default)(containerregistry.Registry, {
|
|
19
19
|
registryName: name,
|
|
20
20
|
...group,
|
|
21
21
|
adminUserEnabled,
|
|
22
|
-
lock,
|
|
23
22
|
sku: { name: sku },
|
|
24
|
-
networkRuleSet: sku ===
|
|
23
|
+
networkRuleSet: sku === "Premium" && network
|
|
25
24
|
? {
|
|
26
25
|
defaultAction: containerregistry.DefaultAction.Allow,
|
|
27
26
|
ipRules: network.ipAddresses
|
|
@@ -34,14 +33,14 @@ exports.default = ({ name, group = global.groupInfo, sku = containerregistry.Sku
|
|
|
34
33
|
: undefined,
|
|
35
34
|
...others,
|
|
36
35
|
});
|
|
37
|
-
if (sku ===
|
|
36
|
+
if (sku === "Premium" && network?.privateLink && network?.subnetId) {
|
|
38
37
|
(0, PrivateEndpoint_1.default)({
|
|
39
38
|
name: (0, Naming_1.getPrivateEndpointName)(name),
|
|
40
39
|
group,
|
|
41
|
-
privateDnsZoneName:
|
|
42
|
-
|
|
40
|
+
privateDnsZoneName: "privatelink.azurecr.io",
|
|
41
|
+
subnetIds: [network.subnetId],
|
|
43
42
|
...network.privateLink,
|
|
44
|
-
linkServiceGroupIds: [
|
|
43
|
+
linkServiceGroupIds: ["azurecr"],
|
|
45
44
|
resourceId: resource.id,
|
|
46
45
|
});
|
|
47
46
|
}
|
|
@@ -59,14 +58,14 @@ exports.default = ({ name, group = global.groupInfo, sku = containerregistry.Sku
|
|
|
59
58
|
name: urlKey,
|
|
60
59
|
value: `https://${name}.azurecr.io`,
|
|
61
60
|
vaultInfo,
|
|
62
|
-
contentType:
|
|
61
|
+
contentType: "Container Registry",
|
|
63
62
|
dependsOn: resource,
|
|
64
63
|
});
|
|
65
64
|
(0, CustomHelper_1.addCustomSecret)({
|
|
66
65
|
name: userNameKey,
|
|
67
66
|
value: keys.username,
|
|
68
67
|
vaultInfo,
|
|
69
|
-
contentType:
|
|
68
|
+
contentType: "Container Registry",
|
|
70
69
|
dependsOn: resource,
|
|
71
70
|
});
|
|
72
71
|
(0, CustomHelper_1.addCustomSecret)({
|
|
@@ -74,7 +73,7 @@ exports.default = ({ name, group = global.groupInfo, sku = containerregistry.Sku
|
|
|
74
73
|
formattedName: true,
|
|
75
74
|
value: keys.passwords[0].value,
|
|
76
75
|
vaultInfo,
|
|
77
|
-
contentType:
|
|
76
|
+
contentType: "Container Registry",
|
|
78
77
|
dependsOn: resource,
|
|
79
78
|
});
|
|
80
79
|
(0, CustomHelper_1.addCustomSecret)({
|
|
@@ -82,7 +81,7 @@ exports.default = ({ name, group = global.groupInfo, sku = containerregistry.Sku
|
|
|
82
81
|
formattedName: true,
|
|
83
82
|
value: keys.passwords[1].value,
|
|
84
83
|
vaultInfo,
|
|
85
|
-
contentType:
|
|
84
|
+
contentType: "Container Registry",
|
|
86
85
|
dependsOn: resource,
|
|
87
86
|
});
|
|
88
87
|
});
|
|
@@ -96,8 +95,7 @@ exports.default = ({ name, group = global.groupInfo, sku = containerregistry.Sku
|
|
|
96
95
|
secondaryPasswordKey,
|
|
97
96
|
urlKey,
|
|
98
97
|
},
|
|
99
|
-
locker,
|
|
100
98
|
diagnostic,
|
|
101
99
|
};
|
|
102
100
|
};
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQ29udGFpbmVyUmVnaXN0cnkvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw0RUFBNEU7QUFPNUUsNkRBQThDO0FBQzlDLDhDQUE4QztBQUM5Qyw2Q0FJMEI7QUFDMUIsNkRBQXNEO0FBQ3RELDJEQUEyRDtBQWEzRDs7R0FFRztBQUNILGtCQUFlLENBQUMsRUFDZCxJQUFJLEVBQ0osS0FBSyxHQUFHLE1BQU0sQ0FBQyxTQUFTLEVBQ3hCLEdBQUcsR0FBRyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUNyQyxnQkFBZ0IsR0FBRyxJQUFJLEVBQ3ZCLFNBQVMsRUFDVCxPQUFPLEVBQ1AsR0FBRyxNQUFNLEVBQ0gsRUFBRSxFQUFFO0lBQ1YsSUFBSSxHQUFHLElBQUEsbUJBQVUsRUFBQyxJQUFJLENBQUMsQ0FBQztJQUV4QixNQUFNLE1BQU0sR0FBRyxHQUFHLElBQUksTUFBTSxDQUFDO0lBQzdCLE1BQU0sV0FBVyxHQUFHLEdBQUcsSUFBSSxZQUFZLENBQUM7SUFDeEMsTUFBTSxrQkFBa0IsR0FBRyxJQUFBLHdCQUFlLEVBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQzVELE1BQU0sb0JBQW9CLEdBQUcsSUFBQSx3QkFBZSxFQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztJQUVoRSxNQUFNLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxHQUFHLElBQUEseUJBQU8sRUFBQyxpQkFBaUIsQ0FBQyxRQUFRLEVBQUU7UUFDbkUsWUFBWSxFQUFFLElBQUk7UUFDbEIsR0FBRyxLQUFLO1FBRVIsZ0JBQWdCO1FBQ2hCLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUU7UUFDbEIsY0FBYyxFQUNaLEdBQUcsS0FBSyxTQUFTLElBQUksT0FBTztZQUMxQixDQUFDLENBQUM7Z0JBQ0UsYUFBYSxFQUFFLGlCQUFpQixDQUFDLGFBQWEs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
|
package/Core/Random.d.ts
CHANGED
|
@@ -26,7 +26,7 @@ interface UserNameProps {
|
|
|
26
26
|
}
|
|
27
27
|
export declare const randomUserName: ({ name, loginPrefix, maxUserNameLength, }: UserNameProps) => Output<string>;
|
|
28
28
|
export interface LoginProps extends UserNameProps {
|
|
29
|
-
passwordOptions?: Omit<RandomPassProps, "name">;
|
|
29
|
+
passwordOptions?: Omit<RandomPassProps, "name" | "vaultInfo">;
|
|
30
30
|
vaultInfo?: KeyVaultInfo;
|
|
31
31
|
}
|
|
32
32
|
export declare const randomLogin: ({ name, loginPrefix, maxUserNameLength, passwordOptions, vaultInfo, }: LoginProps) => {
|
package/Core/Random.js
CHANGED
|
@@ -60,7 +60,11 @@ const randomUserName = ({ name, loginPrefix = "admin", maxUserNameLength = 15, }
|
|
|
60
60
|
exports.randomUserName = randomUserName;
|
|
61
61
|
const randomLogin = ({ name, loginPrefix, maxUserNameLength, passwordOptions = { policy: "yearly" }, vaultInfo, }) => {
|
|
62
62
|
const userName = (0, exports.randomUserName)({ name, loginPrefix, maxUserNameLength });
|
|
63
|
-
const password = (0, exports.randomPassword)({
|
|
63
|
+
const password = (0, exports.randomPassword)({
|
|
64
|
+
name,
|
|
65
|
+
...passwordOptions,
|
|
66
|
+
vaultInfo,
|
|
67
|
+
}).result;
|
|
64
68
|
const userNameKey = `${name}-user`;
|
|
65
69
|
const passwordKey = `${name}-password`;
|
|
66
70
|
if (vaultInfo) {
|
|
@@ -80,4 +84,4 @@ const randomLogin = ({ name, loginPrefix, maxUserNameLength, passwordOptions = {
|
|
|
80
84
|
return { userName, password, vaultKeys: { userNameKey, passwordKey } };
|
|
81
85
|
};
|
|
82
86
|
exports.randomLogin = randomLogin;
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmFuZG9tLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0NvcmUvUmFuZG9tLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHlDQUF5QztBQUV6Qyw2Q0FBbUQ7QUFDbkQsMkRBQTJEO0FBZ0IzRDs7OztHQUlHO0FBQ0ksTUFBTSxjQUFjLEdBQUcsQ0FBQyxFQUM3QixNQUFNLEdBQUcsRUFBRSxFQUNYLElBQUksRUFDSixNQUFNLEdBQUcsUUFBUSxFQUNqQixPQUFPLEVBQ1AsU0FBUyxHQUNPLEVBQUUsRUFBRTtJQUNwQixJQUFJLE1BQU0sR0FBRyxFQUFFO1FBQUUsTUFBTSxHQUFHLEVBQUUsQ0FBQztJQUU3QixNQUFNLE9BQU8sR0FDWCxNQUFNLEtBQUssU0FBUztRQUNsQixDQUFDLENBQUMsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDLFFBQVEsRUFBRSxJQUFJLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFLEVBQUU7UUFDeEQsQ0FBQyxDQUFDLE1BQU0sS0FBSyxRQUFRO1lBQ25CLENBQUMsQ0FBQyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFLEVBQUU7WUFDL0IsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUVYLElBQUksR0FBRyxJQUFBLHdCQUFlLEVBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBRW5DLE1BQU0sVUFBVSxHQUFHLElBQUksTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUU7UUFDakQsT0FBTyxFQUFFLEVBQUUsT0FBTyxFQUFFO1FBQ3BCLE1BQU07UUFDTixLQUFLLEVBQUUsSUFBSTtRQUNYLFFBQVEsRUFBRSxDQUFDO1FBQ1gsS0FBSyxFQUFFLElBQUk7UUFDWCxRQUFRLEVBQUUsQ0FBQztRQUNYLE9BQU8sRUFBRSxJQUFJO1FBQ2IsVUFBVSxFQUFFLENBQUM7UUFDYixPQUFPLEVBQUUsSUFBSTtRQUNiLFVBQVUsRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENB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
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
-
import * as pulumi from
|
|
2
|
-
import { DefaultResourceArgs } from
|
|
3
|
-
import { DiagnosticSetting } from
|
|
1
|
+
import * as pulumi from "@pulumi/pulumi";
|
|
2
|
+
import { DefaultResourceArgs } from "../types";
|
|
3
|
+
import { DiagnosticSetting } from "@pulumi/azure-native/aadiam/diagnosticSetting";
|
|
4
4
|
type ClassOf = new (name: string, props: any, opts?: pulumi.CustomResourceOptions) => pulumi.CustomResource & {
|
|
5
5
|
id: pulumi.Output<string>;
|
|
6
6
|
urn: pulumi.Output<string>;
|
|
7
7
|
};
|
|
8
|
+
export type DefaultCreatorProps = Omit<DefaultResourceArgs, "name" | "group"> & {
|
|
9
|
+
lock?: boolean;
|
|
10
|
+
};
|
|
8
11
|
/** Create Resource with Locker */
|
|
9
|
-
export default function <TClass extends ClassOf, TProps extends
|
|
12
|
+
export default function <TClass extends ClassOf, TProps extends DefaultCreatorProps>(Class: TClass, { lock, monitoring, dependsOn, ignoreChanges, importUri, ...props }: TProps): {
|
|
10
13
|
resource: pulumi.CustomResource & {
|
|
11
14
|
id: pulumi.Output<string>;
|
|
12
15
|
urn: pulumi.Output<string>;
|