@gradientedge/cdk-utils 10.6.0 → 10.8.0

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 (200) hide show
  1. package/dist/app/api-destined-function/src/lib/lambda.d.ts +1 -0
  2. package/dist/app/api-destined-function/src/lib/lambda.d.ts.map +1 -0
  3. package/dist/app/api-destined-function/src/lib/lambda.js +1 -0
  4. package/dist/app/api-destined-function/src/lib/lambda.js.map +1 -0
  5. package/dist/app/api-destined-function/tsconfig.tsbuildinfo +1 -0
  6. package/dist/src/lib/aws/services/cloudwatch/main.d.ts +11 -11
  7. package/dist/src/lib/azure/common/constants.d.ts +74 -0
  8. package/dist/src/lib/azure/common/constants.js +77 -0
  9. package/dist/src/lib/azure/common/construct.d.ts +15 -3
  10. package/dist/src/lib/azure/common/construct.js +40 -4
  11. package/dist/src/lib/azure/common/stack.d.ts +3 -2
  12. package/dist/src/lib/azure/common/stack.js +25 -42
  13. package/dist/src/lib/azure/common/types.d.ts +13 -2
  14. package/dist/src/lib/azure/construct/event-handler/index.d.ts +2 -0
  15. package/dist/src/lib/azure/construct/event-handler/index.js +2 -0
  16. package/dist/src/lib/azure/construct/event-handler/main.d.ts +20 -0
  17. package/dist/src/lib/azure/construct/event-handler/main.js +139 -0
  18. package/dist/src/lib/azure/construct/event-handler/types.d.ts +35 -0
  19. package/dist/src/lib/azure/construct/event-handler/types.js +1 -0
  20. package/dist/src/lib/azure/construct/function-app/index.d.ts +2 -0
  21. package/dist/src/lib/azure/construct/function-app/index.js +2 -0
  22. package/dist/src/lib/azure/construct/function-app/main.d.ts +51 -0
  23. package/dist/src/lib/azure/construct/function-app/main.js +297 -0
  24. package/dist/src/lib/azure/construct/function-app/types.d.ts +33 -0
  25. package/dist/src/lib/azure/construct/function-app/types.js +1 -0
  26. package/dist/src/lib/azure/construct/index.d.ts +6 -0
  27. package/dist/src/lib/azure/construct/index.js +6 -0
  28. package/dist/src/lib/azure/construct/rest-api/index.d.ts +2 -0
  29. package/dist/src/lib/azure/construct/rest-api/index.js +2 -0
  30. package/dist/src/lib/azure/construct/rest-api/main.d.ts +20 -0
  31. package/dist/src/lib/azure/construct/rest-api/main.js +172 -0
  32. package/dist/src/lib/azure/construct/rest-api/types.d.ts +25 -0
  33. package/dist/src/lib/azure/construct/rest-api/types.js +1 -0
  34. package/dist/src/lib/azure/construct/rest-api-function/index.d.ts +2 -0
  35. package/dist/src/lib/azure/construct/rest-api-function/index.js +2 -0
  36. package/dist/src/lib/azure/construct/rest-api-function/main.d.ts +19 -0
  37. package/dist/src/lib/azure/construct/rest-api-function/main.js +255 -0
  38. package/dist/src/lib/azure/construct/rest-api-function/types.d.ts +29 -0
  39. package/dist/src/lib/azure/construct/rest-api-function/types.js +1 -0
  40. package/dist/src/lib/azure/construct/rest-api-with-cache/index.d.ts +2 -0
  41. package/dist/src/lib/azure/construct/rest-api-with-cache/index.js +2 -0
  42. package/dist/src/lib/azure/construct/rest-api-with-cache/main.d.ts +12 -0
  43. package/dist/src/lib/azure/construct/rest-api-with-cache/main.js +56 -0
  44. package/dist/src/lib/azure/construct/rest-api-with-cache/types.d.ts +13 -0
  45. package/dist/src/lib/azure/construct/rest-api-with-cache/types.js +1 -0
  46. package/dist/src/lib/azure/construct/site-with-webapp/index.d.ts +2 -0
  47. package/dist/src/lib/azure/construct/site-with-webapp/index.js +2 -0
  48. package/dist/src/lib/azure/construct/site-with-webapp/main.d.ts +19 -0
  49. package/dist/src/lib/azure/construct/site-with-webapp/main.js +135 -0
  50. package/dist/src/lib/azure/construct/site-with-webapp/types.d.ts +30 -0
  51. package/dist/src/lib/azure/construct/site-with-webapp/types.js +1 -0
  52. package/dist/src/lib/azure/index.d.ts +1 -0
  53. package/dist/src/lib/azure/index.js +1 -0
  54. package/dist/src/lib/azure/services/api-management/main.d.ts +83 -5
  55. package/dist/src/lib/azure/services/api-management/main.js +114 -148
  56. package/dist/src/lib/azure/services/api-management/types.d.ts +22 -1
  57. package/dist/src/lib/azure/services/app-configuration/main.d.ts +13 -1
  58. package/dist/src/lib/azure/services/app-configuration/main.js +21 -2
  59. package/dist/src/lib/azure/services/app-service/main.d.ts +5 -2
  60. package/dist/src/lib/azure/services/app-service/main.js +12 -4
  61. package/dist/src/lib/azure/services/application-insights/main.d.ts +15 -4
  62. package/dist/src/lib/azure/services/application-insights/main.js +27 -6
  63. package/dist/src/lib/azure/services/application-insights/types.d.ts +4 -1
  64. package/dist/src/lib/azure/services/authorisation/constants.d.ts +13 -0
  65. package/dist/src/lib/azure/services/authorisation/constants.js +14 -0
  66. package/dist/src/lib/azure/services/authorisation/index.d.ts +3 -0
  67. package/dist/src/lib/azure/services/authorisation/index.js +3 -0
  68. package/dist/src/lib/azure/services/authorisation/main.d.ts +84 -0
  69. package/dist/src/lib/azure/services/authorisation/main.js +120 -0
  70. package/dist/src/lib/azure/services/authorisation/types.d.ts +3 -0
  71. package/dist/src/lib/azure/services/authorisation/types.js +1 -0
  72. package/dist/src/lib/azure/services/cosmosdb/constants.d.ts +8 -0
  73. package/dist/src/lib/azure/services/cosmosdb/constants.js +10 -0
  74. package/dist/src/lib/azure/services/cosmosdb/index.d.ts +1 -0
  75. package/dist/src/lib/azure/services/cosmosdb/index.js +1 -0
  76. package/dist/src/lib/azure/services/cosmosdb/main.d.ts +47 -5
  77. package/dist/src/lib/azure/services/cosmosdb/main.js +77 -8
  78. package/dist/src/lib/azure/services/cosmosdb/types.d.ts +3 -1
  79. package/dist/src/lib/azure/services/dns/main.d.ts +9 -4
  80. package/dist/src/lib/azure/services/dns/main.js +12 -8
  81. package/dist/src/lib/azure/services/eventgrid/main.d.ts +12 -7
  82. package/dist/src/lib/azure/services/eventgrid/main.js +18 -19
  83. package/dist/src/lib/azure/services/function/main.d.ts +16 -3
  84. package/dist/src/lib/azure/services/function/main.js +122 -8
  85. package/dist/src/lib/azure/services/function/types.d.ts +3 -4
  86. package/dist/src/lib/azure/services/index.d.ts +3 -0
  87. package/dist/src/lib/azure/services/index.js +3 -0
  88. package/dist/src/lib/azure/services/key-vault/main.d.ts +22 -2
  89. package/dist/src/lib/azure/services/key-vault/main.js +28 -3
  90. package/dist/src/lib/azure/services/key-vault/types.d.ts +3 -2
  91. package/dist/src/lib/azure/services/monitor/main.d.ts +3 -1
  92. package/dist/src/lib/azure/services/monitor/main.js +3 -2
  93. package/dist/src/lib/azure/services/operational-insights/main.d.ts +13 -2
  94. package/dist/src/lib/azure/services/operational-insights/main.js +17 -3
  95. package/dist/src/lib/azure/services/operational-insights/types.d.ts +3 -1
  96. package/dist/src/lib/azure/services/portal/error.d.ts +5 -0
  97. package/dist/src/lib/azure/services/portal/error.js +10 -0
  98. package/dist/src/lib/azure/services/portal/index.d.ts +4 -0
  99. package/dist/src/lib/azure/services/portal/index.js +4 -0
  100. package/dist/src/lib/azure/services/portal/main.d.ts +33 -0
  101. package/dist/src/lib/azure/services/portal/main.js +51 -0
  102. package/dist/src/lib/azure/services/portal/renderer.d.ts +11 -0
  103. package/dist/src/lib/azure/services/portal/renderer.js +156 -0
  104. package/dist/src/lib/azure/services/portal/types.d.ts +40 -0
  105. package/dist/src/lib/azure/services/portal/types.js +1 -0
  106. package/dist/src/lib/azure/services/redis/main.d.ts +4 -2
  107. package/dist/src/lib/azure/services/redis/main.js +3 -2
  108. package/dist/src/lib/azure/services/redis/types.d.ts +1 -1
  109. package/dist/src/lib/azure/services/resource-group/main.d.ts +10 -1
  110. package/dist/src/lib/azure/services/resource-group/main.js +17 -3
  111. package/dist/src/lib/azure/services/security-center/index.d.ts +2 -0
  112. package/dist/src/lib/azure/services/security-center/index.js +2 -0
  113. package/dist/src/lib/azure/services/security-center/main.d.ts +31 -0
  114. package/dist/src/lib/azure/services/security-center/main.js +33 -0
  115. package/dist/src/lib/azure/services/security-center/types.d.ts +3 -0
  116. package/dist/src/lib/azure/services/security-center/types.js +1 -0
  117. package/dist/src/lib/azure/services/servicebus/main.d.ts +28 -22
  118. package/dist/src/lib/azure/services/servicebus/main.js +31 -26
  119. package/dist/src/lib/azure/services/servicebus/types.d.ts +4 -4
  120. package/dist/src/lib/azure/services/storage/main.d.ts +26 -5
  121. package/dist/src/lib/azure/services/storage/main.js +51 -9
  122. package/dist/src/lib/azure/services/storage/types.d.ts +7 -2
  123. package/dist/src/lib/cloudflare/common/construct.js +1 -1
  124. package/dist/src/lib/cloudflare/common/stack.d.ts +2 -2
  125. package/dist/src/lib/cloudflare/common/stack.js +25 -25
  126. package/dist/src/lib/cloudflare/services/worker/main.js +8 -1
  127. package/dist/src/lib/cloudflare/services/worker/types.d.ts +1 -0
  128. package/package.json +26 -23
  129. package/src/lib/azure/common/constants.ts +83 -0
  130. package/src/lib/azure/common/construct.ts +50 -7
  131. package/src/lib/azure/common/stack.ts +26 -43
  132. package/src/lib/azure/common/types.ts +14 -2
  133. package/src/lib/azure/construct/event-handler/index.ts +2 -0
  134. package/src/lib/azure/construct/event-handler/main.ts +183 -0
  135. package/src/lib/azure/construct/event-handler/types.ts +49 -0
  136. package/src/lib/azure/construct/function-app/index.ts +2 -0
  137. package/src/lib/azure/construct/function-app/main.ts +410 -0
  138. package/src/lib/azure/construct/function-app/types.ts +45 -0
  139. package/src/lib/azure/construct/index.ts +6 -0
  140. package/src/lib/azure/construct/rest-api/index.ts +2 -0
  141. package/src/lib/azure/construct/rest-api/main.ts +205 -0
  142. package/src/lib/azure/construct/rest-api/types.ts +33 -0
  143. package/src/lib/azure/construct/rest-api-function/index.ts +2 -0
  144. package/src/lib/azure/construct/rest-api-function/main.ts +297 -0
  145. package/src/lib/azure/construct/rest-api-function/types.ts +39 -0
  146. package/src/lib/azure/construct/rest-api-with-cache/index.ts +2 -0
  147. package/src/lib/azure/construct/rest-api-with-cache/main.ts +75 -0
  148. package/src/lib/azure/construct/rest-api-with-cache/types.ts +15 -0
  149. package/src/lib/azure/construct/site-with-webapp/index.ts +2 -0
  150. package/src/lib/azure/construct/site-with-webapp/main.ts +160 -0
  151. package/src/lib/azure/construct/site-with-webapp/types.ts +33 -0
  152. package/src/lib/azure/index.ts +1 -0
  153. package/src/lib/azure/services/api-management/main.ts +168 -152
  154. package/src/lib/azure/services/api-management/types.ts +30 -1
  155. package/src/lib/azure/services/app-configuration/main.ts +29 -2
  156. package/src/lib/azure/services/app-service/main.ts +23 -4
  157. package/src/lib/azure/services/application-insights/main.ts +46 -7
  158. package/src/lib/azure/services/application-insights/types.ts +6 -2
  159. package/src/lib/azure/services/authorisation/constants.ts +13 -0
  160. package/src/lib/azure/services/authorisation/index.ts +3 -0
  161. package/src/lib/azure/services/authorisation/main.ts +202 -0
  162. package/src/lib/azure/services/authorisation/types.ts +3 -0
  163. package/src/lib/azure/services/cosmosdb/constants.ts +9 -0
  164. package/src/lib/azure/services/cosmosdb/index.ts +1 -0
  165. package/src/lib/azure/services/cosmosdb/main.ts +158 -8
  166. package/src/lib/azure/services/cosmosdb/types.ts +3 -0
  167. package/src/lib/azure/services/dns/main.ts +33 -8
  168. package/src/lib/azure/services/eventgrid/main.ts +41 -23
  169. package/src/lib/azure/services/function/main.ts +155 -9
  170. package/src/lib/azure/services/function/types.ts +3 -4
  171. package/src/lib/azure/services/index.ts +3 -0
  172. package/src/lib/azure/services/key-vault/main.ts +47 -4
  173. package/src/lib/azure/services/key-vault/types.ts +4 -4
  174. package/src/lib/azure/services/monitor/main.ts +5 -2
  175. package/src/lib/azure/services/operational-insights/main.ts +30 -4
  176. package/src/lib/azure/services/operational-insights/types.ts +3 -1
  177. package/src/lib/azure/services/portal/error.ts +12 -0
  178. package/src/lib/azure/services/portal/index.ts +4 -0
  179. package/src/lib/azure/services/portal/main.ts +81 -0
  180. package/src/lib/azure/services/portal/renderer.ts +182 -0
  181. package/src/lib/azure/services/portal/types.ts +45 -0
  182. package/src/lib/azure/services/redis/main.ts +10 -3
  183. package/src/lib/azure/services/redis/types.ts +1 -1
  184. package/src/lib/azure/services/resource-group/main.ts +34 -3
  185. package/src/lib/azure/services/security-center/index.ts +2 -0
  186. package/src/lib/azure/services/security-center/main.ts +42 -0
  187. package/src/lib/azure/services/security-center/types.ts +3 -0
  188. package/src/lib/azure/services/servicebus/main.ts +61 -30
  189. package/src/lib/azure/services/servicebus/types.ts +4 -4
  190. package/src/lib/azure/services/storage/main.ts +91 -9
  191. package/src/lib/azure/services/storage/types.ts +11 -2
  192. package/src/lib/cloudflare/common/construct.ts +1 -1
  193. package/src/lib/cloudflare/common/stack.ts +25 -25
  194. package/src/lib/cloudflare/services/worker/main.ts +10 -1
  195. package/src/lib/cloudflare/services/worker/types.ts +8 -1
  196. package/dist/lib/lambda.d.ts +0 -17
  197. package/dist/lib/lambda.d.ts.map +0 -1
  198. package/dist/lib/lambda.js +0 -28
  199. package/dist/lib/lambda.js.map +0 -1
  200. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,139 @@
1
+ import { Provider } from '@pulumi/azure-native';
2
+ import { getTopicOutput } from '@pulumi/azure-native/eventgrid/index.js';
3
+ import { AzureFunctionApp } from '../function-app/index.js';
4
+ export class AzureEventHandler extends AzureFunctionApp {
5
+ props;
6
+ eventGridEventSubscription;
7
+ eventGridTopic;
8
+ serviceBus;
9
+ constructor(id, props) {
10
+ super(id, props);
11
+ this.props = props;
12
+ this.id = id;
13
+ }
14
+ initResources() {
15
+ this.createResourceGroup();
16
+ this.resolveCommonLogAnalyticsWorkspace();
17
+ this.resolveApplicationInsights();
18
+ this.createEventGridSubscriptionDlqStorageAccount();
19
+ this.createEventGridSubscriptionDlqStorageContainer();
20
+ this.createServiceBusNamespace();
21
+ this.createServiceBusQueue();
22
+ this.createEventGrid();
23
+ this.createEventGridEventSubscription();
24
+ this.createServiceBusDiagnosticLog();
25
+ this.enableMalwareScanningOnDataStorageAccount();
26
+ super.initResources();
27
+ }
28
+ createEventGridSubscriptionDlqStorageAccount() {
29
+ this.eventGridEventSubscription.dlqStorageAccount = this.storageManager.createStorageAccount(`${this.id}-eventgrid-subscription-dlq-storage-account`, this, {
30
+ ...this.props.eventGridSubscription.dlqStorageAccount,
31
+ resourceGroupName: this.resourceGroup.name,
32
+ location: this.resourceGroup.location,
33
+ });
34
+ }
35
+ createEventGridSubscriptionDlqStorageContainer() {
36
+ this.eventGridEventSubscription.dlqStorageContainer = this.storageManager.createStorageContainer(`${this.id}-eventgrid-subscription-dlq-container`, this, {
37
+ ...this.props.eventGridSubscription.dlqStorageContainer,
38
+ accountName: this.eventGridEventSubscription.dlqStorageAccount.name,
39
+ containerName: 'eventgrid-subscription-dlq-container',
40
+ resourceGroupName: this.resourceGroup.name,
41
+ });
42
+ }
43
+ createServiceBusNamespace() {
44
+ this.serviceBus.namespace = this.serviceBusManager.createServiceBusNamespace(this.id, this, {
45
+ ...this.props.serviceBus.namespace,
46
+ namespaceName: this.props.serviceBus.namespace.namespaceName ?? this.id,
47
+ resourceGroupName: this.resourceGroup.name,
48
+ }, { ignoreChanges: ['location'] });
49
+ this.registerOutputs({
50
+ serviceBusNamespaceId: this.serviceBus.namespace.id,
51
+ });
52
+ }
53
+ createServiceBusQueue() {
54
+ this.serviceBus.queue = this.serviceBusManager.createServiceBusQueue(this.id, this, {
55
+ ...this.props.serviceBus.queue,
56
+ queueName: this.props.serviceBus.queue.queueName ?? this.id,
57
+ namespaceName: this.serviceBus.namespace.name,
58
+ });
59
+ this.registerOutputs({
60
+ serviceBusQueueId: this.serviceBus.queue.id,
61
+ serviceBusQueueName: this.serviceBus.queue.name,
62
+ });
63
+ }
64
+ createEventGrid() {
65
+ if (!this.props.eventGridTopic.useExistingTopic) {
66
+ this.eventGridTopic = this.eventgridManager.createEventgridTopic(this.id, this, {
67
+ ...this.props.eventGridTopic,
68
+ topicName: this.props.eventGridTopic.topicName ?? this.id,
69
+ location: this.resourceGroup.location,
70
+ resourceGroupName: this.resourceGroup.name,
71
+ }, { protect: true, ignoreChanges: ['location'] });
72
+ return;
73
+ }
74
+ const existingSubscriptionId = this.props.eventGridTopic.existingSubscriptionId;
75
+ const existingTopicName = this.props.eventGridTopic.existingTopicName;
76
+ const existingResourceGroupName = this.props.eventGridTopic.existingResourceGroupName;
77
+ let provider;
78
+ if (existingSubscriptionId) {
79
+ provider = new Provider(`${this.id}-${existingSubscriptionId}`, {
80
+ subscriptionId: existingSubscriptionId,
81
+ });
82
+ }
83
+ if (existingResourceGroupName && existingTopicName) {
84
+ this.eventGridTopic = getTopicOutput({
85
+ topicName: existingTopicName,
86
+ resourceGroupName: existingResourceGroupName,
87
+ }, { provider });
88
+ }
89
+ }
90
+ createEventGridEventSubscription() {
91
+ this.eventGridEventSubscription.eventSubscription = this.eventgridManager.createEventgridSubscription(this.id, this, {
92
+ ...this.props.eventGridEventSubscription,
93
+ eventSubscriptionName: this.props.eventGridEventSubscription.eventSubscriptionName ?? this.id,
94
+ scope: this.eventGridTopic.id,
95
+ destination: {
96
+ endpointType: 'ServiceBusQueue',
97
+ resourceId: this.serviceBus.queue.id,
98
+ },
99
+ deadLetterDestination: {
100
+ blobContainerName: this.eventGridEventSubscription.dlqStorageContainer.name,
101
+ endpointType: 'StorageBlob',
102
+ resourceId: this.eventGridEventSubscription.dlqStorageAccount.id,
103
+ },
104
+ }, { dependsOn: [this.eventGridTopic] });
105
+ }
106
+ createServiceBusDiagnosticLog() {
107
+ this.monitorManager.createMonitorDiagnosticSettings(this.id, this, {
108
+ name: `${this.props.stackName}-servicebus`,
109
+ resourceUri: this.serviceBus.namespace.id,
110
+ workspaceId: this.commonLogAnalyticsWorkspace.id,
111
+ logAnalyticsDestinationType: 'Dedicated',
112
+ logs: [
113
+ {
114
+ categoryGroup: 'allLogs',
115
+ enabled: true,
116
+ },
117
+ ],
118
+ metrics: [
119
+ {
120
+ category: 'AllMetrics',
121
+ enabled: true,
122
+ },
123
+ ],
124
+ });
125
+ }
126
+ enableMalwareScanningOnDataStorageAccount() {
127
+ if (!this.props.defender)
128
+ return;
129
+ this.securityCentermanager.createDefenderForStorage(`${this.id}-data-storage-defender`, this, {
130
+ ...this.props.defender,
131
+ resourceId: this.dataStorageAccount.id,
132
+ properties: {
133
+ malwareScanning: {
134
+ scanResultsEventGridTopicResourceId: this.eventGridTopic.id,
135
+ },
136
+ },
137
+ });
138
+ }
139
+ }
@@ -0,0 +1,35 @@
1
+ import { EventSubscription } from '@pulumi/azure-native/eventgrid/index.js';
2
+ import { Namespace, Queue } from '@pulumi/azure-native/servicebus/index.js';
3
+ import { BlobContainer, StorageAccount } from '@pulumi/azure-native/storage/index.js';
4
+ import { DefenderForStorageProps, EventgridEventSubscriptionProps, EventgridTopicProps, ServiceBusNamespaceProps, ServiceBusQueueProps, StorageAccountProps, StorageContainerProps } from '../../services/index.js';
5
+ import { AzureFunctionAppProps } from '../function-app/index.js';
6
+ export interface EventHandlerEventGridSubscriptionProps {
7
+ dlqStorageAccount: StorageAccountProps;
8
+ dlqStorageContainer: StorageContainerProps;
9
+ }
10
+ export interface EventHandlerEventGridSubscription {
11
+ dlqStorageAccount: StorageAccount;
12
+ dlqStorageContainer: BlobContainer;
13
+ eventSubscription: EventSubscription;
14
+ }
15
+ export interface EventHandlerServiceBusProps {
16
+ namespace: ServiceBusNamespaceProps;
17
+ queue: ServiceBusQueueProps;
18
+ }
19
+ export interface EventHandlerServiceBus {
20
+ namespace: Namespace;
21
+ queue: Queue;
22
+ }
23
+ export interface EventHandlerEventGridTopicProps extends EventgridTopicProps {
24
+ useExistingTopic: boolean;
25
+ existingSubscriptionId?: string;
26
+ existingTopicName?: string;
27
+ existingResourceGroupName?: string;
28
+ }
29
+ export interface AzureEventHandlerProps extends AzureFunctionAppProps {
30
+ defender?: DefenderForStorageProps;
31
+ eventGridEventSubscription: EventgridEventSubscriptionProps;
32
+ eventGridSubscription: EventHandlerEventGridSubscriptionProps;
33
+ eventGridTopic: EventHandlerEventGridTopicProps;
34
+ serviceBus: EventHandlerServiceBusProps;
35
+ }
@@ -0,0 +1,2 @@
1
+ export * from './main.js';
2
+ export * from './types.js';
@@ -0,0 +1,2 @@
1
+ export * from './main.js';
2
+ export * from './types.js';
@@ -0,0 +1,51 @@
1
+ import * as archive from '@pulumi/archive';
2
+ import { ConfigurationStore, GetConfigurationStoreResult } from '@pulumi/azure-native/appconfiguration/index.js';
3
+ import { GetComponentResult } from '@pulumi/azure-native/applicationinsights/index.js';
4
+ import { Dashboard } from '@pulumi/azure-native/portal/index.js';
5
+ import { BlobContainer, StorageAccount } from '@pulumi/azure-native/storage/index.js';
6
+ import { AppServicePlan, WebApp } from '@pulumi/azure-native/web/index.js';
7
+ import { Output, ResourceOptions } from '@pulumi/pulumi';
8
+ import { CommonAzureConstruct } from '../../common/index.js';
9
+ import { AzureFunctionAppProps } from './types.js';
10
+ export declare class AzureFunctionApp extends CommonAzureConstruct {
11
+ props: AzureFunctionAppProps;
12
+ app: WebApp;
13
+ appServicePlan: AppServicePlan;
14
+ appEnvironmentVariables: Record<string, any>;
15
+ appStorageAccount: StorageAccount;
16
+ appDeploymentStorageContainer: BlobContainer;
17
+ appStorageContainer: BlobContainer;
18
+ appConfig: ConfigurationStore | Output<GetConfigurationStoreResult>;
19
+ appCodeArchiveFile: Output<archive.GetFileResult>;
20
+ appConfigHash: string;
21
+ appKeyVaultsByResourceGroup: Map<string, Set<string>>;
22
+ appConnectionStrings: any[];
23
+ appConfigPrefix?: string;
24
+ appConfigurationsParsedConfig: any;
25
+ appConfigurationsOriginalParsedConfig: any;
26
+ dataStorageAccount: StorageAccount;
27
+ dataStorageContainer: BlobContainer;
28
+ applicationInsights: Output<GetComponentResult>;
29
+ functionDashboard: Dashboard;
30
+ constructor(id: string, props: AzureFunctionAppProps);
31
+ initResources(): void;
32
+ protected resolveApplicationInsights(): void;
33
+ protected createAppServicePlan(): void;
34
+ protected createdParsedAppConfigurations(): void;
35
+ protected createAppConfiguration(): void;
36
+ protected createAppConfigurations(): void;
37
+ protected createStorageAccount(): void;
38
+ protected createStorageDeploymentContainer(): void;
39
+ protected createStorageContainer(): void;
40
+ protected createDataStorageAccount(): void;
41
+ protected createDataStorageContainer(): void;
42
+ protected generateStorageContainerSas(): void;
43
+ protected createFunctionHosts(): void;
44
+ protected createCodePackage(): void;
45
+ protected createFunctionAppSiteConfig(): void;
46
+ protected createFunctionApp(resourceOptions?: ResourceOptions): void;
47
+ protected getFunctionAppPrincipalId(): Output<string>;
48
+ protected createRoleAssignments(): void;
49
+ protected dashboardVariables(): Record<string, any>;
50
+ protected createFunctionDashboard(): void;
51
+ }
@@ -0,0 +1,297 @@
1
+ import * as archive from '@pulumi/archive';
2
+ import { getConfigurationStoreOutput, } from '@pulumi/azure-native/appconfiguration/index.js';
3
+ import { getComponentOutput } from '@pulumi/azure-native/applicationinsights/index.js';
4
+ import { SkuFamily, SkuName } from '@pulumi/azure-native/keyvault/index.js';
5
+ import { listStorageAccountKeysOutput } from '@pulumi/azure-native/storage/index.js';
6
+ import { AuthenticationType, FunctionsDeploymentStorageType, } from '@pulumi/azure-native/web/index.js';
7
+ import * as pulumi from '@pulumi/pulumi';
8
+ import fs from 'fs';
9
+ import _ from 'lodash';
10
+ import * as path from 'path';
11
+ import { CommonAzureConstruct } from '../../common/index.js';
12
+ import { CosmosRoleDefinition } from '../../services/cosmosdb/constants.js';
13
+ import { AzureAppConfigurationManager, RoleDefinitionId } from '../../services/index.js';
14
+ export class AzureFunctionApp extends CommonAzureConstruct {
15
+ props;
16
+ app;
17
+ appServicePlan;
18
+ appEnvironmentVariables = {};
19
+ appStorageAccount;
20
+ appDeploymentStorageContainer;
21
+ appStorageContainer;
22
+ appConfig;
23
+ appCodeArchiveFile;
24
+ appConfigHash;
25
+ appKeyVaultsByResourceGroup;
26
+ appConnectionStrings;
27
+ appConfigPrefix;
28
+ appConfigurationsParsedConfig;
29
+ appConfigurationsOriginalParsedConfig;
30
+ dataStorageAccount;
31
+ dataStorageContainer;
32
+ applicationInsights;
33
+ functionDashboard;
34
+ constructor(id, props) {
35
+ super(id, props);
36
+ this.props = props;
37
+ this.id = id;
38
+ }
39
+ initResources() {
40
+ this.createResourceGroup();
41
+ this.resolveCommonLogAnalyticsWorkspace();
42
+ this.resolveApplicationInsights();
43
+ this.createAppServicePlan();
44
+ this.createdParsedAppConfigurations();
45
+ this.createAppConfiguration();
46
+ this.createAppConfigurations();
47
+ this.createStorageAccount();
48
+ this.createStorageDeploymentContainer();
49
+ this.createStorageContainer();
50
+ this.createDataStorageAccount();
51
+ this.createDataStorageContainer();
52
+ this.generateStorageContainerSas();
53
+ this.createFunctionHosts();
54
+ this.createCodePackage();
55
+ this.createFunctionAppSiteConfig();
56
+ this.createFunctionApp();
57
+ this.createRoleAssignments();
58
+ this.createFunctionDashboard();
59
+ }
60
+ resolveApplicationInsights() {
61
+ if (!this.props.commonApplicationInsights || !this.props.commonApplicationInsights.resourceName)
62
+ return;
63
+ this.applicationInsights = getComponentOutput({
64
+ resourceName: this.props.commonApplicationInsights.resourceName,
65
+ resourceGroupName: this.props.commonApplicationInsights.resourceGroupName,
66
+ });
67
+ }
68
+ createAppServicePlan() {
69
+ this.appServicePlan = this.appServiceManager.createAppServicePlan(`${this.id}-app-service-plan`, this, {
70
+ ...this.props.functionApp.servicePlan,
71
+ name: this.id,
72
+ resourceGroupName: this.resourceGroup.name,
73
+ location: this.resourceGroup.location,
74
+ });
75
+ }
76
+ createdParsedAppConfigurations() { }
77
+ createAppConfiguration() {
78
+ if (this.props.functionApp.appConfiguration) {
79
+ this.appConfig = this.appConfigurationManager.createConfigurationStore(`${this.id}-app-configuration`, this, {
80
+ ...this.props.functionApp.appConfiguration,
81
+ resourceGroupName: this.resourceGroup.name,
82
+ location: this.resourceGroup.location,
83
+ });
84
+ }
85
+ else if (!this.props.useConfigOverride) {
86
+ this.appConfig = getConfigurationStoreOutput({
87
+ configStoreName: this.props.existingConfigStoreName,
88
+ resourceGroupName: this.props.existingConfigStoreResourceGroupName,
89
+ });
90
+ }
91
+ this.appConfigPrefix = _.camelCase(this.id);
92
+ }
93
+ createAppConfigurations() { }
94
+ createStorageAccount() {
95
+ this.appStorageAccount = this.storageManager.createStorageAccount(`${this.id}-storage-account`, this, {
96
+ ...this.props.functionApp.storageAccount,
97
+ location: this.resourceGroup.location,
98
+ resourceGroupName: this.resourceGroup.name,
99
+ });
100
+ }
101
+ createStorageDeploymentContainer() {
102
+ this.appDeploymentStorageContainer = this.storageManager.createStorageContainer(`${this.id}-storage-deployment-container`, this, {
103
+ ...this.props.functionApp.deploymentStorageContainer,
104
+ accountName: this.appStorageAccount.name,
105
+ resourceGroupName: this.resourceGroup.name,
106
+ });
107
+ }
108
+ createStorageContainer() {
109
+ if (!this.props.functionApp.storageContainer)
110
+ return;
111
+ this.appStorageContainer = this.storageManager.createStorageContainer(`${this.id}-storage-container`, this, {
112
+ ...this.props.functionApp.storageContainer,
113
+ accountName: this.appStorageAccount.name,
114
+ resourceGroupName: this.resourceGroup.name,
115
+ });
116
+ this.appEnvironmentVariables = {
117
+ ...this.appEnvironmentVariables,
118
+ AZURE_STORAGE_ACCOUNT_NAME: this.appStorageAccount.name,
119
+ };
120
+ }
121
+ createDataStorageAccount() {
122
+ if (!this.props.dataStorageAccount)
123
+ return;
124
+ this.dataStorageAccount = this.storageManager.createStorageAccount(`${this.id}-data-storage-account`, this, {
125
+ ...this.props.dataStorageAccount,
126
+ resourceGroupName: this.resourceGroup.name,
127
+ location: this.resourceGroup.location,
128
+ });
129
+ this.appEnvironmentVariables = {
130
+ ...this.appEnvironmentVariables,
131
+ AZURE_STORAGE_ACCOUNT_NAME: this.dataStorageAccount.name,
132
+ };
133
+ }
134
+ createDataStorageContainer() {
135
+ if (!this.props.dataStorageContainer)
136
+ return;
137
+ this.dataStorageContainer = this.storageManager.createStorageContainer(`${this.id}-data-storage-container`, this, {
138
+ ...this.props.dataStorageContainer,
139
+ accountName: this.dataStorageAccount.name,
140
+ resourceGroupName: this.resourceGroup.name,
141
+ });
142
+ }
143
+ generateStorageContainerSas() {
144
+ if (!this.props.dataStorageContainerSas)
145
+ return;
146
+ const sasToken = this.storageManager.generateContainerSasToken(`${this.id}-storage-container`, this, this.props.dataStorageContainerSas, this.dataStorageAccount);
147
+ const keyVault = this.keyVaultManager.createKeyVault(`${this.id}`, this, {
148
+ vaultName: this.props.dataKeyVaultName,
149
+ location: this.resourceGroup.location,
150
+ resourceGroupName: this.resourceGroup.name,
151
+ properties: {
152
+ sku: {
153
+ name: SkuName.Standard,
154
+ family: SkuFamily.A,
155
+ },
156
+ tenantId: this.props.tenantId ?? '',
157
+ },
158
+ }, { ignoreChanges: ['location'] });
159
+ this.monitorManager.createMonitorDiagnosticSettings(`${this.id}-${this.props.dataKeyVaultName}`, this, {
160
+ name: `${this.props.dataKeyVaultName}-keyvault`,
161
+ resourceUri: keyVault.id,
162
+ workspaceId: this.commonLogAnalyticsWorkspace.id,
163
+ logAnalyticsDestinationType: 'Dedicated',
164
+ logs: [
165
+ {
166
+ categoryGroup: 'allLogs',
167
+ enabled: true,
168
+ },
169
+ ],
170
+ metrics: [
171
+ {
172
+ category: 'AllMetrics',
173
+ enabled: true,
174
+ },
175
+ ],
176
+ });
177
+ this.keyVaultManager.createKeyVaultSecret(`${this.id}-sas-token-secret`, this, {
178
+ vaultName: keyVault.name,
179
+ secretName: this.props.dataKeyVaultSecretName,
180
+ resourceGroupName: this.resourceGroup.name,
181
+ properties: {
182
+ value: sasToken,
183
+ },
184
+ });
185
+ }
186
+ createFunctionHosts() {
187
+ const currentDirectory = path.resolve();
188
+ const hostsJsonFile = `${currentDirectory}/${this.props.functionApp.deploySource}/host.json`;
189
+ if (!fs.existsSync(hostsJsonFile))
190
+ return;
191
+ const sourceHostsConfig = JSON.parse(fs.readFileSync(hostsJsonFile).toString('utf-8'));
192
+ const hostsConfig = _.merge(sourceHostsConfig, this.props.hostsConfiguration, this.props.functionApp.hostsConfiguration);
193
+ fs.writeFileSync(hostsJsonFile, JSON.stringify(hostsConfig, null, 2));
194
+ }
195
+ createCodePackage() {
196
+ const currentDirectory = path.resolve();
197
+ this.appCodeArchiveFile = archive.getFileOutput({
198
+ type: 'zip',
199
+ sourceDir: `${currentDirectory}/${this.props.functionApp.deploySource}`,
200
+ outputPath: `${currentDirectory}/${this.props.functionApp.deploySource}/${this.props.functionApp.packageName}`,
201
+ excludes: ['*.zip'],
202
+ });
203
+ }
204
+ createFunctionAppSiteConfig() { }
205
+ createFunctionApp(resourceOptions) {
206
+ this.app = this.functionManager.createFunctionAppFlexConsumption(`${this.id}-function-app-flex`, this, {
207
+ ...this.props.functionApp,
208
+ name: this.props.functionApp.app.name ?? this.id,
209
+ serverFarmId: this.appServicePlan.id,
210
+ resourceGroupName: this.resourceGroup.name,
211
+ functionAppConfig: {
212
+ deployment: {
213
+ storage: {
214
+ type: FunctionsDeploymentStorageType.BlobContainer,
215
+ value: pulumi.interpolate `${this.appStorageAccount.primaryEndpoints.apply(e => e?.blob)}${this.appDeploymentStorageContainer.name}`,
216
+ authentication: {
217
+ type: AuthenticationType.StorageAccountConnectionString,
218
+ storageAccountConnectionStringName: 'AzureWebJobsStorage',
219
+ },
220
+ },
221
+ },
222
+ },
223
+ siteConfig: {
224
+ appSettings: [
225
+ ..._.map(this.appEnvironmentVariables, (value, name) => ({ name, value })),
226
+ {
227
+ name: 'APPLICATIONINSIGHTS_CONNECTION_STRING',
228
+ value: this.applicationInsights.connectionString,
229
+ },
230
+ {
231
+ name: 'APPINSIGHTS_INSTRUMENTATIONKEY',
232
+ value: this.applicationInsights.instrumentationKey,
233
+ },
234
+ {
235
+ name: 'AzureWebJobsStorage',
236
+ value: pulumi.interpolate `DefaultEndpointsProtocol=https;AccountName=${this.appStorageAccount.name};AccountKey=${listStorageAccountKeysOutput({
237
+ resourceGroupName: this.resourceGroup.name,
238
+ accountName: this.appStorageAccount.name,
239
+ }).keys[0].value};EndpointSuffix=core.windows.net`,
240
+ },
241
+ ],
242
+ connectionStrings: Object.fromEntries(this.appConnectionStrings.map(cs => [cs.name, { type: cs.type, value: cs.value }])),
243
+ },
244
+ httpsOnly: this.props.functionApp.app.httpsOnly ?? true,
245
+ }, { ...resourceOptions });
246
+ }
247
+ getFunctionAppPrincipalId() {
248
+ return this.app.identity.apply(identity => (identity?.principalId ? identity.principalId : ''));
249
+ }
250
+ createRoleAssignments() {
251
+ if (this.props.dataStorageAccount) {
252
+ this.authorisationManager.grantRoleAssignmentToStorageAccount(`${this.id}-data`, this, this.dataStorageAccount.id, this.getFunctionAppPrincipalId(), RoleDefinitionId.STORAGE_BLOB_DATA_CONTRIBUTOR);
253
+ }
254
+ this.authorisationManager.grantRoleAssignmentToStorageAccount(this.id, this, this.appStorageAccount.id, this.getFunctionAppPrincipalId(), RoleDefinitionId.STORAGE_BLOB_DATA_CONTRIBUTOR);
255
+ if (!this.props.useConfigOverride) {
256
+ this.authorisationManager.grantRoleAssignmentToApplicationConfiguration(this.id, this, this.appConfig.id, this.getFunctionAppPrincipalId(), RoleDefinitionId.APP_CONFIGURATION_DATA_READER);
257
+ }
258
+ if (this.appConfigurationsParsedConfig &&
259
+ AzureAppConfigurationManager.hasCosmosDependencies(this.appConfigurationsParsedConfig)) {
260
+ this.cosmosDbManager.grantSqlRoleDefinitionToAccount(this.id, this, this.props.existingCosmosAccountName, this.props.existingCosmosAccountResourceGroupName, this.getFunctionAppPrincipalId(), [CosmosRoleDefinition.CONTRIBUTOR, CosmosRoleDefinition.READER]);
261
+ }
262
+ if (this.appKeyVaultsByResourceGroup && this.appKeyVaultsByResourceGroup.size > 0) {
263
+ this.appKeyVaultsByResourceGroup.forEach((keyVaultNames, resourceGroup) => {
264
+ keyVaultNames.forEach(keyVaultName => {
265
+ this.authorisationManager.grantRoleAssignmentToKeyVault(this.id, this, keyVaultName, resourceGroup, this.getFunctionAppPrincipalId(), RoleDefinitionId.KEY_VAULT_SECRETS_USER);
266
+ });
267
+ });
268
+ }
269
+ if (AzureAppConfigurationManager.hasEventGridTargets(this.appConfigurationsParsedConfig)) {
270
+ this.authorisationManager.grantRoleAssignmentToEventgridTopic(this.id, this, this.props.existingTopicName, this.props.existingTopicResourceGroupName, this.getFunctionAppPrincipalId(), RoleDefinitionId.EVENTGRID_DATA_SENDER);
271
+ }
272
+ }
273
+ dashboardVariables() {
274
+ return {
275
+ displayName: this.props.functionApp.dashboard.displayName,
276
+ name: this.id,
277
+ subscriptionId: this.props.subscriptionId,
278
+ functionAppName: this.app.name,
279
+ functionAppResourceGroupName: this.resourceGroup.name,
280
+ insightsAppName: this.applicationInsights.name,
281
+ insightsAppResourceGroupName: this.props.commonLogAnalyticsWorkspace?.resourceGroupName,
282
+ };
283
+ }
284
+ createFunctionDashboard() {
285
+ if (!this.props.functionApp.dashboard?.enabled)
286
+ return;
287
+ this.functionDashboard = this.portalManager.createDashBoard(`${this.id}-dsh`, this, {
288
+ displayName: this.props.functionApp.dashboard.displayName,
289
+ location: this.props.locationConfig?.[this.props.location].name,
290
+ dashboardName: this.id,
291
+ resourceGroupName: this.resourceGroup.name,
292
+ variables: this.dashboardVariables(),
293
+ panes: this.props.functionApp.dashboard.panes,
294
+ properties: this.appConfigurationsOriginalParsedConfig.appConfig,
295
+ });
296
+ }
297
+ }
@@ -0,0 +1,33 @@
1
+ import { AppConfigurationProps, CommonAzureStackProps, ContainerSasTokenProps, FunctionAppFlexConsumptionProps, PortalDashboardProps, ServicePlanProps, StorageAccountProps, StorageContainerProps } from '../../index.js';
2
+ export interface OtelProps {
3
+ otelTracesSamplerArg: string;
4
+ }
5
+ export interface FunctionAppProperties {
6
+ app: FunctionAppFlexConsumptionProps;
7
+ appConfiguration: AppConfigurationProps;
8
+ dashboard: PortalDashboardProps;
9
+ deploymentStorageContainer: StorageContainerProps;
10
+ deploySource: string;
11
+ hostsConfiguration?: string;
12
+ packageName: string;
13
+ servicePlan: ServicePlanProps;
14
+ storageAccount: StorageAccountProps;
15
+ storageContainer: StorageContainerProps;
16
+ timerTriggerCronExpression: string;
17
+ }
18
+ export interface AzureFunctionAppProps extends CommonAzureStackProps {
19
+ existingTopicName: string;
20
+ existingTopicResourceGroupName: string;
21
+ existingCosmosAccountResourceGroupName: string;
22
+ existingCosmosAccountName: string;
23
+ hostsConfiguration: any;
24
+ existingConfigStoreResourceGroupName: string;
25
+ existingConfigStoreName: string;
26
+ functionApp: FunctionAppProperties;
27
+ useConfigOverride?: boolean;
28
+ dataStorageContainer: StorageContainerProps;
29
+ dataStorageAccount: StorageAccountProps;
30
+ dataStorageContainerSas: ContainerSasTokenProps;
31
+ dataKeyVaultName: string;
32
+ dataKeyVaultSecretName: string;
33
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,6 @@
1
+ export * from './event-handler/index.js';
2
+ export * from './function-app/index.js';
3
+ export * from './rest-api-function/index.js';
4
+ export * from './rest-api-with-cache/index.js';
5
+ export * from './rest-api/index.js';
6
+ export * from './site-with-webapp/index.js';
@@ -0,0 +1,6 @@
1
+ export * from './event-handler/index.js';
2
+ export * from './function-app/index.js';
3
+ export * from './rest-api-function/index.js';
4
+ export * from './rest-api-with-cache/index.js';
5
+ export * from './rest-api/index.js';
6
+ export * from './site-with-webapp/index.js';
@@ -0,0 +1,2 @@
1
+ export * from './main.js';
2
+ export * from './types.js';
@@ -0,0 +1,2 @@
1
+ export * from './main.js';
2
+ export * from './types.js';
@@ -0,0 +1,20 @@
1
+ import { GetComponentResult } from '@pulumi/azure-native/applicationinsights/index.js';
2
+ import { Output } from '@pulumi/pulumi';
3
+ import { CommonAzureConstruct } from '../../common/index.js';
4
+ import { AzureApi, AzureRestApiProps } from './types.js';
5
+ export declare class AzureRestApi extends CommonAzureConstruct {
6
+ props: AzureRestApiProps;
7
+ api: AzureApi;
8
+ applicationInsights: Output<GetComponentResult>;
9
+ constructor(id: string, props: AzureRestApiProps);
10
+ initResources(): void;
11
+ protected resolveApiKeyVault(): void;
12
+ protected resolveApplicationInsights(): void;
13
+ protected createApiManagement(): void;
14
+ protected createNamespaceSecretRole(): void;
15
+ protected createNamespaceSecret(): void;
16
+ protected createSubscriptionKeySecret(): void;
17
+ protected createApiManagementLogger(): void;
18
+ protected createApiDiagnostic(): void;
19
+ protected createDiagnosticLog(): void;
20
+ }