@drunk-pulumi/azure 0.0.41 → 0.0.43

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.
Files changed (192) hide show
  1. package/Aks/Helper.d.ts +0 -3
  2. package/Aks/Helper.js +43 -18
  3. package/Aks/Identity.js +5 -2
  4. package/Aks/VmSetAutoScale/index.js +25 -2
  5. package/Aks/VmSetMonitor/index.js +26 -3
  6. package/Aks/index.d.ts +2 -2
  7. package/Aks/index.js +35 -6
  8. package/Apim/ApiProduct/SwaggerHelper.d.ts +0 -5
  9. package/Apim/ApiProduct/SwaggerHelper.js +7 -12
  10. package/Apim/Helpers.d.ts +2 -0
  11. package/Apim/Helpers.js +17 -1
  12. package/Apps/LogicApp.js +29 -3
  13. package/Automation/index.js +29 -3
  14. package/AzAd/B2C.js +25 -2
  15. package/AzAd/EnvRoles.Consts.d.ts +1 -1
  16. package/AzAd/EnvRoles.Consts.js +38 -35
  17. package/AzAd/EnvRoles.js +5 -2
  18. package/AzAd/Group.js +25 -2
  19. package/AzAd/Identities/AzDevOpsIdentity.js +5 -2
  20. package/AzAd/Identities/AzDevOpsManagedIdentity.js +5 -2
  21. package/AzAd/Identities/AzUserAdRevertSync.js +5 -2
  22. package/AzAd/Identities/index.js +7 -4
  23. package/AzAd/Identity.js +26 -3
  24. package/AzAd/Role.js +5 -2
  25. package/AzAd/RoleAssignment.js +29 -26
  26. package/AzAd/RoleDefinitions/JustInTimeRequestRole.js +25 -2
  27. package/AzAd/UserAssignedIdentity.js +25 -2
  28. package/Builder/AksBuilder.js +6 -3
  29. package/Builder/ApimApiBuilder.d.ts +22 -0
  30. package/Builder/ApimApiBuilder.js +198 -0
  31. package/Builder/ApimBuilder.d.ts +3 -0
  32. package/Builder/ApimBuilder.js +325 -0
  33. package/Builder/ApimPolicyBuilder.d.ts +51 -0
  34. package/Builder/ApimPolicyBuilder.js +384 -0
  35. package/Builder/ApimProductBuilder.d.ts +21 -0
  36. package/Builder/ApimProductBuilder.js +153 -0
  37. package/Builder/ApimRootBuilder.d.ts +9 -0
  38. package/Builder/ApimRootBuilder.js +26 -0
  39. package/Builder/ApimWorkspaceBuilder.d.ts +10 -0
  40. package/Builder/ApimWorkspaceBuilder.js +57 -0
  41. package/Builder/CdnBuilder.d.ts +13 -0
  42. package/Builder/CdnBuilder.js +39 -0
  43. package/Builder/DnsZoneBuilder.d.ts +4 -0
  44. package/Builder/DnsZoneBuilder.js +109 -0
  45. package/Builder/PrivateDnsZoneBuilder.d.ts +4 -0
  46. package/Builder/PrivateDnsZoneBuilder.js +99 -0
  47. package/Builder/ResourceBuilder.js +20 -5
  48. package/Builder/SqlBuilder.js +21 -6
  49. package/Builder/StorageBuilder.d.ts +3 -0
  50. package/Builder/StorageBuilder.js +101 -0
  51. package/Builder/VaultBuilder.js +25 -2
  52. package/Builder/VmBuilder.js +16 -3
  53. package/Builder/VnetBuilder.js +21 -20
  54. package/Builder/index.d.ts +6 -0
  55. package/Builder/index.js +23 -8
  56. package/Builder/types/apimBuilder.d.ts +71 -0
  57. package/Builder/types/apimBuilder.js +3 -0
  58. package/Builder/types/apimPolicyBuilder.d.ts +84 -0
  59. package/Builder/types/apimPolicyBuilder.js +11 -0
  60. package/Builder/types/apimProductBuilder.d.ts +56 -0
  61. package/Builder/types/apimProductBuilder.js +3 -0
  62. package/Builder/types/apimWorkspaceBuilder.d.ts +2 -0
  63. package/Builder/types/apimWorkspaceBuilder.js +3 -0
  64. package/Builder/types/askBuilder.d.ts +11 -15
  65. package/Builder/types/cdnBuilder.d.ts +7 -0
  66. package/Builder/types/cdnBuilder.js +3 -0
  67. package/Builder/types/dnsZoneBuilder.d.ts +11 -0
  68. package/Builder/types/dnsZoneBuilder.js +3 -0
  69. package/Builder/types/genericBuilder.d.ts +9 -9
  70. package/Builder/types/genericBuilder.js +1 -1
  71. package/Builder/types/index.d.ts +7 -0
  72. package/Builder/types/index.js +8 -1
  73. package/Builder/types/privateDnsZoneBuilder.d.ts +13 -0
  74. package/Builder/types/privateDnsZoneBuilder.js +3 -0
  75. package/Builder/types/resourceBuilder.d.ts +17 -15
  76. package/Builder/types/sqlBuilder.d.ts +10 -5
  77. package/Builder/types/storageBuilder.d.ts +24 -0
  78. package/Builder/types/storageBuilder.js +3 -0
  79. package/Builder/types/vaultBuilder.d.ts +7 -7
  80. package/Builder/types/vmBuilder.d.ts +9 -7
  81. package/Builder/types/vnetBuilder.d.ts +17 -17
  82. package/Cdn/CdnEndpoint.d.ts +13 -0
  83. package/Cdn/CdnEndpoint.js +94 -0
  84. package/{Storage → Cdn}/CdnRules.d.ts +2 -2
  85. package/Cdn/CdnRules.js +133 -0
  86. package/Cdn/index.d.ts +7 -6
  87. package/Cdn/index.js +45 -33
  88. package/Certificate/index.js +27 -4
  89. package/Certificate/p12.js +25 -2
  90. package/Common/AzureEnv.js +25 -2
  91. package/Common/ConfigHelper.js +25 -2
  92. package/Common/GlobalEnv.d.ts +2 -8
  93. package/Common/GlobalEnv.js +12 -16
  94. package/Common/StackEnv.js +25 -2
  95. package/Common/index.js +29 -6
  96. package/ContainerRegistry/Helper.js +29 -3
  97. package/ContainerRegistry/index.js +31 -5
  98. package/Core/Locker.js +25 -2
  99. package/Core/Random.js +25 -2
  100. package/Core/ResourceCreator.js +5 -2
  101. package/Core/ResourceGroup.js +5 -2
  102. package/CosmosDb/index.js +29 -3
  103. package/CustomRoles/index.js +25 -2
  104. package/IOT/Hub/index.js +25 -2
  105. package/KeyVault/Helper.js +25 -2
  106. package/KeyVault/index.js +29 -3
  107. package/Logs/AppInsight.d.ts +4 -4
  108. package/Logs/AppInsight.js +35 -9
  109. package/Logs/Helpers.d.ts +12 -9
  110. package/Logs/Helpers.js +57 -14
  111. package/Logs/LogAnalytics.js +25 -2
  112. package/Logs/WebTest.d.ts +1 -1
  113. package/Logs/WebTest.js +35 -12
  114. package/Logs/index.d.ts +1 -10
  115. package/Logs/index.js +36 -8
  116. package/MySql/index.js +30 -4
  117. package/Postgresql/index.js +30 -4
  118. package/RedisCache/index.js +26 -3
  119. package/ServiceBus/index.js +30 -4
  120. package/SignalR/index.js +29 -3
  121. package/Sql/SqlDb.js +25 -2
  122. package/Sql/index.d.ts +9 -9
  123. package/Sql/index.js +49 -20
  124. package/Storage/Helper.d.ts +4 -4
  125. package/Storage/Helper.js +25 -2
  126. package/Storage/ManagementRules.js +25 -2
  127. package/Storage/index.d.ts +37 -39
  128. package/Storage/index.js +71 -97
  129. package/VM/AzureDevOpsExtension.js +5 -2
  130. package/VM/Extension.js +25 -2
  131. package/VM/GlobalSchedule.js +25 -2
  132. package/VM/index.d.ts +7 -6
  133. package/VM/index.js +33 -6
  134. package/VNet/Bastion.js +29 -3
  135. package/VNet/Firewall.js +31 -5
  136. package/VNet/FirewallPolicies/index.js +8 -5
  137. package/VNet/FirewallPolicy.js +25 -2
  138. package/VNet/GlobalNetworkPeering.js +25 -2
  139. package/VNet/Helper.js +26 -3
  140. package/VNet/IpAddress.js +30 -4
  141. package/VNet/IpAddressPrefix.js +30 -4
  142. package/VNet/NSGRules/ApimSecurityRule.d.ts +7 -0
  143. package/VNet/NSGRules/ApimSecurityRule.js +34 -0
  144. package/VNet/NSGRules/AzADSecurityRule.d.ts +2 -2
  145. package/VNet/NSGRules/AzADSecurityRule.js +2 -2
  146. package/VNet/NSGRules/BastionSecurityRule.d.ts +1 -2
  147. package/VNet/NSGRules/BastionSecurityRule.js +2 -2
  148. package/VNet/NSGRules/index.d.ts +4 -0
  149. package/VNet/NSGRules/index.js +15 -0
  150. package/VNet/NatGateway.js +25 -2
  151. package/VNet/NetworkPeering.js +25 -2
  152. package/VNet/PrivateEndpoint.js +32 -27
  153. package/VNet/RouteTable.js +25 -2
  154. package/VNet/SecurityGroup.js +25 -2
  155. package/VNet/Subnet.js +25 -2
  156. package/VNet/VPNGateway.js +29 -3
  157. package/VNet/VirtualWAN.js +29 -3
  158. package/VNet/Vnet.d.ts +2 -2
  159. package/VNet/Vnet.js +35 -6
  160. package/VNet/index.d.ts +3 -0
  161. package/VNet/index.js +34 -8
  162. package/Web/AppCertOrder.js +29 -3
  163. package/Web/AppConfig.d.ts +8 -11
  164. package/Web/AppConfig.js +51 -33
  165. package/Web/AppGateway.js +29 -3
  166. package/Web/FuncApp.js +25 -2
  167. package/Web/Helpers.js +25 -2
  168. package/Web/WebAppPlan.js +25 -2
  169. package/index.d.ts +1 -0
  170. package/index.js +18 -0
  171. package/package.json +5 -4
  172. package/types.d.ts +0 -6
  173. package/z_tests/_tools/Mocks.js +25 -2
  174. package/Apim/ApiProduct/Api.d.ts +0 -35
  175. package/Apim/ApiProduct/Api.js +0 -131
  176. package/Apim/ApiProduct/PolicyBuilder.d.ts +0 -79
  177. package/Apim/ApiProduct/PolicyBuilder.js +0 -359
  178. package/Apim/ApiProduct/Product.d.ts +0 -8
  179. package/Apim/ApiProduct/Product.js +0 -63
  180. package/Apim/ApiProduct/index.d.ts +0 -9
  181. package/Apim/ApiProduct/index.js +0 -21
  182. package/Apim/HookProxy/index.d.ts +0 -20
  183. package/Apim/HookProxy/index.js +0 -27
  184. package/Apim/index.d.ts +0 -22
  185. package/Apim/index.js +0 -115
  186. package/Storage/CdnEndpoint.d.ts +0 -12
  187. package/Storage/CdnEndpoint.js +0 -61
  188. package/Storage/CdnRules.js +0 -134
  189. package/VNet/PrivateDns.d.ts +0 -31
  190. package/VNet/PrivateDns.js +0 -68
  191. package/VNet/PublicDns.d.ts +0 -21
  192. package/VNet/PublicDns.js +0 -59
@@ -0,0 +1,384 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ const apim = __importStar(require("@pulumi/azure-native/apimanagement"));
30
+ const StackEnv_1 = require("../Common/StackEnv");
31
+ const Helper_1 = require("../VNet/Helper");
32
+ const xml_formatter_1 = __importDefault(require("xml-formatter"));
33
+ const types_1 = require("./types");
34
+ class ApimPolicyBuilder {
35
+ props;
36
+ _baseUrl = undefined;
37
+ _rewriteUri = undefined;
38
+ _rateLimit = undefined;
39
+ _cacheOptions = undefined;
40
+ _backendCert = undefined;
41
+ _verifyClientCert = undefined;
42
+ _cors = undefined;
43
+ _validateJwtWhitelistIp = undefined;
44
+ _mockResponses = [];
45
+ _headers = [];
46
+ _checkHeaders = [];
47
+ _whitelistIps = [];
48
+ _findAndReplaces = [];
49
+ //private _inboundCustomPolicies: ApimCustomPolicyType[] = [];
50
+ //private _outboundCustomPolicies: ApimCustomPolicyType[] = [];
51
+ _inboundPolicies = [];
52
+ _outboundPolicies = [];
53
+ constructor(props) {
54
+ this.props = props;
55
+ }
56
+ setBaseUrl(props) {
57
+ this._baseUrl = props;
58
+ return this;
59
+ }
60
+ setHeader(props) {
61
+ this._headers.push(props);
62
+ return this;
63
+ }
64
+ checkHeader(props) {
65
+ this._checkHeaders.push(props);
66
+ return this;
67
+ }
68
+ mockResponse(props) {
69
+ this._mockResponses.push(props);
70
+ return this;
71
+ }
72
+ rewriteUri(props) {
73
+ this._rewriteUri = props;
74
+ return this;
75
+ }
76
+ setRateLimit(props) {
77
+ this._rateLimit = props;
78
+ return this;
79
+ }
80
+ setCacheOptions(props) {
81
+ this._cacheOptions = props;
82
+ return this;
83
+ }
84
+ setBackendCert(props) {
85
+ this._backendCert = props;
86
+ return this;
87
+ }
88
+ verifyClientCert(props) {
89
+ this._verifyClientCert = props;
90
+ return this;
91
+ }
92
+ setCors(props) {
93
+ this._cors = props;
94
+ return this;
95
+ }
96
+ setClientIpHeader(props) {
97
+ this._headers.push({
98
+ name: props.headerKey ?? `x-${StackEnv_1.organization}-clientIp`,
99
+ value: "@(context.Request.IpAddress)",
100
+ type: types_1.SetHeaderTypes.override,
101
+ });
102
+ return this;
103
+ }
104
+ /** Filter IP from Bearer Token */
105
+ validateJwtWhitelistIp(props) {
106
+ this._validateJwtWhitelistIp = props;
107
+ return this;
108
+ }
109
+ /** IP Address Whitelisting */
110
+ setWhitelistIPs(props) {
111
+ this._whitelistIps.push(props);
112
+ return this;
113
+ }
114
+ /**Replace outbound results */
115
+ setFindAndReplaces(props) {
116
+ this._findAndReplaces.push(props);
117
+ return this;
118
+ }
119
+ //Custom Policies
120
+ // public withInboundPolicy(props: ApimCustomPolicyType): IApimPolicyBuilder {
121
+ // this._inboundCustomPolicies.push(props);
122
+ // return this;
123
+ // }
124
+ // public withOutPolicy(props: ApimCustomPolicyType): IApimPolicyBuilder {
125
+ // this._outboundCustomPolicies.push(props);
126
+ // return this;
127
+ // }
128
+ buildBaseUrl() {
129
+ if (!this._baseUrl)
130
+ return;
131
+ this._inboundPolicies.push(`<set-backend-service base-url="${this._baseUrl.url}" />`);
132
+ }
133
+ buildHeaders() {
134
+ this._inboundPolicies.push(...this._headers.map((h) => {
135
+ let rs = `<set-header name="${h.name}" exists-action="${h.type}">`;
136
+ if (h.value) {
137
+ rs += ` <value>${h.value}</value>`;
138
+ }
139
+ rs += "</set-header>";
140
+ return rs;
141
+ }));
142
+ }
143
+ buildCheckHeaders() {
144
+ this._inboundPolicies.push(...this._checkHeaders.map((ch) => `<check-header name="${ch.name}" failed-check-httpcode="401" failed-check-error-message="The header ${ch.name} is not found" ignore-case="true">
145
+ ${ch.value ? ch.value.map((v) => `<value>${v}</value>`).join("\n") : ""}
146
+ </check-header>`));
147
+ }
148
+ buildMockResponse() {
149
+ this._inboundPolicies.push(...this._mockResponses.map((m) => `<mock-response status-code="${m.code ?? 200}" content-type="${m.contentType ?? "application/json"}" />`));
150
+ }
151
+ buildRewriteUri() {
152
+ if (!this._rewriteUri)
153
+ return;
154
+ this._inboundPolicies.push(`<rewrite-uri template="${this._rewriteUri.template ?? "/"}" />`);
155
+ }
156
+ buildRateLimit() {
157
+ if (!this._rateLimit)
158
+ return;
159
+ this._inboundPolicies.push(this._rateLimit.successConditionOnly
160
+ ? `<rate-limit-by-key calls="${this._rateLimit.calls ?? 10}" renewal-period="${this._rateLimit.inSecond ?? 10}" counter-key="@(context.Request.IpAddress)" increment-condition="@(context.Response.StatusCode &gt;= 200 &amp;&amp; context.Response.StatusCode &lt; 300)" />`
161
+ : `<rate-limit-by-key calls="${this._rateLimit.calls ?? 10}" renewal-period="${this._rateLimit.inSecond ?? 10}" counter-key="@(context.Request.IpAddress)" />`);
162
+ }
163
+ buildCacheOptions() {
164
+ if (!this._cacheOptions)
165
+ return;
166
+ this._inboundPolicies.push(`<cache-lookup vary-by-developer="false"
167
+ vary-by-developer-groups="false"
168
+ allow-private-response-caching="true"
169
+ must-revalidate="true"
170
+ downstream-caching-type="public" />`);
171
+ this._outboundPolicies.push(`<cache-store duration="${this._cacheOptions.duration ?? 60}" />`);
172
+ }
173
+ buildBackendCert() {
174
+ if (!this._backendCert)
175
+ return;
176
+ this._inboundPolicies.push(`<authentication-certificate thumbprint="${this._backendCert.thumbprint}" />`);
177
+ }
178
+ buildVerifyClientCert() {
179
+ if (!this._verifyClientCert)
180
+ return;
181
+ this._inboundPolicies.push(`<choose>
182
+ <when condition="@(context.Request.Certificate == null${this._verifyClientCert.verifyCert
183
+ ? " || !context.Request.Certificate.VerifyNoRevocation()"
184
+ : ""}${this._verifyClientCert.issuer
185
+ ? ` || context.Request.Certificate.Issuer != "${this._verifyClientCert.issuer}"`
186
+ : ""}${this._verifyClientCert.subject
187
+ ? ` || context.Request.Certificate.SubjectName.Name != "${this._verifyClientCert.subject}"`
188
+ : ""}${this._verifyClientCert.thumbprint
189
+ ? ` || context.Request.Certificate.Thumbprint != "${this._verifyClientCert.thumbprint}"`
190
+ : ""})" >
191
+ <return-response>
192
+ <set-status code="403" reason="Invalid client certificate" />
193
+ </return-response>
194
+ </when>
195
+ </choose>`);
196
+ }
197
+ buildCors() {
198
+ if (!this._cors)
199
+ return;
200
+ const orgs = this._cors.origins
201
+ ? this._cors.origins.map((o) => `<origin>${o}</origin>`)
202
+ : ["<origin>*</origin>"];
203
+ const cors = `<cors allow-credentials="${Array.isArray(this._cors.origins)}">
204
+ <allowed-origins>
205
+ ${orgs.join("\n")}
206
+ </allowed-origins>
207
+ <allowed-methods preflight-result-max-age="300">
208
+ <method>*</method>
209
+ </allowed-methods>
210
+ <allowed-headers>
211
+ <header>*</header>
212
+ </allowed-headers>
213
+ </cors>`;
214
+ this._inboundPolicies.push(cors);
215
+ }
216
+ buildValidateJwtWhitelistIp() {
217
+ if (!this._validateJwtWhitelistIp)
218
+ return;
219
+ const claimKey = this._validateJwtWhitelistIp.claimKey ?? "client_IpWhitelist";
220
+ const setHeader = `<set-header name="IpAddressValidation" exists-action="override">
221
+ <value>@{
222
+ Boolean ipAddressValid = false;
223
+ string authHeader = context.Request.Headers.GetValueOrDefault("Authorization", "");
224
+ if (authHeader?.Length > 0)
225
+ {
226
+ string[] authHeaderParts = authHeader.Split(' ');
227
+ if (authHeaderParts?.Length == 2 && authHeaderParts[0].Equals("Bearer", StringComparison.InvariantCultureIgnoreCase))
228
+ {
229
+ if (authHeaderParts[1].TryParseJwt(out Jwt jwt))
230
+ {
231
+ var ipsWhitelist = jwt.Claims.GetValueOrDefault("${claimKey}", "");
232
+ IEnumerable<string> ips = ipsWhitelist
233
+ .Split(new char[] { ';', ',' }, StringSplitOptions.RemoveEmptyEntries)
234
+ .Select(p => p.Trim());
235
+
236
+ if(string.IsNullOrEmpty(ipsWhitelist) || ips.Contains(context.Request.IpAddress))
237
+ {
238
+ ipAddressValid = true;
239
+ }
240
+ }
241
+ }
242
+ }
243
+ else
244
+ {
245
+ ipAddressValid = true;
246
+ }
247
+
248
+ return ipAddressValid.ToString();
249
+ }</value>
250
+ </set-header>`;
251
+ const checkHeader = `<choose>
252
+ <when condition="@(context.Request.Headers.GetValueOrDefault("IpAddressValidation", "").Equals(Boolean.FalseString))">
253
+ <return-response>
254
+ <set-status code="403" reason="Forbidden"/>
255
+ <set-body>@{
256
+ return new JObject(
257
+ new JProperty("message","The IP does not match.")
258
+ ).ToString();
259
+ }</set-body>
260
+ </return-response>
261
+ </when>
262
+ </choose>`;
263
+ //Create Policy Fragment
264
+ const pfName = `${this.props.name}-PolicyFragment`;
265
+ new apim.PolicyFragment(pfName, {
266
+ id: pfName,
267
+ description: pfName,
268
+ serviceName: this.props.apimServiceName,
269
+ resourceGroupName: this.props.group.resourceGroupName,
270
+ format: "xml",
271
+ value: (0, xml_formatter_1.default)(`
272
+ <fragment>
273
+ ${setHeader}
274
+ ${checkHeader}
275
+ </fragment>
276
+ `),
277
+ });
278
+ this._inboundPolicies.push(`<include-fragment fragment-id="${pfName}" />`);
279
+ }
280
+ buildWhiteListIps() {
281
+ if (this._whitelistIps.length <= 0)
282
+ return;
283
+ const ipAddresses = this._whitelistIps.flatMap((ip) => ip.ipAddresses);
284
+ const policy = `<ip-filter action="allow">\r\n${ipAddresses
285
+ .map((ip) => {
286
+ if (ip.includes("/")) {
287
+ const range = (0, Helper_1.getIpsRange)(ip);
288
+ return `<address-range from="${range.first}" to="${range.last}" />`;
289
+ }
290
+ return `<address>${ip}</address>`;
291
+ })
292
+ .join("\r\n")}
293
+ </ip-filter>`;
294
+ this._inboundPolicies.push(policy);
295
+ }
296
+ buildFindAndReplace() {
297
+ if (!this._findAndReplaces)
298
+ return;
299
+ this._outboundPolicies.push(...this._findAndReplaces
300
+ .map((f) => `<find-and-replace from="${f.from}" to="${f.to}" />`)
301
+ .join("\n"));
302
+ }
303
+ // private buildCustomRules() {
304
+ // if (this._inboundCustomPolicies) {
305
+ // this._inboundPolicies.push(
306
+ // ...this._inboundCustomPolicies.map((i) => i.policy),
307
+ // );
308
+ // }
309
+ // if (this._outboundPolicies) {
310
+ // this._outboundPolicies.push(
311
+ // ...this._outboundCustomPolicies.map((i) => i.policy),
312
+ // );
313
+ // }
314
+ // }
315
+ build() {
316
+ this.buildHeaders();
317
+ this.buildBaseUrl();
318
+ this.buildRewriteUri();
319
+ this.buildCacheOptions();
320
+ this.buildMockResponse();
321
+ this.buildRateLimit();
322
+ this.buildBackendCert();
323
+ this.buildCors();
324
+ this.buildValidateJwtWhitelistIp();
325
+ this.buildWhiteListIps();
326
+ this.buildCheckHeaders();
327
+ this.buildFindAndReplace();
328
+ //this.buildCustomRules();
329
+ //This must be a last rule
330
+ this.buildVerifyClientCert();
331
+ let backend = "<base />";
332
+ if (!this._mockResponses) {
333
+ backend =
334
+ '<forward-request timeout="120" follow-redirects="true" buffer-request-body="true" fail-on-error-status-code="true"/>';
335
+ }
336
+ const xmlPolicy = `<policies>
337
+ <inbound>
338
+ <base />
339
+ ${this._inboundPolicies.join("\n")}
340
+ </inbound>
341
+ <backend>
342
+ ${backend}
343
+ </backend>
344
+ <outbound>
345
+ <base />
346
+ <set-header name="Strict-Transport-Security" exists-action="override">
347
+ <value>max-age=15724800; includeSubDomains</value>
348
+ </set-header>
349
+ <set-header name="X-XSS-Protection" exists-action="override">
350
+ <value>1; mode=block</value>
351
+ </set-header>
352
+ <set-header name="Content-Security-Policy" exists-action="override">
353
+ <value>default-src 'self' data: 'unsafe-inline' 'unsafe-eval'</value>
354
+ </set-header>
355
+ <set-header name="X-Frame-Options" exists-action="override">
356
+ <value>Deny</value>
357
+ </set-header>
358
+ <set-header name="X-Content-Type-Options" exists-action="override">
359
+ <value>nosniff</value>
360
+ </set-header>
361
+ <set-header name="Expect-Ct" exists-action="override">
362
+ <value>max-age=604800,enforce</value>
363
+ </set-header>
364
+ <set-header name="Cache-Control" exists-action="override">
365
+ <value>none</value>
366
+ </set-header>
367
+ <set-header name="X-Powered-By" exists-action="delete" />
368
+ <set-header name="X-AspNet-Version" exists-action="delete" />
369
+
370
+ ${this._outboundPolicies.join("\n")}
371
+ </outbound>
372
+ <on-error>
373
+ <base />
374
+ </on-error>
375
+ </policies>`;
376
+ return (0, xml_formatter_1.default)(xmlPolicy, {
377
+ strictMode: true,
378
+ throwOnFailure: true,
379
+ forceSelfClosingEmptyTag: true,
380
+ });
381
+ }
382
+ }
383
+ exports.default = ApimPolicyBuilder;
384
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ApimPolicyBuilder.js","sourceRoot":"","sources":["../../src/Builder/ApimPolicyBuilder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import { ResourceInfo } from "../types";
2
+ import { APimApiBuilderFunction, ApimApiPolicyType, ApimChildBuilderProps, ApimProductSubscriptionBuilderType, BuilderAsync, IApimProductBuilder, IBuilderAsync } from "./types";
3
+ export declare class ApimProductBuilder extends BuilderAsync<ResourceInfo> implements IApimProductBuilder {
4
+ private props;
5
+ private _apis;
6
+ private _requiredSubscription;
7
+ private _productInstance;
8
+ private _subInstance;
9
+ private _productInstanceName;
10
+ private _policyString;
11
+ private _state;
12
+ constructor(props: ApimChildBuilderProps);
13
+ withPolicies(props: ApimApiPolicyType): IApimProductBuilder;
14
+ requiredSubscription(props: ApimProductSubscriptionBuilderType): IApimProductBuilder;
15
+ withApi(props: APimApiBuilderFunction): IApimProductBuilder;
16
+ published(): IBuilderAsync<ResourceInfo>;
17
+ private buildProduct;
18
+ private buildSubscription;
19
+ private buildApis;
20
+ build(): Promise<ResourceInfo>;
21
+ }
@@ -0,0 +1,153 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.ApimProductBuilder = void 0;
30
+ const apim = __importStar(require("@pulumi/azure-native/apimanagement"));
31
+ const pulumi_1 = require("@pulumi/pulumi");
32
+ const Naming_1 = require("../Common/Naming");
33
+ const Random_1 = require("../Core/Random");
34
+ const CustomHelper_1 = require("../KeyVault/CustomHelper");
35
+ const ApimApiBuilder_1 = __importDefault(require("./ApimApiBuilder"));
36
+ const ApimPolicyBuilder_1 = __importDefault(require("./ApimPolicyBuilder"));
37
+ const types_1 = require("./types");
38
+ class ApimProductBuilder extends types_1.BuilderAsync {
39
+ props;
40
+ _apis = [];
41
+ _requiredSubscription = undefined;
42
+ _productInstance = undefined;
43
+ _subInstance = undefined;
44
+ _productInstanceName;
45
+ _policyString;
46
+ _state = "notPublished";
47
+ constructor(props) {
48
+ super(props);
49
+ this.props = props;
50
+ this._productInstanceName = `${props.name}-product`;
51
+ //Empty Policy
52
+ this._policyString = new ApimPolicyBuilder_1.default({
53
+ ...props,
54
+ name: this._productInstanceName,
55
+ }).build();
56
+ }
57
+ withPolicies(props) {
58
+ this._policyString = props(new ApimPolicyBuilder_1.default({ ...this.props, name: this._productInstanceName })).build();
59
+ return this;
60
+ }
61
+ requiredSubscription(props) {
62
+ this._requiredSubscription = props;
63
+ return this;
64
+ }
65
+ withApi(props) {
66
+ this._apis.push(props);
67
+ return this;
68
+ }
69
+ published() {
70
+ this._state = "published";
71
+ return this;
72
+ }
73
+ buildProduct() {
74
+ this._productInstance = new apim.Product(this._productInstanceName, {
75
+ productId: this._productInstanceName,
76
+ displayName: this._productInstanceName,
77
+ description: this._productInstanceName,
78
+ serviceName: this.props.apimServiceName,
79
+ resourceGroupName: this.props.group.resourceGroupName,
80
+ state: this._state,
81
+ subscriptionRequired: Boolean(this._requiredSubscription),
82
+ approvalRequired: this._requiredSubscription
83
+ ? this._requiredSubscription?.approvalRequired
84
+ : undefined,
85
+ subscriptionsLimit: this._requiredSubscription?.subscriptionsLimit ?? 5,
86
+ });
87
+ if (this._policyString) {
88
+ new apim.ProductPolicy(`${this._productInstanceName}-policy`, {
89
+ serviceName: this.props.apimServiceName,
90
+ resourceGroupName: this.props.group.resourceGroupName,
91
+ productId: this._productInstanceName,
92
+ format: "xml",
93
+ policyId: "policy",
94
+ value: this._policyString,
95
+ });
96
+ }
97
+ }
98
+ buildSubscription() {
99
+ if (!this._productInstance)
100
+ return;
101
+ const subName = `${this.props.name}-sub`;
102
+ const primaryKey = (0, Naming_1.getPasswordName)(subName, "primary");
103
+ const secondaryKey = (0, Naming_1.getPasswordName)(subName, "secondary");
104
+ const primaryPass = (0, Random_1.randomPassword)({ name: primaryKey }).result;
105
+ const secondaryPass = (0, Random_1.randomPassword)({ name: secondaryKey }).result;
106
+ this._subInstance = new apim.Subscription(subName, {
107
+ sid: subName,
108
+ displayName: subName,
109
+ serviceName: this.props.apimServiceName,
110
+ resourceGroupName: this.props.group.resourceGroupName,
111
+ scope: (0, pulumi_1.interpolate) `/products/${this._productInstance.id}`,
112
+ primaryKey: primaryPass,
113
+ secondaryKey: secondaryPass,
114
+ }, { dependsOn: this._productInstance });
115
+ (0, CustomHelper_1.addCustomSecret)({
116
+ name: primaryKey,
117
+ formattedName: true,
118
+ value: primaryPass,
119
+ contentType: subName,
120
+ vaultInfo: this.props.vaultInfo,
121
+ dependsOn: this._subInstance,
122
+ });
123
+ (0, CustomHelper_1.addCustomSecret)({
124
+ name: secondaryKey,
125
+ formattedName: true,
126
+ value: secondaryPass,
127
+ contentType: subName,
128
+ vaultInfo: this.props.vaultInfo,
129
+ dependsOn: this._subInstance,
130
+ });
131
+ }
132
+ async buildApis() {
133
+ const tasks = this._apis.map((api) => api(new ApimApiBuilder_1.default({
134
+ ...this.props,
135
+ productId: this._productInstanceName,
136
+ requiredSubscription: Boolean(this._requiredSubscription),
137
+ dependsOn: this._productInstance,
138
+ })).build());
139
+ await Promise.all(tasks);
140
+ }
141
+ async build() {
142
+ this.buildProduct();
143
+ this.buildSubscription();
144
+ await this.buildApis();
145
+ return {
146
+ resourceName: this._productInstanceName,
147
+ group: this.props.group,
148
+ id: this._productInstance.id,
149
+ };
150
+ }
151
+ }
152
+ exports.ApimProductBuilder = ApimProductBuilder;
153
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpbVByb2R1Y3RCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0J1aWxkZXIvQXBpbVByb2R1Y3RCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUVBQTJEO0FBQzNELDJDQUE2QztBQUM3Qyw2Q0FBbUQ7QUFDbkQsMkNBQWdEO0FBQ2hELDJEQUEyRDtBQUUzRCxzRUFBOEM7QUFDOUMsNEVBQW9EO0FBQ3BELG1DQVFpQjtBQUVqQixNQUFhLGtCQUNYLFNBQVEsb0JBQTBCO0lBY1A7SUFYbkIsS0FBSyxHQUE2QixFQUFFLENBQUM7SUFDckMscUJBQXFCLEdBRWIsU0FBUyxDQUFDO0lBRWxCLGdCQUFnQixHQUE2QixTQUFTLENBQUM7SUFDdkQsWUFBWSxHQUFrQyxTQUFTLENBQUM7SUFDeEQsb0JBQW9CLENBQVM7SUFDN0IsYUFBYSxDQUFTO0lBQ3RCLE1BQU0sR0FBc0IsY0FBYyxDQUFDO0lBRW5ELFlBQTJCLEtBQTRCO1FBQ3JELEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQURZLFVBQUssR0FBTCxLQUFLLENBQXVCO1FBRXJELElBQUksQ0FBQyxvQkFBb0IsR0FBRyxHQUFHLEtBQUssQ0FBQyxJQUFJLFVBQVUsQ0FBQztRQUNwRCxjQUFjO1FBQ2QsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLDJCQUFpQixDQUFDO1lBQ3pDLEdBQUcsS0FBSztZQUNSLElBQUksRUFBRSxJQUFJLENBQUMsb0JBQW9CO1NBQ2hDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNiLENBQUM7SUFFTSxZQUFZLENBQUMsS0FBd0I7UUFDMUMsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQ3hCLElBQUksMkJBQWlCLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQzFFLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDVixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxvQkFBb0IsQ0FDekIsS0FBeUM7UUFFekMsSUFBSSxDQUFDLHFCQUFxQixHQUFHLEtBQUssQ0FBQztRQUNuQyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFDTSxPQUFPLENBQUMsS0FBNkI7UUFDMUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBQ00sU0FBUztRQUNkLElBQUksQ0FBQyxNQUFNLEdBQUcsV0FBVyxDQUFDO1FBQzFCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVPLFlBQVk7UUFDbEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsb0JBQW9CLEVBQUU7WUFDbEUsU0FBUyxFQUFFLElBQUksQ0FBQyxvQkFBb0I7WUFDcEMsV0FBVyxFQUFFLElBQUksQ0FBQyxvQkFBb0I7WUFDdEMsV0FBVyxFQUFFLElBQUksQ0FBQyxvQkFBb0I7WUFFdEMsV0FBVyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZTtZQUN2QyxpQkFBaUIsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxpQkFBaUI7WUFFckQsS0FBSyxFQUFFLElBQUksQ0FBQyxNQUFNO1lBQ2xCLG9CQUFvQixFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUM7WUFDekQsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLHFCQUFxQjtnQkFDMUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxnQkFBZ0I7Z0JBQzlDLENBQUMsQ0FBQyxTQUFTO1lBQ2Isa0JBQWtCLEVBQUUsSUFBSSxDQUFDLHFCQUFxQixFQUFFLGtCQUFrQixJQUFJLENBQUM7U0FDeEUsQ0FBQyxDQUFDO1FBRUgsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDdkIsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixTQUFTLEVBQUU7Z0JBQzVELFdBQVcsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWU7Z0JBQ3ZDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLGlCQUFpQjtnQkFDckQsU0FBUyxFQUFFLElBQUksQ0FBQyxvQkFBb0I7Z0JBQ3BDLE1BQU0sRUFBRSxLQUFLO2dCQUNiLFFBQVEsRUFBRSxRQUFRO2dCQUNsQixLQUFLLEVBQUUsSUFBSSxDQUFDLGFBQWE7YUFDMUIsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7SUFDTyxpQkFBaUI7UUFDdkIsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0I7WUFBRSxPQUFPO1FBQ25DLE1BQU0sT0FBTyxHQUFHLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLE1BQU0sQ0FBQztRQUN6QyxNQUFNLFVBQVUsR0FBRyxJQUFBLHdCQUFlLEVBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3ZELE1BQU0sWUFBWSxHQUFHLElBQUEsd0JBQWUsRUFBQyxPQUFPLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFFM0QsTUFBTSxXQUFXLEdBQUcsSUFBQSx1QkFBYyxFQUFDLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDO1FBQ2hFLE1BQU0sYUFBYSxHQUFHLElBQUEsdUJBQWMsRUFBQyxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUVwRSxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksSUFBSSxDQUFDLFlBQVksQ0FDdkMsT0FBTyxFQUNQO1lBQ0UsR0FBRyxFQUFFLE9BQU87WUFDWixXQUFXLEVBQUUsT0FBTztZQUNwQixXQUFXLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlO1lBQ3ZDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLGlCQUFpQjtZQUNyRCxLQUFLLEVBQUUsSUFBQSxvQkFBVyxFQUFBLGFBQWEsSUFBSSxDQUFDLGdCQUFpQixDQUFDLEVBQUUsRUFBRTtZQUMxRCxVQUFVLEVBQUUsV0FBVztZQUN2QixZQUFZLEVBQUUsYUFBYTtTQUM1QixFQUNELEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUNyQyxDQUFDO1FBRUYsSUFBQSw4QkFBZSxFQUFDO1lBQ2QsSUFBSSxFQUFFLFVBQVU7WUFDaEIsYUFBYSxFQUFFLElBQUk7WUFDbkIsS0FBSyxFQUFFLFdBQVc7WUFDbEIsV0FBVyxFQUFFLE9BQU87WUFDcEIsU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUztZQUMvQixTQUFTLEVBQUUsSUFBSSxDQUFDLFlBQVk7U0FDN0IsQ0FBQyxDQUFDO1FBRUgsSUFBQSw4QkFBZSxFQUFDO1lBQ2QsSUFBSSxFQUFFLFlBQVk7WUFDbEIsYUFBYSxFQUFFLElBQUk7WUFDbkIsS0FBSyxFQUFFLGFBQWE7WUFDcEIsV0FBVyxFQUFFLE9BQU87WUFDcEIsU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUztZQUMvQixTQUFTLEVBQUUsSUFBSSxDQUFDLFlBQVk7U0FDN0IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVPLEtBQUssQ0FBQyxTQUFTO1FBQ3JCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FDbkMsR0FBRyxDQUNELElBQUksd0JBQWMsQ0FBQztZQUNqQixHQUFHLElBQUksQ0FBQyxLQUFLO1lBQ2IsU0FBUyxFQUFFLElBQUksQ0FBQyxvQkFBb0I7WUFDcEMsb0JBQW9CLEVBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztZQUN6RCxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQjtTQUNqQyxDQUFDLENBQ0gsQ0FBQyxLQUFLLEVBQUUsQ0FDVixDQUFDO1FBQ0YsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFTSxLQUFLLENBQUMsS0FBSztRQUNoQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDcEIsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDekIsTUFBTSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFFdkIsT0FBTztZQUNMLFlBQVksRUFBRSxJQUFJLENBQUMsb0JBQW9CO1lBQ3ZDLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUs7WUFDdkIsRUFBRSxFQUFFLElBQUksQ0FBQyxnQkFBaUIsQ0FBQyxFQUFFO1NBQzlCLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUE3SUQsZ0RBNklDIn0=
@@ -0,0 +1,9 @@
1
+ import { ResourceInfo } from "../types";
2
+ import { BuilderProps, IApimProductBuilder, IApimWorkspaceBuilder } from "./types";
3
+ export default class ApimRootBuilder {
4
+ private props;
5
+ private constructor();
6
+ static from(apimInfo: ResourceInfo, props: Omit<BuilderProps, "group" | "name">): ApimRootBuilder;
7
+ newProduct(name: string): IApimProductBuilder;
8
+ newWorkspace(name: string): IApimWorkspaceBuilder;
9
+ }
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const ApimProductBuilder_1 = require("./ApimProductBuilder");
4
+ const ApimWorkspaceBuilder_1 = require("./ApimWorkspaceBuilder");
5
+ class ApimRootBuilder {
6
+ props;
7
+ constructor(props) {
8
+ this.props = props;
9
+ }
10
+ static from(apimInfo, props) {
11
+ return new ApimRootBuilder({
12
+ ...props,
13
+ name: apimInfo.resourceName,
14
+ apimServiceName: apimInfo.resourceName,
15
+ group: apimInfo.group,
16
+ });
17
+ }
18
+ newProduct(name) {
19
+ return new ApimProductBuilder_1.ApimProductBuilder({ ...this.props, name });
20
+ }
21
+ newWorkspace(name) {
22
+ return new ApimWorkspaceBuilder_1.ApimWorkspaceBuilder({ ...this.props, name });
23
+ }
24
+ }
25
+ exports.default = ApimRootBuilder;
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpbVJvb3RCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL0J1aWxkZXIvQXBpbVJvb3RCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0EsNkRBQTBEO0FBQzFELGlFQUE4RDtBQVE5RCxNQUFxQixlQUFlO0lBQ047SUFBNUIsWUFBNEIsS0FBNEI7UUFBNUIsVUFBSyxHQUFMLEtBQUssQ0FBdUI7SUFBRyxDQUFDO0lBRXJELE1BQU0sQ0FBQyxJQUFJLENBQ2hCLFFBQXNCLEVBQ3RCLEtBQTJDO1FBRTNDLE9BQU8sSUFBSSxlQUFlLENBQUM7WUFDekIsR0FBRyxLQUFLO1lBQ1IsSUFBSSxFQUFFLFFBQVEsQ0FBQyxZQUFZO1lBQzNCLGVBQWUsRUFBRSxRQUFRLENBQUMsWUFBWTtZQUN0QyxLQUFLLEVBQUUsUUFBUSxDQUFDLEtBQUs7U0FDdEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVNLFVBQVUsQ0FBQyxJQUFZO1FBQzVCLE9BQU8sSUFBSSx1Q0FBa0IsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFTSxZQUFZLENBQUMsSUFBWTtRQUM5QixPQUFPLElBQUksMkNBQW9CLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMzRCxDQUFDO0NBQ0Y7QUF0QkQsa0NBc0JDIn0=
@@ -0,0 +1,10 @@
1
+ import { ResourceInfo } from "../types";
2
+ import { ApimChildBuilderProps, Builder, IApimWorkspaceBuilder } from "./types";
3
+ export declare class ApimWorkspaceBuilder extends Builder<ResourceInfo> implements IApimWorkspaceBuilder {
4
+ private props;
5
+ private _wpInstanceName;
6
+ private _wpInstance;
7
+ constructor(props: ApimChildBuilderProps);
8
+ private buildWp;
9
+ build(): ResourceInfo;
10
+ }