pulumi-gcp 7.12.0a1709102105__py3-none-any.whl → 7.12.0a1709149267__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (940) hide show
  1. pulumi_gcp/accessapproval/get_folder_service_account.py +2 -2
  2. pulumi_gcp/accessapproval/get_organization_service_account.py +2 -2
  3. pulumi_gcp/accessapproval/get_project_service_account.py +2 -2
  4. pulumi_gcp/accesscontextmanager/access_level.py +10 -8
  5. pulumi_gcp/accesscontextmanager/access_level_condition.py +2 -0
  6. pulumi_gcp/accesscontextmanager/access_levels.py +16 -16
  7. pulumi_gcp/accesscontextmanager/access_policy.py +12 -6
  8. pulumi_gcp/accesscontextmanager/access_policy_iam_binding.py +10 -2
  9. pulumi_gcp/accesscontextmanager/access_policy_iam_member.py +10 -2
  10. pulumi_gcp/accesscontextmanager/access_policy_iam_policy.py +10 -2
  11. pulumi_gcp/accesscontextmanager/authorized_orgs_desc.py +8 -6
  12. pulumi_gcp/accesscontextmanager/gcp_user_access_binding.py +80 -0
  13. pulumi_gcp/accesscontextmanager/get_access_policy_iam_policy.py +2 -2
  14. pulumi_gcp/accesscontextmanager/service_perimeter.py +34 -24
  15. pulumi_gcp/accesscontextmanager/service_perimeter_resource.py +6 -4
  16. pulumi_gcp/accesscontextmanager/service_perimeters.py +14 -12
  17. pulumi_gcp/activedirectory/domain_trust.py +6 -6
  18. pulumi_gcp/activedirectory/peering.py +20 -22
  19. pulumi_gcp/alloydb/backup.py +62 -66
  20. pulumi_gcp/alloydb/cluster.py +78 -82
  21. pulumi_gcp/alloydb/instance.py +70 -74
  22. pulumi_gcp/alloydb/user.py +44 -48
  23. pulumi_gcp/apigateway/api.py +2 -4
  24. pulumi_gcp/apigateway/api_config.py +86 -14
  25. pulumi_gcp/apigateway/api_config_iam_binding.py +18 -24
  26. pulumi_gcp/apigateway/api_config_iam_member.py +18 -24
  27. pulumi_gcp/apigateway/api_config_iam_policy.py +18 -24
  28. pulumi_gcp/apigateway/api_iam_binding.py +18 -24
  29. pulumi_gcp/apigateway/api_iam_member.py +18 -24
  30. pulumi_gcp/apigateway/api_iam_policy.py +18 -24
  31. pulumi_gcp/apigateway/gateway.py +16 -22
  32. pulumi_gcp/apigateway/gateway_iam_binding.py +24 -30
  33. pulumi_gcp/apigateway/gateway_iam_member.py +24 -30
  34. pulumi_gcp/apigateway/gateway_iam_policy.py +24 -30
  35. pulumi_gcp/apigee/addons_config.py +22 -26
  36. pulumi_gcp/apigee/endpoint_attachment.py +14 -14
  37. pulumi_gcp/apigee/env_group.py +16 -14
  38. pulumi_gcp/apigee/env_group_attachment.py +0 -100
  39. pulumi_gcp/apigee/environment.py +14 -12
  40. pulumi_gcp/apigee/environment_iam_binding.py +12 -12
  41. pulumi_gcp/apigee/environment_iam_member.py +12 -12
  42. pulumi_gcp/apigee/environment_iam_policy.py +12 -12
  43. pulumi_gcp/apigee/get_environment_iam_policy.py +4 -4
  44. pulumi_gcp/apigee/instance.py +84 -76
  45. pulumi_gcp/apigee/instance_attachment.py +0 -100
  46. pulumi_gcp/apigee/keystores_aliases_self_signed_cert.py +40 -40
  47. pulumi_gcp/apigee/nat_address.py +42 -36
  48. pulumi_gcp/apigee/organization.py +62 -58
  49. pulumi_gcp/apigee/sync_authorization.py +16 -12
  50. pulumi_gcp/apigee/target_server.py +34 -36
  51. pulumi_gcp/appengine/application.py +8 -2
  52. pulumi_gcp/appengine/application_url_dispatch_rules.py +12 -6
  53. pulumi_gcp/appengine/domain_mapping.py +2 -2
  54. pulumi_gcp/appengine/engine_split_traffic.py +12 -6
  55. pulumi_gcp/appengine/firewall_rule.py +6 -2
  56. pulumi_gcp/appengine/flexible_app_version.py +20 -12
  57. pulumi_gcp/appengine/service_network_settings.py +14 -8
  58. pulumi_gcp/appengine/standard_app_version.py +18 -12
  59. pulumi_gcp/artifactregistry/get_repository_iam_policy.py +6 -6
  60. pulumi_gcp/artifactregistry/repository.py +78 -82
  61. pulumi_gcp/artifactregistry/repository_iam_binding.py +18 -18
  62. pulumi_gcp/artifactregistry/repository_iam_member.py +18 -18
  63. pulumi_gcp/artifactregistry/repository_iam_policy.py +18 -18
  64. pulumi_gcp/artifactregistry/vpcsc_config.py +2 -4
  65. pulumi_gcp/assuredworkloads/workload.py +16 -18
  66. pulumi_gcp/backupdisasterrecovery/management_server.py +20 -24
  67. pulumi_gcp/beyondcorp/app_connection.py +44 -30
  68. pulumi_gcp/beyondcorp/app_connector.py +22 -16
  69. pulumi_gcp/beyondcorp/app_gateway.py +20 -16
  70. pulumi_gcp/biglake/catalog.py +6 -2
  71. pulumi_gcp/biglake/database.py +14 -4
  72. pulumi_gcp/biglake/table.py +20 -6
  73. pulumi_gcp/bigquery/app_profile.py +8 -0
  74. pulumi_gcp/bigquery/capacity_commitment.py +4 -4
  75. pulumi_gcp/bigquery/connection.py +72 -54
  76. pulumi_gcp/bigquery/connection_iam_binding.py +18 -18
  77. pulumi_gcp/bigquery/connection_iam_member.py +18 -18
  78. pulumi_gcp/bigquery/connection_iam_policy.py +18 -18
  79. pulumi_gcp/bigquery/data_transfer_config.py +8 -12
  80. pulumi_gcp/bigquery/dataset.py +20 -14
  81. pulumi_gcp/bigquery/dataset_access.py +16 -16
  82. pulumi_gcp/bigquery/dataset_iam_binding.py +4 -4
  83. pulumi_gcp/bigquery/dataset_iam_member.py +4 -4
  84. pulumi_gcp/bigquery/dataset_iam_policy.py +4 -4
  85. pulumi_gcp/bigquery/get_connection_iam_policy.py +6 -6
  86. pulumi_gcp/bigquery/get_dataset_iam_policy.py +2 -2
  87. pulumi_gcp/bigquery/get_default_service_account.py +4 -4
  88. pulumi_gcp/bigquery/get_table_iam_policy.py +6 -6
  89. pulumi_gcp/bigquery/iam_binding.py +36 -36
  90. pulumi_gcp/bigquery/iam_member.py +36 -36
  91. pulumi_gcp/bigquery/iam_policy.py +36 -36
  92. pulumi_gcp/bigquery/job.py +326 -20
  93. pulumi_gcp/bigquery/reservation.py +14 -12
  94. pulumi_gcp/bigquery/reservation_assignment.py +2 -0
  95. pulumi_gcp/bigquery/routine.py +22 -22
  96. pulumi_gcp/bigquery/table.py +8 -8
  97. pulumi_gcp/bigqueryanalyticshub/data_exchange.py +6 -6
  98. pulumi_gcp/bigqueryanalyticshub/data_exchange_iam_binding.py +18 -18
  99. pulumi_gcp/bigqueryanalyticshub/data_exchange_iam_member.py +18 -18
  100. pulumi_gcp/bigqueryanalyticshub/data_exchange_iam_policy.py +18 -18
  101. pulumi_gcp/bigqueryanalyticshub/get_data_exchange_iam_policy.py +6 -6
  102. pulumi_gcp/bigqueryanalyticshub/get_listing_iam_policy.py +8 -8
  103. pulumi_gcp/bigqueryanalyticshub/listing.py +16 -16
  104. pulumi_gcp/bigqueryanalyticshub/listing_iam_binding.py +24 -24
  105. pulumi_gcp/bigqueryanalyticshub/listing_iam_member.py +24 -24
  106. pulumi_gcp/bigqueryanalyticshub/listing_iam_policy.py +24 -24
  107. pulumi_gcp/bigquerydatapolicy/data_policy.py +4 -4
  108. pulumi_gcp/bigquerydatapolicy/data_policy_iam_binding.py +18 -18
  109. pulumi_gcp/bigquerydatapolicy/data_policy_iam_member.py +18 -18
  110. pulumi_gcp/bigquerydatapolicy/data_policy_iam_policy.py +18 -18
  111. pulumi_gcp/bigquerydatapolicy/get_iam_policy.py +6 -6
  112. pulumi_gcp/bigtable/gc_policy.py +0 -208
  113. pulumi_gcp/bigtable/get_instance_iam_policy.py +2 -2
  114. pulumi_gcp/bigtable/get_table_iam_policy.py +4 -4
  115. pulumi_gcp/bigtable/instance.py +14 -10
  116. pulumi_gcp/bigtable/instance_iam_binding.py +8 -8
  117. pulumi_gcp/bigtable/instance_iam_member.py +8 -8
  118. pulumi_gcp/bigtable/instance_iam_policy.py +8 -8
  119. pulumi_gcp/bigtable/table.py +18 -12
  120. pulumi_gcp/bigtable/table_iam_binding.py +8 -8
  121. pulumi_gcp/bigtable/table_iam_member.py +8 -8
  122. pulumi_gcp/bigtable/table_iam_policy.py +8 -8
  123. pulumi_gcp/billing/account_iam_binding.py +8 -8
  124. pulumi_gcp/billing/account_iam_member.py +8 -8
  125. pulumi_gcp/billing/account_iam_policy.py +8 -8
  126. pulumi_gcp/billing/budget.py +2 -2
  127. pulumi_gcp/billing/project_info.py +28 -0
  128. pulumi_gcp/binaryauthorization/attestor.py +74 -52
  129. pulumi_gcp/binaryauthorization/attestor_iam_binding.py +12 -12
  130. pulumi_gcp/binaryauthorization/attestor_iam_member.py +12 -12
  131. pulumi_gcp/binaryauthorization/attestor_iam_policy.py +12 -12
  132. pulumi_gcp/binaryauthorization/get_attestor_iam_policy.py +4 -4
  133. pulumi_gcp/binaryauthorization/policy.py +48 -32
  134. pulumi_gcp/blockchainnodeengine/blockchain_nodes.py +38 -38
  135. pulumi_gcp/certificateauthority/authority.py +34 -42
  136. pulumi_gcp/certificateauthority/ca_pool.py +274 -6
  137. pulumi_gcp/certificateauthority/ca_pool_iam_binding.py +12 -12
  138. pulumi_gcp/certificateauthority/ca_pool_iam_member.py +12 -12
  139. pulumi_gcp/certificateauthority/ca_pool_iam_policy.py +12 -12
  140. pulumi_gcp/certificateauthority/certificate.py +264 -44
  141. pulumi_gcp/certificateauthority/certificate_template.py +168 -0
  142. pulumi_gcp/certificateauthority/certificate_template_iam_binding.py +12 -12
  143. pulumi_gcp/certificateauthority/certificate_template_iam_member.py +12 -12
  144. pulumi_gcp/certificateauthority/certificate_template_iam_policy.py +12 -12
  145. pulumi_gcp/certificateauthority/get_ca_pool_iam_policy.py +2 -2
  146. pulumi_gcp/certificateauthority/get_certificate_template_iam_policy.py +2 -2
  147. pulumi_gcp/certificatemanager/certificate.py +114 -84
  148. pulumi_gcp/certificatemanager/certificate_issuance_config.py +34 -32
  149. pulumi_gcp/certificatemanager/certificate_map.py +2 -0
  150. pulumi_gcp/certificatemanager/certificate_map_entry.py +12 -2
  151. pulumi_gcp/certificatemanager/dns_authorization.py +2 -0
  152. pulumi_gcp/certificatemanager/trust_config.py +8 -4
  153. pulumi_gcp/cloudasset/folder_feed.py +82 -0
  154. pulumi_gcp/cloudasset/organization_feed.py +74 -0
  155. pulumi_gcp/cloudasset/project_feed.py +70 -0
  156. pulumi_gcp/cloudbuild/bitbucket_server_config.py +98 -14
  157. pulumi_gcp/cloudbuild/get_trigger.py +2 -2
  158. pulumi_gcp/cloudbuild/trigger.py +650 -122
  159. pulumi_gcp/cloudbuild/worker_pool.py +20 -16
  160. pulumi_gcp/cloudbuildv2/connection.py +20 -18
  161. pulumi_gcp/cloudbuildv2/connection_iam_binding.py +18 -12
  162. pulumi_gcp/cloudbuildv2/connection_iam_member.py +18 -12
  163. pulumi_gcp/cloudbuildv2/connection_iam_policy.py +18 -12
  164. pulumi_gcp/cloudbuildv2/get_connection_iam_policy.py +6 -6
  165. pulumi_gcp/cloudbuildv2/repository.py +18 -14
  166. pulumi_gcp/clouddeploy/automation.py +16 -16
  167. pulumi_gcp/clouddeploy/custom_target_type.py +38 -32
  168. pulumi_gcp/clouddeploy/delivery_pipeline.py +40 -38
  169. pulumi_gcp/clouddeploy/get_delivery_pipeline_iam_policy.py +6 -6
  170. pulumi_gcp/clouddeploy/target.py +26 -24
  171. pulumi_gcp/clouddomains/registration.py +74 -74
  172. pulumi_gcp/cloudfunctions/function.py +20 -4
  173. pulumi_gcp/cloudfunctions/function_iam_binding.py +18 -18
  174. pulumi_gcp/cloudfunctions/function_iam_member.py +18 -18
  175. pulumi_gcp/cloudfunctions/function_iam_policy.py +18 -18
  176. pulumi_gcp/cloudfunctions/get_function_iam_policy.py +6 -6
  177. pulumi_gcp/cloudfunctionsv2/function.py +776 -42
  178. pulumi_gcp/cloudfunctionsv2/function_iam_binding.py +18 -18
  179. pulumi_gcp/cloudfunctionsv2/function_iam_member.py +18 -18
  180. pulumi_gcp/cloudfunctionsv2/function_iam_policy.py +18 -18
  181. pulumi_gcp/cloudfunctionsv2/get_function.py +4 -4
  182. pulumi_gcp/cloudfunctionsv2/get_function_iam_policy.py +6 -6
  183. pulumi_gcp/cloudidentity/group.py +8 -8
  184. pulumi_gcp/cloudidentity/group_membership.py +4 -4
  185. pulumi_gcp/cloudids/endpoint.py +12 -10
  186. pulumi_gcp/cloudrun/domain_mapping.py +10 -6
  187. pulumi_gcp/cloudrun/get_service.py +4 -4
  188. pulumi_gcp/cloudrun/get_service_iam_policy.py +6 -6
  189. pulumi_gcp/cloudrun/iam_binding.py +18 -18
  190. pulumi_gcp/cloudrun/iam_member.py +18 -18
  191. pulumi_gcp/cloudrun/iam_policy.py +18 -18
  192. pulumi_gcp/cloudrun/service.py +28 -14
  193. pulumi_gcp/cloudrunv2/get_job.py +4 -4
  194. pulumi_gcp/cloudrunv2/get_job_iam_policy.py +6 -6
  195. pulumi_gcp/cloudrunv2/get_service.py +4 -4
  196. pulumi_gcp/cloudrunv2/get_service_iam_policy.py +6 -6
  197. pulumi_gcp/cloudrunv2/job.py +56 -46
  198. pulumi_gcp/cloudrunv2/job_iam_binding.py +18 -12
  199. pulumi_gcp/cloudrunv2/job_iam_member.py +18 -12
  200. pulumi_gcp/cloudrunv2/job_iam_policy.py +18 -12
  201. pulumi_gcp/cloudrunv2/service.py +94 -68
  202. pulumi_gcp/cloudrunv2/service_iam_binding.py +18 -12
  203. pulumi_gcp/cloudrunv2/service_iam_member.py +18 -12
  204. pulumi_gcp/cloudrunv2/service_iam_policy.py +18 -12
  205. pulumi_gcp/cloudscheduler/job.py +168 -26
  206. pulumi_gcp/cloudtasks/get_queue_iam_policy.py +6 -6
  207. pulumi_gcp/cloudtasks/queue.py +18 -12
  208. pulumi_gcp/cloudtasks/queue_iam_binding.py +18 -12
  209. pulumi_gcp/cloudtasks/queue_iam_member.py +18 -12
  210. pulumi_gcp/cloudtasks/queue_iam_policy.py +18 -12
  211. pulumi_gcp/composer/get_environment.py +22 -0
  212. pulumi_gcp/composer/get_image_versions.py +2 -0
  213. pulumi_gcp/compute/address.py +32 -18
  214. pulumi_gcp/compute/attached_disk.py +8 -6
  215. pulumi_gcp/compute/autoscaler.py +34 -28
  216. pulumi_gcp/compute/backend_bucket.py +42 -16
  217. pulumi_gcp/compute/backend_bucket_signed_url_key.py +16 -8
  218. pulumi_gcp/compute/backend_service.py +350 -34
  219. pulumi_gcp/compute/backend_service_signed_url_key.py +98 -0
  220. pulumi_gcp/compute/disk.py +26 -18
  221. pulumi_gcp/compute/disk_async_replication.py +4 -0
  222. pulumi_gcp/compute/disk_iam_binding.py +18 -12
  223. pulumi_gcp/compute/disk_iam_member.py +18 -12
  224. pulumi_gcp/compute/disk_iam_policy.py +18 -12
  225. pulumi_gcp/compute/disk_resource_policy_attachment.py +12 -6
  226. pulumi_gcp/compute/external_vpn_gateway.py +40 -16
  227. pulumi_gcp/compute/firewall.py +16 -12
  228. pulumi_gcp/compute/firewall_policy.py +4 -4
  229. pulumi_gcp/compute/firewall_policy_association.py +10 -8
  230. pulumi_gcp/compute/firewall_policy_rule.py +4 -2
  231. pulumi_gcp/compute/forwarding_rule.py +1840 -22
  232. pulumi_gcp/compute/get_address.py +6 -2
  233. pulumi_gcp/compute/get_addresses.py +6 -2
  234. pulumi_gcp/compute/get_backend_service.py +32 -0
  235. pulumi_gcp/compute/get_disk.py +0 -2
  236. pulumi_gcp/compute/get_disk_iam_policy.py +6 -6
  237. pulumi_gcp/compute/get_global_address.py +6 -2
  238. pulumi_gcp/compute/get_image.py +0 -2
  239. pulumi_gcp/compute/get_image_iam_policy.py +4 -4
  240. pulumi_gcp/compute/get_instance_iam_policy.py +6 -6
  241. pulumi_gcp/compute/get_instance_serial_port.py +10 -8
  242. pulumi_gcp/compute/get_instance_template.py +0 -22
  243. pulumi_gcp/compute/get_lbip_ranges.py +4 -2
  244. pulumi_gcp/compute/get_machine_types.py +100 -0
  245. pulumi_gcp/compute/get_netblock_ip_ranges.py +4 -2
  246. pulumi_gcp/compute/get_network_peering.py +16 -4
  247. pulumi_gcp/compute/get_node_types.py +4 -2
  248. pulumi_gcp/compute/get_region_disk_iam_policy.py +6 -6
  249. pulumi_gcp/compute/get_region_instance_template.py +4 -0
  250. pulumi_gcp/compute/get_regions.py +2 -0
  251. pulumi_gcp/compute/get_snapshot.py +4 -0
  252. pulumi_gcp/compute/get_snapshot_iam_policy.py +4 -4
  253. pulumi_gcp/compute/get_subnetwork_iam_policy.py +6 -6
  254. pulumi_gcp/compute/global_address.py +12 -10
  255. pulumi_gcp/compute/global_forwarding_rule.py +1574 -56
  256. pulumi_gcp/compute/global_network_endpoint.py +2 -0
  257. pulumi_gcp/compute/global_network_endpoint_group.py +8 -4
  258. pulumi_gcp/compute/ha_vpn_gateway.py +38 -10
  259. pulumi_gcp/compute/health_check.py +114 -90
  260. pulumi_gcp/compute/http_health_check.py +6 -4
  261. pulumi_gcp/compute/https_health_check.py +6 -4
  262. pulumi_gcp/compute/image.py +22 -14
  263. pulumi_gcp/compute/image_iam_binding.py +24 -24
  264. pulumi_gcp/compute/image_iam_member.py +24 -24
  265. pulumi_gcp/compute/image_iam_policy.py +24 -24
  266. pulumi_gcp/compute/instance.py +16 -14
  267. pulumi_gcp/compute/instance_from_machine_image.py +4 -4
  268. pulumi_gcp/compute/instance_from_template.py +10 -6
  269. pulumi_gcp/compute/instance_group.py +108 -6
  270. pulumi_gcp/compute/instance_group_manager.py +16 -12
  271. pulumi_gcp/compute/instance_group_membership.py +6 -4
  272. pulumi_gcp/compute/instance_group_named_port.py +22 -10
  273. pulumi_gcp/compute/instance_iam_binding.py +36 -36
  274. pulumi_gcp/compute/instance_iam_member.py +36 -36
  275. pulumi_gcp/compute/instance_iam_policy.py +36 -36
  276. pulumi_gcp/compute/instance_settings.py +4 -6
  277. pulumi_gcp/compute/instance_template.py +150 -12
  278. pulumi_gcp/compute/interconnect_attachment.py +28 -10
  279. pulumi_gcp/compute/machine_image.py +30 -24
  280. pulumi_gcp/compute/machine_image_iam_binding.py +36 -48
  281. pulumi_gcp/compute/machine_image_iam_member.py +36 -48
  282. pulumi_gcp/compute/machine_image_iam_policy.py +36 -48
  283. pulumi_gcp/compute/managed_ssl_certificate.py +212 -0
  284. pulumi_gcp/compute/manged_ssl_certificate.py +212 -0
  285. pulumi_gcp/compute/network.py +18 -14
  286. pulumi_gcp/compute/network_attachment.py +60 -52
  287. pulumi_gcp/compute/network_edge_security_service.py +4 -4
  288. pulumi_gcp/compute/network_endpoint.py +32 -22
  289. pulumi_gcp/compute/network_endpoint_group.py +20 -10
  290. pulumi_gcp/compute/network_endpoint_list.py +44 -32
  291. pulumi_gcp/compute/network_firewall_policy.py +6 -2
  292. pulumi_gcp/compute/network_firewall_policy_association.py +8 -4
  293. pulumi_gcp/compute/network_firewall_policy_rule.py +14 -10
  294. pulumi_gcp/compute/network_peering.py +16 -4
  295. pulumi_gcp/compute/network_peering_routes_config.py +38 -18
  296. pulumi_gcp/compute/node_group.py +28 -10
  297. pulumi_gcp/compute/node_template.py +12 -8
  298. pulumi_gcp/compute/organization_security_policy.py +2 -4
  299. pulumi_gcp/compute/organization_security_policy_association.py +22 -28
  300. pulumi_gcp/compute/organization_security_policy_rule.py +10 -14
  301. pulumi_gcp/compute/packet_mirroring.py +128 -0
  302. pulumi_gcp/compute/per_instance_config.py +16 -8
  303. pulumi_gcp/compute/project_metadata.py +6 -8
  304. pulumi_gcp/compute/public_advertised_prefix.py +2 -0
  305. pulumi_gcp/compute/public_delegated_prefix.py +4 -0
  306. pulumi_gcp/compute/region_autoscaler.py +14 -8
  307. pulumi_gcp/compute/region_backend_service.py +462 -2
  308. pulumi_gcp/compute/region_commitment.py +20 -16
  309. pulumi_gcp/compute/region_disk.py +20 -8
  310. pulumi_gcp/compute/region_disk_iam_binding.py +18 -12
  311. pulumi_gcp/compute/region_disk_iam_member.py +18 -12
  312. pulumi_gcp/compute/region_disk_iam_policy.py +18 -12
  313. pulumi_gcp/compute/region_disk_resource_policy_attachment.py +16 -6
  314. pulumi_gcp/compute/region_health_check.py +114 -90
  315. pulumi_gcp/compute/region_instance_group_manager.py +14 -8
  316. pulumi_gcp/compute/region_network_endpoint.py +16 -4
  317. pulumi_gcp/compute/region_network_endpoint_group.py +166 -32
  318. pulumi_gcp/compute/region_network_firewall_policy.py +6 -2
  319. pulumi_gcp/compute/region_network_firewall_policy_association.py +8 -4
  320. pulumi_gcp/compute/region_network_firewall_policy_rule.py +14 -10
  321. pulumi_gcp/compute/region_per_instance_config.py +12 -4
  322. pulumi_gcp/compute/region_security_policy.py +12 -12
  323. pulumi_gcp/compute/region_security_policy_rule.py +38 -48
  324. pulumi_gcp/compute/region_ssl_certificate.py +138 -32
  325. pulumi_gcp/compute/region_target_http_proxy.py +88 -4
  326. pulumi_gcp/compute/region_target_https_proxy.py +96 -0
  327. pulumi_gcp/compute/region_target_tcp_proxy.py +52 -0
  328. pulumi_gcp/compute/region_url_map.py +1038 -0
  329. pulumi_gcp/compute/reservation.py +10 -8
  330. pulumi_gcp/compute/resource_policy.py +60 -48
  331. pulumi_gcp/compute/route.py +206 -4
  332. pulumi_gcp/compute/router.py +18 -6
  333. pulumi_gcp/compute/router_interface.py +6 -4
  334. pulumi_gcp/compute/router_nat.py +82 -42
  335. pulumi_gcp/compute/router_peer.py +72 -42
  336. pulumi_gcp/compute/security_policy.py +120 -108
  337. pulumi_gcp/compute/security_scan_config.py +4 -6
  338. pulumi_gcp/compute/service_attachment.py +376 -0
  339. pulumi_gcp/compute/snapshot.py +8 -0
  340. pulumi_gcp/compute/snapshot_iam_binding.py +12 -6
  341. pulumi_gcp/compute/snapshot_iam_member.py +12 -6
  342. pulumi_gcp/compute/snapshot_iam_policy.py +12 -6
  343. pulumi_gcp/compute/ssl_certificate.py +118 -30
  344. pulumi_gcp/compute/ssl_policy.py +20 -12
  345. pulumi_gcp/compute/subnetwork.py +58 -30
  346. pulumi_gcp/compute/subnetwork_iam_binding.py +36 -36
  347. pulumi_gcp/compute/subnetwork_iam_member.py +36 -36
  348. pulumi_gcp/compute/subnetwork_iam_policy.py +36 -36
  349. pulumi_gcp/compute/target_grpc_proxy.py +176 -0
  350. pulumi_gcp/compute/target_http_proxy.py +166 -10
  351. pulumi_gcp/compute/target_https_proxy.py +336 -14
  352. pulumi_gcp/compute/target_instance.py +136 -16
  353. pulumi_gcp/compute/target_pool.py +40 -0
  354. pulumi_gcp/compute/target_ssl_proxy.py +54 -0
  355. pulumi_gcp/compute/target_tcp_proxy.py +44 -0
  356. pulumi_gcp/compute/url_map.py +1146 -0
  357. pulumi_gcp/compute/vpn_gateway.py +28 -24
  358. pulumi_gcp/compute/vpn_tunnel.py +40 -36
  359. pulumi_gcp/container/_inputs.py +0 -188
  360. pulumi_gcp/container/attached_cluster.py +124 -0
  361. pulumi_gcp/container/aws_cluster.py +46 -42
  362. pulumi_gcp/container/aws_node_pool.py +34 -26
  363. pulumi_gcp/container/azure_client.py +6 -4
  364. pulumi_gcp/container/azure_cluster.py +30 -26
  365. pulumi_gcp/container/azure_node_pool.py +12 -6
  366. pulumi_gcp/container/cluster.py +62 -6
  367. pulumi_gcp/container/get_attached_versions.py +2 -2
  368. pulumi_gcp/container/get_aws_versions.py +2 -2
  369. pulumi_gcp/container/get_azure_versions.py +2 -2
  370. pulumi_gcp/container/get_engine_versions.py +2 -0
  371. pulumi_gcp/container/node_pool.py +68 -2
  372. pulumi_gcp/container/outputs.py +0 -188
  373. pulumi_gcp/container/registry.py +4 -4
  374. pulumi_gcp/containeranalysis/get_note_iam_policy.py +4 -4
  375. pulumi_gcp/containeranalysis/note.py +32 -26
  376. pulumi_gcp/containeranalysis/note_iam_binding.py +12 -12
  377. pulumi_gcp/containeranalysis/note_iam_member.py +12 -12
  378. pulumi_gcp/containeranalysis/note_iam_policy.py +12 -12
  379. pulumi_gcp/databasemigrationservice/connection_profile.py +138 -46
  380. pulumi_gcp/databasemigrationservice/private_connection.py +6 -6
  381. pulumi_gcp/datacatalog/entry.py +12 -12
  382. pulumi_gcp/datacatalog/entry_group.py +8 -8
  383. pulumi_gcp/datacatalog/entry_group_iam_binding.py +6 -6
  384. pulumi_gcp/datacatalog/entry_group_iam_member.py +6 -6
  385. pulumi_gcp/datacatalog/entry_group_iam_policy.py +6 -6
  386. pulumi_gcp/datacatalog/get_entry_group_iam_policy.py +2 -2
  387. pulumi_gcp/datacatalog/get_policy_tag_iam_policy.py +2 -2
  388. pulumi_gcp/datacatalog/get_tag_template_iam_policy.py +2 -2
  389. pulumi_gcp/datacatalog/get_taxonomy_iam_policy.py +2 -2
  390. pulumi_gcp/datacatalog/policy_tag.py +14 -16
  391. pulumi_gcp/datacatalog/policy_tag_iam_binding.py +6 -6
  392. pulumi_gcp/datacatalog/policy_tag_iam_member.py +6 -6
  393. pulumi_gcp/datacatalog/policy_tag_iam_policy.py +6 -6
  394. pulumi_gcp/datacatalog/tag.py +22 -22
  395. pulumi_gcp/datacatalog/tag_template.py +16 -16
  396. pulumi_gcp/datacatalog/tag_template_iam_binding.py +6 -6
  397. pulumi_gcp/datacatalog/tag_template_iam_member.py +6 -6
  398. pulumi_gcp/datacatalog/tag_template_iam_policy.py +6 -6
  399. pulumi_gcp/datacatalog/taxonomy.py +6 -6
  400. pulumi_gcp/datacatalog/taxonomy_iam_binding.py +6 -6
  401. pulumi_gcp/datacatalog/taxonomy_iam_member.py +6 -6
  402. pulumi_gcp/datacatalog/taxonomy_iam_policy.py +6 -6
  403. pulumi_gcp/dataflow/flex_template_job.py +18 -18
  404. pulumi_gcp/dataflow/job.py +34 -26
  405. pulumi_gcp/dataflow/pipeline.py +4 -2
  406. pulumi_gcp/dataform/repository.py +28 -36
  407. pulumi_gcp/dataform/repository_release_config.py +16 -20
  408. pulumi_gcp/dataform/repository_workflow_config.py +26 -32
  409. pulumi_gcp/datafusion/get_instance_iam_policy.py +6 -6
  410. pulumi_gcp/datafusion/instance.py +60 -40
  411. pulumi_gcp/dataloss/prevention_deidentify_template.py +206 -10
  412. pulumi_gcp/dataloss/prevention_inspect_template.py +270 -42
  413. pulumi_gcp/dataloss/prevention_job_trigger.py +368 -192
  414. pulumi_gcp/dataloss/prevention_stored_info_type.py +24 -20
  415. pulumi_gcp/dataplex/asset.py +16 -10
  416. pulumi_gcp/dataplex/asset_iam_binding.py +30 -30
  417. pulumi_gcp/dataplex/asset_iam_member.py +30 -30
  418. pulumi_gcp/dataplex/asset_iam_policy.py +30 -30
  419. pulumi_gcp/dataplex/datascan.py +90 -92
  420. pulumi_gcp/dataplex/datascan_iam_binding.py +18 -18
  421. pulumi_gcp/dataplex/datascan_iam_member.py +18 -18
  422. pulumi_gcp/dataplex/datascan_iam_policy.py +18 -18
  423. pulumi_gcp/dataplex/get_asset_iam_policy.py +10 -10
  424. pulumi_gcp/dataplex/get_datascan_iam_policy.py +6 -6
  425. pulumi_gcp/dataplex/get_lake_iam_policy.py +6 -6
  426. pulumi_gcp/dataplex/get_task_iam_policy.py +8 -8
  427. pulumi_gcp/dataplex/get_zone_iam_policy.py +8 -8
  428. pulumi_gcp/dataplex/lake.py +8 -6
  429. pulumi_gcp/dataplex/lake_iam_binding.py +18 -18
  430. pulumi_gcp/dataplex/lake_iam_member.py +18 -18
  431. pulumi_gcp/dataplex/lake_iam_policy.py +18 -18
  432. pulumi_gcp/dataplex/task.py +300 -0
  433. pulumi_gcp/dataplex/task_iam_binding.py +24 -24
  434. pulumi_gcp/dataplex/task_iam_member.py +24 -24
  435. pulumi_gcp/dataplex/task_iam_policy.py +24 -24
  436. pulumi_gcp/dataplex/zone.py +4 -0
  437. pulumi_gcp/dataplex/zone_iam_binding.py +24 -24
  438. pulumi_gcp/dataplex/zone_iam_member.py +24 -24
  439. pulumi_gcp/dataplex/zone_iam_policy.py +24 -24
  440. pulumi_gcp/dataproc/autoscaling_policy.py +2 -0
  441. pulumi_gcp/dataproc/autoscaling_policy_iam_binding.py +18 -18
  442. pulumi_gcp/dataproc/autoscaling_policy_iam_member.py +18 -18
  443. pulumi_gcp/dataproc/autoscaling_policy_iam_policy.py +18 -18
  444. pulumi_gcp/dataproc/cluster.py +18 -10
  445. pulumi_gcp/dataproc/cluster_iam_binding.py +8 -8
  446. pulumi_gcp/dataproc/cluster_iam_member.py +8 -8
  447. pulumi_gcp/dataproc/cluster_iam_policy.py +8 -8
  448. pulumi_gcp/dataproc/get_autoscaling_policy_iam_policy.py +6 -6
  449. pulumi_gcp/dataproc/get_cluster_iam_policy.py +2 -2
  450. pulumi_gcp/dataproc/get_job_iam_policy.py +2 -2
  451. pulumi_gcp/dataproc/get_metastore_service.py +4 -4
  452. pulumi_gcp/dataproc/get_metastore_service_iam_policy.py +6 -6
  453. pulumi_gcp/dataproc/job.py +6 -2
  454. pulumi_gcp/dataproc/job_iam_binding.py +8 -8
  455. pulumi_gcp/dataproc/job_iam_member.py +8 -8
  456. pulumi_gcp/dataproc/job_iam_policy.py +8 -8
  457. pulumi_gcp/dataproc/metastore_federation.py +16 -24
  458. pulumi_gcp/dataproc/metastore_service.py +64 -56
  459. pulumi_gcp/dataproc/metastore_service_iam_binding.py +18 -18
  460. pulumi_gcp/dataproc/metastore_service_iam_member.py +18 -18
  461. pulumi_gcp/dataproc/metastore_service_iam_policy.py +18 -18
  462. pulumi_gcp/dataproc/workflow_template.py +58 -56
  463. pulumi_gcp/datastore/data_store_index.py +4 -4
  464. pulumi_gcp/datastream/connection_profile.py +52 -36
  465. pulumi_gcp/datastream/private_connection.py +4 -4
  466. pulumi_gcp/datastream/stream.py +52 -30
  467. pulumi_gcp/deploymentmanager/deployment.py +6 -2
  468. pulumi_gcp/diagflow/agent.py +20 -20
  469. pulumi_gcp/diagflow/cx_agent.py +4 -2
  470. pulumi_gcp/diagflow/cx_entity_type.py +2 -2
  471. pulumi_gcp/diagflow/cx_environment.py +2 -2
  472. pulumi_gcp/diagflow/cx_flow.py +6 -4
  473. pulumi_gcp/diagflow/cx_intent.py +2 -2
  474. pulumi_gcp/diagflow/cx_page.py +6 -6
  475. pulumi_gcp/diagflow/cx_security_settings.py +6 -4
  476. pulumi_gcp/diagflow/cx_test_case.py +6 -6
  477. pulumi_gcp/diagflow/cx_version.py +2 -2
  478. pulumi_gcp/diagflow/cx_webhook.py +2 -2
  479. pulumi_gcp/diagflow/entity_type.py +6 -8
  480. pulumi_gcp/diagflow/fulfillment.py +6 -8
  481. pulumi_gcp/diagflow/intent.py +32 -30
  482. pulumi_gcp/discoveryengine/chat_engine.py +4 -4
  483. pulumi_gcp/discoveryengine/data_store.py +8 -8
  484. pulumi_gcp/discoveryengine/search_engine.py +8 -8
  485. pulumi_gcp/dns/dns_managed_zone_iam_binding.py +12 -12
  486. pulumi_gcp/dns/dns_managed_zone_iam_member.py +12 -12
  487. pulumi_gcp/dns/dns_managed_zone_iam_policy.py +12 -12
  488. pulumi_gcp/dns/get_keys.py +2 -0
  489. pulumi_gcp/dns/get_managed_zone_iam_policy.py +4 -4
  490. pulumi_gcp/dns/managed_zone.py +82 -38
  491. pulumi_gcp/dns/policy.py +14 -4
  492. pulumi_gcp/dns/record_set.py +76 -44
  493. pulumi_gcp/dns/response_policy.py +16 -4
  494. pulumi_gcp/dns/response_policy_rule.py +12 -4
  495. pulumi_gcp/edgecontainer/cluster.py +54 -48
  496. pulumi_gcp/edgecontainer/node_pool.py +34 -16
  497. pulumi_gcp/edgecontainer/vpn_connection.py +12 -8
  498. pulumi_gcp/edgenetwork/network.py +2 -2
  499. pulumi_gcp/edgenetwork/subnet.py +8 -8
  500. pulumi_gcp/endpoints/get_service_iam_policy.py +2 -2
  501. pulumi_gcp/endpoints/service.py +12 -12
  502. pulumi_gcp/endpoints/service_iam_binding.py +6 -6
  503. pulumi_gcp/endpoints/service_iam_member.py +6 -6
  504. pulumi_gcp/endpoints/service_iam_policy.py +6 -6
  505. pulumi_gcp/essentialcontacts/document_ai_processor.py +2 -2
  506. pulumi_gcp/essentialcontacts/document_ai_processor_default_version.py +8 -8
  507. pulumi_gcp/essentialcontacts/document_ai_warehouse_document_schema.py +18 -18
  508. pulumi_gcp/eventarc/channel.py +10 -10
  509. pulumi_gcp/eventarc/google_channel_config.py +8 -8
  510. pulumi_gcp/eventarc/trigger.py +6 -2
  511. pulumi_gcp/filestore/backup.py +4 -0
  512. pulumi_gcp/filestore/instance.py +44 -30
  513. pulumi_gcp/filestore/snapshot.py +8 -0
  514. pulumi_gcp/firebase/_inputs.py +0 -6
  515. pulumi_gcp/firebase/android_app.py +8 -12
  516. pulumi_gcp/firebase/app_check_debug_token.py +38 -0
  517. pulumi_gcp/firebase/app_check_service_config.py +6 -12
  518. pulumi_gcp/firebase/apple_app.py +8 -12
  519. pulumi_gcp/firebase/database_instance.py +26 -36
  520. pulumi_gcp/firebase/extensions_instance.py +8 -10
  521. pulumi_gcp/firebase/hosting_channel.py +14 -22
  522. pulumi_gcp/firebase/hosting_custom_domain.py +40 -54
  523. pulumi_gcp/firebase/hosting_release.py +48 -66
  524. pulumi_gcp/firebase/hosting_site.py +6 -12
  525. pulumi_gcp/firebase/hosting_version.py +66 -86
  526. pulumi_gcp/firebase/outputs.py +0 -6
  527. pulumi_gcp/firebase/project.py +10 -10
  528. pulumi_gcp/firebase/storage_bucket.py +10 -12
  529. pulumi_gcp/firebase/web_app.py +46 -40
  530. pulumi_gcp/firebaserules/release.py +20 -24
  531. pulumi_gcp/firebaserules/ruleset.py +10 -10
  532. pulumi_gcp/firestore/backup_schedule.py +4 -0
  533. pulumi_gcp/firestore/database.py +40 -32
  534. pulumi_gcp/firestore/document.py +132 -0
  535. pulumi_gcp/firestore/field.py +126 -0
  536. pulumi_gcp/firestore/index.py +94 -10
  537. pulumi_gcp/folder/access_approval_settings.py +26 -18
  538. pulumi_gcp/folder/get_iam_policy.py +2 -2
  539. pulumi_gcp/folder/iam_audit_config.py +42 -42
  540. pulumi_gcp/folder/iam_member.py +42 -42
  541. pulumi_gcp/folder/iam_policy.py +42 -42
  542. pulumi_gcp/folder/organization_policy.py +22 -22
  543. pulumi_gcp/gkebackup/backup_plan.py +28 -4
  544. pulumi_gcp/gkebackup/backup_plan_iam_binding.py +18 -12
  545. pulumi_gcp/gkebackup/backup_plan_iam_member.py +18 -12
  546. pulumi_gcp/gkebackup/backup_plan_iam_policy.py +18 -12
  547. pulumi_gcp/gkebackup/get_backup_plan_iam_policy.py +6 -6
  548. pulumi_gcp/gkebackup/get_restore_plan_iam_policy.py +6 -6
  549. pulumi_gcp/gkebackup/restore_plan.py +48 -12
  550. pulumi_gcp/gkebackup/restore_plan_iam_binding.py +48 -12
  551. pulumi_gcp/gkebackup/restore_plan_iam_member.py +48 -12
  552. pulumi_gcp/gkebackup/restore_plan_iam_policy.py +48 -12
  553. pulumi_gcp/gkehub/feature.py +200 -38
  554. pulumi_gcp/gkehub/feature_iam_binding.py +18 -12
  555. pulumi_gcp/gkehub/feature_iam_member.py +18 -12
  556. pulumi_gcp/gkehub/feature_iam_policy.py +18 -12
  557. pulumi_gcp/gkehub/feature_membership.py +54 -22
  558. pulumi_gcp/gkehub/fleet.py +4 -4
  559. pulumi_gcp/gkehub/get_feature_iam_policy.py +6 -6
  560. pulumi_gcp/gkehub/get_membership_iam_policy.py +6 -6
  561. pulumi_gcp/gkehub/get_scope_iam_policy.py +4 -4
  562. pulumi_gcp/gkehub/membership.py +24 -18
  563. pulumi_gcp/gkehub/membership_binding.py +64 -0
  564. pulumi_gcp/gkehub/membership_iam_binding.py +18 -18
  565. pulumi_gcp/gkehub/membership_iam_member.py +18 -18
  566. pulumi_gcp/gkehub/membership_iam_policy.py +18 -18
  567. pulumi_gcp/gkehub/membership_rbac_role_binding.py +60 -0
  568. pulumi_gcp/gkehub/namespace.py +44 -0
  569. pulumi_gcp/gkehub/scope.py +6 -6
  570. pulumi_gcp/gkehub/scope_iam_binding.py +12 -12
  571. pulumi_gcp/gkehub/scope_iam_member.py +12 -12
  572. pulumi_gcp/gkehub/scope_iam_policy.py +12 -12
  573. pulumi_gcp/gkehub/scope_rbac_role_binding.py +36 -0
  574. pulumi_gcp/gkeonprem/bare_metal_admin_cluster.py +126 -122
  575. pulumi_gcp/gkeonprem/bare_metal_cluster.py +242 -236
  576. pulumi_gcp/gkeonprem/bare_metal_node_pool.py +8 -0
  577. pulumi_gcp/gkeonprem/v_mware_cluster.py +242 -236
  578. pulumi_gcp/gkeonprem/v_mware_node_pool.py +4 -180
  579. pulumi_gcp/healthcare/consent_store.py +32 -10
  580. pulumi_gcp/healthcare/consent_store_iam_binding.py +12 -12
  581. pulumi_gcp/healthcare/consent_store_iam_member.py +12 -12
  582. pulumi_gcp/healthcare/consent_store_iam_policy.py +12 -12
  583. pulumi_gcp/healthcare/dataset.py +2 -0
  584. pulumi_gcp/healthcare/dataset_iam_binding.py +8 -8
  585. pulumi_gcp/healthcare/dataset_iam_member.py +8 -8
  586. pulumi_gcp/healthcare/dataset_iam_policy.py +8 -8
  587. pulumi_gcp/healthcare/dicom_store.py +30 -26
  588. pulumi_gcp/healthcare/dicom_store_iam_binding.py +14 -14
  589. pulumi_gcp/healthcare/dicom_store_iam_member.py +14 -14
  590. pulumi_gcp/healthcare/dicom_store_iam_policy.py +14 -14
  591. pulumi_gcp/healthcare/fhir_store.py +44 -24
  592. pulumi_gcp/healthcare/fhir_store_iam_binding.py +14 -14
  593. pulumi_gcp/healthcare/fhir_store_iam_member.py +14 -14
  594. pulumi_gcp/healthcare/fhir_store_iam_policy.py +14 -14
  595. pulumi_gcp/healthcare/get_consent_store_iam_policy.py +4 -4
  596. pulumi_gcp/healthcare/get_dataset_iam_policy.py +2 -2
  597. pulumi_gcp/healthcare/get_dicom_store_iam_policy.py +2 -2
  598. pulumi_gcp/healthcare/get_fhir_store_iam_policy.py +2 -2
  599. pulumi_gcp/healthcare/get_hl7_v2_store_iam_policy.py +2 -2
  600. pulumi_gcp/healthcare/hl7_store.py +30 -20
  601. pulumi_gcp/healthcare/hl7_store_iam_binding.py +14 -14
  602. pulumi_gcp/healthcare/hl7_store_iam_member.py +14 -14
  603. pulumi_gcp/healthcare/hl7_store_iam_policy.py +14 -14
  604. pulumi_gcp/iam/_inputs.py +0 -18
  605. pulumi_gcp/iam/access_boundary_policy.py +100 -0
  606. pulumi_gcp/iam/deny_policy.py +92 -0
  607. pulumi_gcp/iam/outputs.py +0 -18
  608. pulumi_gcp/iam/workforce_pool.py +20 -20
  609. pulumi_gcp/iam/workforce_pool_provider.py +0 -21
  610. pulumi_gcp/iam/workload_identity_pool.py +6 -6
  611. pulumi_gcp/iam/workload_identity_pool_provider.py +8 -46
  612. pulumi_gcp/iap/app_engine_service_iam_binding.py +56 -56
  613. pulumi_gcp/iap/app_engine_service_iam_member.py +56 -56
  614. pulumi_gcp/iap/app_engine_service_iam_policy.py +56 -56
  615. pulumi_gcp/iap/app_engine_version_iam_binding.py +68 -68
  616. pulumi_gcp/iap/app_engine_version_iam_member.py +68 -68
  617. pulumi_gcp/iap/app_engine_version_iam_policy.py +68 -68
  618. pulumi_gcp/iap/brand.py +12 -6
  619. pulumi_gcp/iap/client.py +14 -8
  620. pulumi_gcp/iap/get_app_engine_service_iam_policy.py +6 -6
  621. pulumi_gcp/iap/get_app_engine_version_iam_policy.py +8 -8
  622. pulumi_gcp/iap/get_client.py +2 -2
  623. pulumi_gcp/iap/get_tunnel_iam_policy.py +2 -2
  624. pulumi_gcp/iap/get_tunnel_instance_iam_policy.py +6 -6
  625. pulumi_gcp/iap/get_web_backend_service_iam_policy.py +4 -4
  626. pulumi_gcp/iap/get_web_iam_policy.py +2 -2
  627. pulumi_gcp/iap/get_web_region_backend_service_iam_policy.py +6 -6
  628. pulumi_gcp/iap/get_web_type_app_engine_iam_policy.py +4 -4
  629. pulumi_gcp/iap/get_web_type_compute_iam_policy.py +2 -2
  630. pulumi_gcp/iap/tunnel_iam_binding.py +12 -12
  631. pulumi_gcp/iap/tunnel_iam_member.py +12 -12
  632. pulumi_gcp/iap/tunnel_iam_policy.py +12 -12
  633. pulumi_gcp/iap/tunnel_instance_iam_binding.py +36 -36
  634. pulumi_gcp/iap/tunnel_instance_iam_member.py +36 -36
  635. pulumi_gcp/iap/tunnel_instance_iam_policy.py +36 -36
  636. pulumi_gcp/iap/web_backend_service_iam_binding.py +24 -24
  637. pulumi_gcp/iap/web_backend_service_iam_member.py +24 -24
  638. pulumi_gcp/iap/web_backend_service_iam_policy.py +24 -24
  639. pulumi_gcp/iap/web_iam_binding.py +12 -12
  640. pulumi_gcp/iap/web_iam_member.py +12 -12
  641. pulumi_gcp/iap/web_iam_policy.py +12 -12
  642. pulumi_gcp/iap/web_region_backend_service_iam_binding.py +36 -36
  643. pulumi_gcp/iap/web_region_backend_service_iam_member.py +36 -36
  644. pulumi_gcp/iap/web_region_backend_service_iam_policy.py +36 -36
  645. pulumi_gcp/iap/web_type_app_enging_iam_binding.py +24 -24
  646. pulumi_gcp/iap/web_type_app_enging_iam_member.py +24 -24
  647. pulumi_gcp/iap/web_type_app_enging_iam_policy.py +24 -24
  648. pulumi_gcp/iap/web_type_compute_iam_binding.py +12 -12
  649. pulumi_gcp/iap/web_type_compute_iam_member.py +12 -12
  650. pulumi_gcp/iap/web_type_compute_iam_policy.py +12 -12
  651. pulumi_gcp/identityplatform/config.py +12 -8
  652. pulumi_gcp/identityplatform/default_supported_idp_config.py +8 -8
  653. pulumi_gcp/identityplatform/inbound_saml_config.py +8 -4
  654. pulumi_gcp/identityplatform/oauth_idp_config.py +10 -8
  655. pulumi_gcp/identityplatform/tenant.py +4 -4
  656. pulumi_gcp/identityplatform/tenant_default_supported_idp_config.py +2 -2
  657. pulumi_gcp/identityplatform/tenant_inbound_saml_config.py +8 -4
  658. pulumi_gcp/identityplatform/tenant_oauth_idp_config.py +4 -2
  659. pulumi_gcp/integrationconnectors/connection.py +16 -14
  660. pulumi_gcp/integrationconnectors/endpoint_attachment.py +8 -6
  661. pulumi_gcp/kms/crypto_key.py +16 -4
  662. pulumi_gcp/kms/crypto_key_iam_binding.py +32 -26
  663. pulumi_gcp/kms/crypto_key_iam_member.py +32 -26
  664. pulumi_gcp/kms/crypto_key_iam_policy.py +32 -26
  665. pulumi_gcp/kms/crypto_key_version.py +8 -2
  666. pulumi_gcp/kms/get_crypto_key_iam_policy.py +2 -2
  667. pulumi_gcp/kms/get_kms_crypto_key_version.py +2 -2
  668. pulumi_gcp/kms/get_kms_key_ring.py +4 -4
  669. pulumi_gcp/kms/key_ring.py +6 -2
  670. pulumi_gcp/kms/key_ring_iam_binding.py +52 -44
  671. pulumi_gcp/kms/key_ring_iam_member.py +52 -44
  672. pulumi_gcp/kms/key_ring_iam_policy.py +52 -44
  673. pulumi_gcp/kms/secret_ciphertext.py +20 -12
  674. pulumi_gcp/logging/billing_account_exclusion.py +2 -0
  675. pulumi_gcp/logging/billing_account_sink.py +8 -2
  676. pulumi_gcp/logging/folder_exclusion.py +2 -0
  677. pulumi_gcp/logging/folder_settings.py +12 -14
  678. pulumi_gcp/logging/folder_sink.py +8 -2
  679. pulumi_gcp/logging/linked_dataset.py +22 -24
  680. pulumi_gcp/logging/log_view.py +8 -6
  681. pulumi_gcp/logging/metric.py +78 -68
  682. pulumi_gcp/logging/organization_exclusion.py +6 -4
  683. pulumi_gcp/logging/organization_settings.py +10 -12
  684. pulumi_gcp/logging/organization_sink.py +8 -2
  685. pulumi_gcp/logging/project_bucket_config.py +178 -0
  686. pulumi_gcp/logging/project_exclusion.py +2 -0
  687. pulumi_gcp/looker/instance.py +76 -70
  688. pulumi_gcp/memcache/instance.py +10 -6
  689. pulumi_gcp/migrationcenter/group.py +6 -6
  690. pulumi_gcp/ml/engine_model.py +8 -4
  691. pulumi_gcp/monitoring/alert_policy.py +58 -58
  692. pulumi_gcp/monitoring/custom_service.py +2 -2
  693. pulumi_gcp/monitoring/dashboard.py +0 -4
  694. pulumi_gcp/monitoring/generic_service.py +18 -18
  695. pulumi_gcp/monitoring/get_app_engine_service.py +10 -2
  696. pulumi_gcp/monitoring/get_cluster_istio_service.py +10 -8
  697. pulumi_gcp/monitoring/get_istio_canonical_service.py +6 -4
  698. pulumi_gcp/monitoring/get_mesh_istio_service.py +6 -4
  699. pulumi_gcp/monitoring/get_notification_channel.py +2 -2
  700. pulumi_gcp/monitoring/metric_descriptor.py +34 -34
  701. pulumi_gcp/monitoring/monitored_project.py +14 -4
  702. pulumi_gcp/monitoring/notification_channel.py +8 -8
  703. pulumi_gcp/monitoring/slo.py +238 -4
  704. pulumi_gcp/monitoring/uptime_check_config.py +106 -102
  705. pulumi_gcp/netapp/active_directory.py +4 -2
  706. pulumi_gcp/netapp/backup_policy.py +12 -10
  707. pulumi_gcp/netapp/backup_vault.py +4 -2
  708. pulumi_gcp/netapp/kmsconfig.py +14 -6
  709. pulumi_gcp/netapp/storage_pool.py +12 -8
  710. pulumi_gcp/netapp/volume.py +12 -8
  711. pulumi_gcp/netapp/volume_snapshot.py +16 -12
  712. pulumi_gcp/networkconnectivity/hub.py +6 -4
  713. pulumi_gcp/networkconnectivity/policy_based_route.py +18 -6
  714. pulumi_gcp/networkconnectivity/service_connection_policy.py +12 -4
  715. pulumi_gcp/networkconnectivity/spoke.py +28 -8
  716. pulumi_gcp/networkmanagement/connectivity_test.py +36 -22
  717. pulumi_gcp/networksecurity/address_group.py +32 -26
  718. pulumi_gcp/networksecurity/authorization_policy.py +8 -8
  719. pulumi_gcp/networksecurity/client_tls_policy.py +8 -8
  720. pulumi_gcp/networksecurity/firewall_endpoint.py +4 -4
  721. pulumi_gcp/networksecurity/gateway_security_policy.py +38 -54
  722. pulumi_gcp/networksecurity/gateway_security_policy_rule.py +20 -12
  723. pulumi_gcp/networksecurity/security_profile.py +8 -8
  724. pulumi_gcp/networksecurity/security_profile_group.py +10 -10
  725. pulumi_gcp/networksecurity/server_tls_policy.py +30 -28
  726. pulumi_gcp/networksecurity/tls_inspection_policy.py +28 -44
  727. pulumi_gcp/networksecurity/url_list.py +6 -2
  728. pulumi_gcp/networkservices/edge_cache_keyset.py +4 -0
  729. pulumi_gcp/networkservices/edge_cache_origin.py +12 -4
  730. pulumi_gcp/networkservices/edge_cache_service.py +270 -16
  731. pulumi_gcp/networkservices/endpoint_policy.py +8 -8
  732. pulumi_gcp/networkservices/gateway.py +96 -60
  733. pulumi_gcp/networkservices/grpc_route.py +12 -12
  734. pulumi_gcp/networkservices/http_route.py +26 -26
  735. pulumi_gcp/networkservices/mesh.py +8 -8
  736. pulumi_gcp/networkservices/service_binding.py +16 -20
  737. pulumi_gcp/networkservices/tcp_route.py +298 -0
  738. pulumi_gcp/networkservices/tls_route.py +214 -0
  739. pulumi_gcp/notebooks/environment.py +6 -4
  740. pulumi_gcp/notebooks/get_instance_iam_policy.py +6 -6
  741. pulumi_gcp/notebooks/get_runtime_iam_policy.py +6 -6
  742. pulumi_gcp/notebooks/instance.py +38 -28
  743. pulumi_gcp/notebooks/instance_iam_binding.py +18 -18
  744. pulumi_gcp/notebooks/instance_iam_member.py +18 -18
  745. pulumi_gcp/notebooks/instance_iam_policy.py +18 -18
  746. pulumi_gcp/notebooks/runtime.py +74 -64
  747. pulumi_gcp/notebooks/runtime_iam_binding.py +18 -18
  748. pulumi_gcp/notebooks/runtime_iam_member.py +18 -18
  749. pulumi_gcp/notebooks/runtime_iam_policy.py +18 -18
  750. pulumi_gcp/organizations/access_approval_settings.py +34 -26
  751. pulumi_gcp/organizations/get_billing_account.py +6 -2
  752. pulumi_gcp/organizations/get_folders.py +2 -2
  753. pulumi_gcp/organizations/get_iam_policy.py +0 -62
  754. pulumi_gcp/organizations/iam_audit_config.py +8 -8
  755. pulumi_gcp/organizations/iam_binding.py +4 -4
  756. pulumi_gcp/organizations/iam_custom_role.py +8 -8
  757. pulumi_gcp/organizations/iam_member.py +42 -42
  758. pulumi_gcp/organizations/iam_policy.py +42 -42
  759. pulumi_gcp/organizations/policy.py +26 -26
  760. pulumi_gcp/organizations/project.py +16 -4
  761. pulumi_gcp/orgpolicy/custom_constraint.py +14 -8
  762. pulumi_gcp/orgpolicy/policy.py +46 -22
  763. pulumi_gcp/osconfig/guest_policies.py +16 -22
  764. pulumi_gcp/osconfig/os_policy_assignment.py +42 -40
  765. pulumi_gcp/osconfig/patch_deployment.py +122 -120
  766. pulumi_gcp/oslogin/ssh_public_key.py +4 -2
  767. pulumi_gcp/projects/access_approval_settings.py +24 -22
  768. pulumi_gcp/projects/api_key.py +50 -10
  769. pulumi_gcp/projects/default_service_accounts.py +10 -10
  770. pulumi_gcp/projects/iam_audit_config.py +46 -46
  771. pulumi_gcp/projects/iam_binding.py +46 -46
  772. pulumi_gcp/projects/iam_custom_role.py +6 -6
  773. pulumi_gcp/projects/iam_member.py +46 -46
  774. pulumi_gcp/projects/iam_policy.py +46 -46
  775. pulumi_gcp/projects/organization_policy.py +26 -26
  776. pulumi_gcp/projects/service.py +4 -4
  777. pulumi_gcp/projects/service_identity.py +6 -8
  778. pulumi_gcp/projects/usage_export_bucket.py +16 -4
  779. pulumi_gcp/pubsub/get_schema_iam_policy.py +4 -4
  780. pulumi_gcp/pubsub/get_subscription_iam_policy.py +2 -2
  781. pulumi_gcp/pubsub/get_topic_iam_policy.py +4 -4
  782. pulumi_gcp/pubsub/lite_reservation.py +2 -0
  783. pulumi_gcp/pubsub/lite_subscription.py +10 -6
  784. pulumi_gcp/pubsub/lite_topic.py +10 -6
  785. pulumi_gcp/pubsub/schema.py +22 -18
  786. pulumi_gcp/pubsub/schema_iam_binding.py +12 -12
  787. pulumi_gcp/pubsub/schema_iam_member.py +12 -12
  788. pulumi_gcp/pubsub/schema_iam_policy.py +12 -12
  789. pulumi_gcp/pubsub/subscription.py +204 -96
  790. pulumi_gcp/pubsub/subscription_iam_binding.py +8 -8
  791. pulumi_gcp/pubsub/subscription_iam_member.py +8 -8
  792. pulumi_gcp/pubsub/subscription_iam_policy.py +8 -8
  793. pulumi_gcp/pubsub/topic.py +46 -24
  794. pulumi_gcp/pubsub/topic_iam_binding.py +12 -12
  795. pulumi_gcp/pubsub/topic_iam_member.py +12 -12
  796. pulumi_gcp/pubsub/topic_iam_policy.py +12 -12
  797. pulumi_gcp/recaptcha/enterprise_key.py +54 -54
  798. pulumi_gcp/redis/cluster.py +32 -24
  799. pulumi_gcp/redis/instance.py +132 -14
  800. pulumi_gcp/resourcemanager/lien.py +12 -8
  801. pulumi_gcp/runtimeconfig/config.py +6 -2
  802. pulumi_gcp/runtimeconfig/get_variable.py +4 -4
  803. pulumi_gcp/runtimeconfig/variable.py +20 -8
  804. pulumi_gcp/secretmanager/get_secret_iam_policy.py +4 -4
  805. pulumi_gcp/secretmanager/secret.py +16 -18
  806. pulumi_gcp/secretmanager/secret_iam_binding.py +12 -12
  807. pulumi_gcp/secretmanager/secret_iam_member.py +12 -12
  808. pulumi_gcp/secretmanager/secret_iam_policy.py +12 -12
  809. pulumi_gcp/secretmanager/secret_version.py +4 -4
  810. pulumi_gcp/securesourcemanager/get_instance_iam_policy.py +6 -6
  811. pulumi_gcp/securesourcemanager/instance.py +144 -14
  812. pulumi_gcp/securitycenter/get_source_iam_policy.py +2 -2
  813. pulumi_gcp/securitycenter/instance_iam_binding.py +60 -40
  814. pulumi_gcp/securitycenter/instance_iam_member.py +60 -40
  815. pulumi_gcp/securitycenter/instance_iam_policy.py +60 -40
  816. pulumi_gcp/securitycenter/mute_config.py +6 -6
  817. pulumi_gcp/securitycenter/notification_config.py +4 -4
  818. pulumi_gcp/securitycenter/organization_custom_module.py +40 -40
  819. pulumi_gcp/securitycenter/project_custom_module.py +36 -36
  820. pulumi_gcp/securitycenter/source.py +6 -6
  821. pulumi_gcp/securitycenter/source_iam_binding.py +6 -6
  822. pulumi_gcp/securitycenter/source_iam_member.py +6 -6
  823. pulumi_gcp/securitycenter/source_iam_policy.py +6 -6
  824. pulumi_gcp/securityposture/posture.py +46 -46
  825. pulumi_gcp/serviceaccount/account.py +2 -2
  826. pulumi_gcp/serviceaccount/get_account.py +34 -0
  827. pulumi_gcp/serviceaccount/get_account_access_token.py +8 -10
  828. pulumi_gcp/serviceaccount/get_account_key.py +4 -4
  829. pulumi_gcp/serviceaccount/get_iam_policy.py +2 -2
  830. pulumi_gcp/serviceaccount/key.py +46 -2
  831. pulumi_gcp/servicedirectory/endpoint.py +28 -40
  832. pulumi_gcp/servicedirectory/namespace.py +2 -4
  833. pulumi_gcp/servicedirectory/namespace_iam_binding.py +14 -12
  834. pulumi_gcp/servicedirectory/namespace_iam_member.py +14 -12
  835. pulumi_gcp/servicedirectory/namespace_iam_policy.py +14 -12
  836. pulumi_gcp/servicedirectory/service.py +10 -14
  837. pulumi_gcp/servicedirectory/service_iam_binding.py +14 -12
  838. pulumi_gcp/servicedirectory/service_iam_member.py +14 -12
  839. pulumi_gcp/servicedirectory/service_iam_policy.py +14 -12
  840. pulumi_gcp/servicenetworking/connection.py +8 -6
  841. pulumi_gcp/servicenetworking/peered_dns_domain.py +6 -4
  842. pulumi_gcp/serviceusage/consumer_quota_override.py +126 -0
  843. pulumi_gcp/sourcerepo/get_repository_iam_policy.py +4 -4
  844. pulumi_gcp/sourcerepo/repository.py +20 -16
  845. pulumi_gcp/sourcerepo/repository_iam_binding.py +12 -12
  846. pulumi_gcp/sourcerepo/repository_iam_member.py +12 -12
  847. pulumi_gcp/sourcerepo/repository_iam_policy.py +12 -12
  848. pulumi_gcp/spanner/database.py +2 -0
  849. pulumi_gcp/spanner/database_iam_binding.py +12 -12
  850. pulumi_gcp/spanner/database_iam_member.py +12 -12
  851. pulumi_gcp/spanner/database_iam_policy.py +12 -12
  852. pulumi_gcp/spanner/get_database_iam_policy.py +6 -6
  853. pulumi_gcp/spanner/get_instance_iam_policy.py +4 -4
  854. pulumi_gcp/spanner/instance.py +16 -16
  855. pulumi_gcp/spanner/instance_iam_binding.py +8 -8
  856. pulumi_gcp/spanner/instance_iam_member.py +8 -8
  857. pulumi_gcp/spanner/instance_iam_policy.py +8 -8
  858. pulumi_gcp/sql/database.py +14 -4
  859. pulumi_gcp/sql/database_instance.py +76 -26
  860. pulumi_gcp/sql/get_backup_run.py +2 -2
  861. pulumi_gcp/sql/get_ca_certs.py +32 -0
  862. pulumi_gcp/sql/get_database.py +2 -2
  863. pulumi_gcp/sql/get_databases.py +2 -2
  864. pulumi_gcp/sql/source_representation_instance.py +20 -16
  865. pulumi_gcp/sql/ssl_cert.py +6 -4
  866. pulumi_gcp/sql/user.py +154 -0
  867. pulumi_gcp/storage/bucket.py +44 -38
  868. pulumi_gcp/storage/bucket_access_control.py +8 -4
  869. pulumi_gcp/storage/bucket_acl.py +6 -2
  870. pulumi_gcp/storage/bucket_iam_binding.py +12 -12
  871. pulumi_gcp/storage/bucket_iam_member.py +12 -12
  872. pulumi_gcp/storage/bucket_iam_policy.py +12 -12
  873. pulumi_gcp/storage/bucket_object.py +14 -12
  874. pulumi_gcp/storage/default_object_access_control.py +8 -4
  875. pulumi_gcp/storage/default_object_acl.py +6 -2
  876. pulumi_gcp/storage/get_bucket_iam_policy.py +2 -2
  877. pulumi_gcp/storage/get_bucket_object.py +4 -4
  878. pulumi_gcp/storage/get_object_signed_url.py +6 -4
  879. pulumi_gcp/storage/get_project_service_account.py +6 -6
  880. pulumi_gcp/storage/hmac_key.py +2 -2
  881. pulumi_gcp/storage/insights_report_config.py +14 -14
  882. pulumi_gcp/storage/notification.py +20 -18
  883. pulumi_gcp/storage/object_access_control.py +10 -4
  884. pulumi_gcp/storage/object_acl.py +8 -2
  885. pulumi_gcp/storage/transfer_agent_pool.py +6 -6
  886. pulumi_gcp/storage/transfer_job.py +30 -38
  887. pulumi_gcp/tags/get_tag_key_iam_policy.py +2 -2
  888. pulumi_gcp/tags/get_tag_value_iam_policy.py +2 -2
  889. pulumi_gcp/tags/location_tag_binding.py +44 -32
  890. pulumi_gcp/tags/tag_binding.py +16 -10
  891. pulumi_gcp/tags/tag_key.py +4 -4
  892. pulumi_gcp/tags/tag_key_iam_binding.py +6 -6
  893. pulumi_gcp/tags/tag_key_iam_member.py +6 -6
  894. pulumi_gcp/tags/tag_key_iam_policy.py +6 -6
  895. pulumi_gcp/tags/tag_value.py +8 -8
  896. pulumi_gcp/tags/tag_value_iam_binding.py +6 -6
  897. pulumi_gcp/tags/tag_value_iam_member.py +6 -6
  898. pulumi_gcp/tags/tag_value_iam_policy.py +6 -6
  899. pulumi_gcp/tpu/get_tensorflow_versions.py +2 -0
  900. pulumi_gcp/tpu/get_v2_accelerator_types.py +10 -8
  901. pulumi_gcp/tpu/get_v2_runtime_versions.py +2 -0
  902. pulumi_gcp/tpu/node.py +12 -6
  903. pulumi_gcp/tpu/v2_vm.py +134 -2
  904. pulumi_gcp/vertex/ai_dataset.py +6 -6
  905. pulumi_gcp/vertex/ai_endpoint.py +28 -26
  906. pulumi_gcp/vertex/ai_feature_group.py +8 -6
  907. pulumi_gcp/vertex/ai_feature_group_feature.py +12 -8
  908. pulumi_gcp/vertex/ai_feature_online_store.py +26 -24
  909. pulumi_gcp/vertex/ai_feature_online_store_featureview.py +36 -28
  910. pulumi_gcp/vertex/ai_feature_store.py +30 -26
  911. pulumi_gcp/vertex/ai_feature_store_entity_type.py +12 -8
  912. pulumi_gcp/vertex/ai_feature_store_entity_type_feature.py +18 -12
  913. pulumi_gcp/vertex/ai_index.py +8 -0
  914. pulumi_gcp/vertex/ai_index_endpoint.py +36 -36
  915. pulumi_gcp/vertex/ai_metadata_store.py +2 -0
  916. pulumi_gcp/vertex/ai_tensorboard.py +12 -14
  917. pulumi_gcp/vmwareengine/cluster.py +12 -0
  918. pulumi_gcp/vmwareengine/external_access_rule.py +16 -0
  919. pulumi_gcp/vmwareengine/external_address.py +10 -4
  920. pulumi_gcp/vmwareengine/get_network.py +4 -4
  921. pulumi_gcp/vmwareengine/get_network_policy.py +4 -4
  922. pulumi_gcp/vmwareengine/get_private_cloud.py +4 -4
  923. pulumi_gcp/vmwareengine/network.py +56 -4
  924. pulumi_gcp/vmwareengine/network_peering.py +12 -2
  925. pulumi_gcp/vmwareengine/network_policy.py +8 -0
  926. pulumi_gcp/vmwareengine/private_cloud.py +8 -0
  927. pulumi_gcp/vmwareengine/subnet.py +6 -0
  928. pulumi_gcp/vpcaccess/connector.py +16 -6
  929. pulumi_gcp/vpcaccess/get_connector.py +2 -0
  930. pulumi_gcp/workbench/get_instance_iam_policy.py +6 -6
  931. pulumi_gcp/workbench/instance.py +42 -26
  932. pulumi_gcp/workflows/workflow.py +98 -0
  933. pulumi_gcp/workstations/workstation.py +26 -30
  934. pulumi_gcp/workstations/workstation_cluster.py +48 -48
  935. pulumi_gcp/workstations/workstation_config.py +182 -194
  936. {pulumi_gcp-7.12.0a1709102105.dist-info → pulumi_gcp-7.12.0a1709149267.dist-info}/METADATA +1 -1
  937. pulumi_gcp-7.12.0a1709149267.dist-info/RECORD +1489 -0
  938. pulumi_gcp-7.12.0a1709102105.dist-info/RECORD +0 -1489
  939. {pulumi_gcp-7.12.0a1709102105.dist-info → pulumi_gcp-7.12.0a1709149267.dist-info}/WHEEL +0 -0
  940. {pulumi_gcp-7.12.0a1709102105.dist-info → pulumi_gcp-7.12.0a1709149267.dist-info}/top_level.txt +0 -0
@@ -493,6 +493,164 @@ class Function(pulumi.CustomResource):
493
493
  * [API documentation](https://cloud.google.com/functions/docs/reference/rest/v2beta/projects.locations.functions)
494
494
 
495
495
  ## Example Usage
496
+ ### Cloudfunctions2 Basic
497
+
498
+ ```python
499
+ import pulumi
500
+ import pulumi_gcp as gcp
501
+
502
+ project = "my-project-name"
503
+ bucket = gcp.storage.Bucket("bucket",
504
+ name=f"{project}-gcf-source",
505
+ location="US",
506
+ uniform_bucket_level_access=True)
507
+ object = gcp.storage.BucketObject("object",
508
+ name="function-source.zip",
509
+ bucket=bucket.name,
510
+ source=pulumi.FileAsset("function-source.zip"))
511
+ function = gcp.cloudfunctionsv2.Function("function",
512
+ name="function-v2",
513
+ location="us-central1",
514
+ description="a new function",
515
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
516
+ runtime="nodejs16",
517
+ entry_point="helloHttp",
518
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
519
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
520
+ bucket=bucket.name,
521
+ object=object.name,
522
+ ),
523
+ ),
524
+ ),
525
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
526
+ max_instance_count=1,
527
+ available_memory="256M",
528
+ timeout_seconds=60,
529
+ ))
530
+ pulumi.export("functionUri", function.service_config.uri)
531
+ ```
532
+ ### Cloudfunctions2 Full
533
+
534
+ ```python
535
+ import pulumi
536
+ import pulumi_gcp as gcp
537
+
538
+ project = "my-project-name"
539
+ account = gcp.serviceaccount.Account("account",
540
+ account_id="gcf-sa",
541
+ display_name="Test Service Account")
542
+ topic = gcp.pubsub.Topic("topic", name="functions2-topic")
543
+ bucket = gcp.storage.Bucket("bucket",
544
+ name=f"{project}-gcf-source",
545
+ location="US",
546
+ uniform_bucket_level_access=True)
547
+ object = gcp.storage.BucketObject("object",
548
+ name="function-source.zip",
549
+ bucket=bucket.name,
550
+ source=pulumi.FileAsset("function-source.zip"))
551
+ function = gcp.cloudfunctionsv2.Function("function",
552
+ name="gcf-function",
553
+ location="us-central1",
554
+ description="a new function",
555
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
556
+ runtime="nodejs16",
557
+ entry_point="helloPubSub",
558
+ environment_variables={
559
+ "BUILD_CONFIG_TEST": "build_test",
560
+ },
561
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
562
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
563
+ bucket=bucket.name,
564
+ object=object.name,
565
+ ),
566
+ ),
567
+ ),
568
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
569
+ max_instance_count=3,
570
+ min_instance_count=1,
571
+ available_memory="4Gi",
572
+ timeout_seconds=60,
573
+ max_instance_request_concurrency=80,
574
+ available_cpu="4",
575
+ environment_variables={
576
+ "SERVICE_CONFIG_TEST": "config_test",
577
+ },
578
+ ingress_settings="ALLOW_INTERNAL_ONLY",
579
+ all_traffic_on_latest_revision=True,
580
+ service_account_email=account.email,
581
+ ),
582
+ event_trigger=gcp.cloudfunctionsv2.FunctionEventTriggerArgs(
583
+ trigger_region="us-central1",
584
+ event_type="google.cloud.pubsub.topic.v1.messagePublished",
585
+ pubsub_topic=topic.id,
586
+ retry_policy="RETRY_POLICY_RETRY",
587
+ ))
588
+ ```
589
+ ### Cloudfunctions2 Scheduler Auth
590
+
591
+ ```python
592
+ import pulumi
593
+ import pulumi_gcp as gcp
594
+
595
+ project = "my-project-name"
596
+ account = gcp.serviceaccount.Account("account",
597
+ account_id="gcf-sa",
598
+ display_name="Test Service Account")
599
+ bucket = gcp.storage.Bucket("bucket",
600
+ name=f"{project}-gcf-source",
601
+ location="US",
602
+ uniform_bucket_level_access=True)
603
+ object = gcp.storage.BucketObject("object",
604
+ name="function-source.zip",
605
+ bucket=bucket.name,
606
+ source=pulumi.FileAsset("function-source.zip"))
607
+ function = gcp.cloudfunctionsv2.Function("function",
608
+ name="gcf-function",
609
+ location="us-central1",
610
+ description="a new function",
611
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
612
+ runtime="nodejs16",
613
+ entry_point="helloHttp",
614
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
615
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
616
+ bucket=bucket.name,
617
+ object=object.name,
618
+ ),
619
+ ),
620
+ ),
621
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
622
+ min_instance_count=1,
623
+ available_memory="256M",
624
+ timeout_seconds=60,
625
+ service_account_email=account.email,
626
+ ))
627
+ invoker = gcp.cloudfunctionsv2.FunctionIamMember("invoker",
628
+ project=function.project,
629
+ location=function.location,
630
+ cloud_function=function.name,
631
+ role="roles/cloudfunctions.invoker",
632
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
633
+ cloud_run_invoker = gcp.cloudrun.IamMember("cloud_run_invoker",
634
+ project=function.project,
635
+ location=function.location,
636
+ service=function.name,
637
+ role="roles/run.invoker",
638
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
639
+ invoke_cloud_function = gcp.cloudscheduler.Job("invoke_cloud_function",
640
+ name="invoke-gcf-function",
641
+ description="Schedule the HTTPS trigger for cloud function",
642
+ schedule="0 0 * * *",
643
+ project=function.project,
644
+ region=function.location,
645
+ http_target=gcp.cloudscheduler.JobHttpTargetArgs(
646
+ uri=function.service_config.uri,
647
+ http_method="POST",
648
+ oidc_token=gcp.cloudscheduler.JobHttpTargetOidcTokenArgs(
649
+ audience=function.service_config.apply(lambda service_config: f"{service_config.uri}/"),
650
+ service_account_email=account.email,
651
+ ),
652
+ ))
653
+ ```
496
654
  ### Cloudfunctions2 Basic Gcs
497
655
 
498
656
  ```python
@@ -500,13 +658,15 @@ class Function(pulumi.CustomResource):
500
658
  import pulumi_gcp as gcp
501
659
 
502
660
  source_bucket = gcp.storage.Bucket("source-bucket",
661
+ name="gcf-source-bucket",
503
662
  location="US",
504
663
  uniform_bucket_level_access=True)
505
664
  object = gcp.storage.BucketObject("object",
665
+ name="function-source.zip",
506
666
  bucket=source_bucket.name,
507
667
  source=pulumi.FileAsset("function-source.zip"))
508
- # Add path to the zipped function source code
509
668
  trigger_bucket = gcp.storage.Bucket("trigger-bucket",
669
+ name="gcf-trigger-bucket",
510
670
  location="us-central1",
511
671
  uniform_bucket_level_access=True)
512
672
  gcs_account = gcp.storage.get_project_service_account()
@@ -523,19 +683,17 @@ class Function(pulumi.CustomResource):
523
683
  invoking = gcp.projects.IAMMember("invoking",
524
684
  project="my-project-name",
525
685
  role="roles/run.invoker",
526
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
527
- opts=pulumi.ResourceOptions(depends_on=[gcs_pubsub_publishing]))
686
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
528
687
  event_receiving = gcp.projects.IAMMember("event-receiving",
529
688
  project="my-project-name",
530
689
  role="roles/eventarc.eventReceiver",
531
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
532
- opts=pulumi.ResourceOptions(depends_on=[invoking]))
690
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
533
691
  artifactregistry_reader = gcp.projects.IAMMember("artifactregistry-reader",
534
692
  project="my-project-name",
535
693
  role="roles/artifactregistry.reader",
536
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
537
- opts=pulumi.ResourceOptions(depends_on=[event_receiving]))
694
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
538
695
  function = gcp.cloudfunctionsv2.Function("function",
696
+ name="gcf-function",
539
697
  location="us-central1",
540
698
  description="a new function",
541
699
  build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
@@ -572,11 +730,7 @@ class Function(pulumi.CustomResource):
572
730
  attribute="bucket",
573
731
  value=trigger_bucket.name,
574
732
  )],
575
- ),
576
- opts=pulumi.ResourceOptions(depends_on=[
577
- event_receiving,
578
- artifactregistry_reader,
579
- ]))
733
+ ))
580
734
  ```
581
735
  ### Cloudfunctions2 Basic Auditlogs
582
736
 
@@ -589,12 +743,13 @@ class Function(pulumi.CustomResource):
589
743
  # and the docs:
590
744
  # https://cloud.google.com/eventarc/docs/path-patterns
591
745
  source_bucket = gcp.storage.Bucket("source-bucket",
746
+ name="gcf-source-bucket",
592
747
  location="US",
593
748
  uniform_bucket_level_access=True)
594
749
  object = gcp.storage.BucketObject("object",
750
+ name="function-source.zip",
595
751
  bucket=source_bucket.name,
596
752
  source=pulumi.FileAsset("function-source.zip"))
597
- # Add path to the zipped function source code
598
753
  account = gcp.serviceaccount.Account("account",
599
754
  account_id="gcf-sa",
600
755
  display_name="Test Service Account - used for both the cloud function and eventarc trigger in the test")
@@ -602,6 +757,7 @@ class Function(pulumi.CustomResource):
602
757
  # Here we use Audit Logs to monitor the bucket so path patterns can be used in the example of
603
758
  # google_cloudfunctions2_function below (Audit Log events have path pattern support)
604
759
  audit_log_bucket = gcp.storage.Bucket("audit-log-bucket",
760
+ name="gcf-auditlog-bucket",
605
761
  location="us-central1",
606
762
  uniform_bucket_level_access=True)
607
763
  # Permissions on the service account used by the function and Eventarc trigger
@@ -612,14 +768,13 @@ class Function(pulumi.CustomResource):
612
768
  event_receiving = gcp.projects.IAMMember("event-receiving",
613
769
  project="my-project-name",
614
770
  role="roles/eventarc.eventReceiver",
615
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
616
- opts=pulumi.ResourceOptions(depends_on=[invoking]))
771
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
617
772
  artifactregistry_reader = gcp.projects.IAMMember("artifactregistry-reader",
618
773
  project="my-project-name",
619
774
  role="roles/artifactregistry.reader",
620
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
621
- opts=pulumi.ResourceOptions(depends_on=[event_receiving]))
775
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
622
776
  function = gcp.cloudfunctionsv2.Function("function",
777
+ name="gcf-function",
623
778
  location="us-central1",
624
779
  description="a new function",
625
780
  build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
@@ -667,11 +822,223 @@ class Function(pulumi.CustomResource):
667
822
  operator="match-path-pattern",
668
823
  ),
669
824
  ],
825
+ ))
826
+ ```
827
+ ### Cloudfunctions2 Secret Env
828
+
829
+ ```python
830
+ import pulumi
831
+ import pulumi_gcp as gcp
832
+
833
+ project = "my-project-name"
834
+ bucket = gcp.storage.Bucket("bucket",
835
+ name=f"{project}-gcf-source",
836
+ location="US",
837
+ uniform_bucket_level_access=True)
838
+ object = gcp.storage.BucketObject("object",
839
+ name="function-source.zip",
840
+ bucket=bucket.name,
841
+ source=pulumi.FileAsset("function-source.zip"))
842
+ secret = gcp.secretmanager.Secret("secret",
843
+ secret_id="secret",
844
+ replication=gcp.secretmanager.SecretReplicationArgs(
845
+ user_managed=gcp.secretmanager.SecretReplicationUserManagedArgs(
846
+ replicas=[gcp.secretmanager.SecretReplicationUserManagedReplicaArgs(
847
+ location="us-central1",
848
+ )],
849
+ ),
850
+ ))
851
+ function = gcp.cloudfunctionsv2.Function("function",
852
+ name="function-secret",
853
+ location="us-central1",
854
+ description="a new function",
855
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
856
+ runtime="nodejs16",
857
+ entry_point="helloHttp",
858
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
859
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
860
+ bucket=bucket.name,
861
+ object=object.name,
862
+ ),
863
+ ),
864
+ ),
865
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
866
+ max_instance_count=1,
867
+ available_memory="256M",
868
+ timeout_seconds=60,
869
+ secret_environment_variables=[gcp.cloudfunctionsv2.FunctionServiceConfigSecretEnvironmentVariableArgs(
870
+ key="TEST",
871
+ project_id=project,
872
+ secret=secret.secret_id,
873
+ version="latest",
874
+ )],
875
+ ))
876
+ secret_secret_version = gcp.secretmanager.SecretVersion("secret",
877
+ secret=secret.name,
878
+ secret_data="secret",
879
+ enabled=True)
880
+ ```
881
+ ### Cloudfunctions2 Secret Volume
882
+
883
+ ```python
884
+ import pulumi
885
+ import pulumi_gcp as gcp
886
+
887
+ project = "my-project-name"
888
+ bucket = gcp.storage.Bucket("bucket",
889
+ name=f"{project}-gcf-source",
890
+ location="US",
891
+ uniform_bucket_level_access=True)
892
+ object = gcp.storage.BucketObject("object",
893
+ name="function-source.zip",
894
+ bucket=bucket.name,
895
+ source=pulumi.FileAsset("function-source.zip"))
896
+ secret = gcp.secretmanager.Secret("secret",
897
+ secret_id="secret",
898
+ replication=gcp.secretmanager.SecretReplicationArgs(
899
+ user_managed=gcp.secretmanager.SecretReplicationUserManagedArgs(
900
+ replicas=[gcp.secretmanager.SecretReplicationUserManagedReplicaArgs(
901
+ location="us-central1",
902
+ )],
903
+ ),
904
+ ))
905
+ function = gcp.cloudfunctionsv2.Function("function",
906
+ name="function-secret",
907
+ location="us-central1",
908
+ description="a new function",
909
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
910
+ runtime="nodejs16",
911
+ entry_point="helloHttp",
912
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
913
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
914
+ bucket=bucket.name,
915
+ object=object.name,
916
+ ),
917
+ ),
918
+ ),
919
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
920
+ max_instance_count=1,
921
+ available_memory="256M",
922
+ timeout_seconds=60,
923
+ secret_volumes=[gcp.cloudfunctionsv2.FunctionServiceConfigSecretVolumeArgs(
924
+ mount_path="/etc/secrets",
925
+ project_id=project,
926
+ secret=secret.secret_id,
927
+ )],
928
+ ))
929
+ secret_secret_version = gcp.secretmanager.SecretVersion("secret",
930
+ secret=secret.name,
931
+ secret_data="secret",
932
+ enabled=True)
933
+ ```
934
+ ### Cloudfunctions2 Private Workerpool
935
+
936
+ ```python
937
+ import pulumi
938
+ import pulumi_gcp as gcp
939
+
940
+ project = "my-project-name"
941
+ bucket = gcp.storage.Bucket("bucket",
942
+ name=f"{project}-gcf-source",
943
+ location="US",
944
+ uniform_bucket_level_access=True)
945
+ object = gcp.storage.BucketObject("object",
946
+ name="function-source.zip",
947
+ bucket=bucket.name,
948
+ source=pulumi.FileAsset("function-source.zip"))
949
+ pool = gcp.cloudbuild.WorkerPool("pool",
950
+ name="workerpool",
951
+ location="us-central1",
952
+ worker_config=gcp.cloudbuild.WorkerPoolWorkerConfigArgs(
953
+ disk_size_gb=100,
954
+ machine_type="e2-standard-8",
955
+ no_external_ip=False,
956
+ ))
957
+ function = gcp.cloudfunctionsv2.Function("function",
958
+ name="function-workerpool",
959
+ location="us-central1",
960
+ description="a new function",
961
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
962
+ runtime="nodejs16",
963
+ entry_point="helloHttp",
964
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
965
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
966
+ bucket=bucket.name,
967
+ object=object.name,
968
+ ),
969
+ ),
970
+ worker_pool=pool.id,
670
971
  ),
671
- opts=pulumi.ResourceOptions(depends_on=[
672
- event_receiving,
673
- artifactregistry_reader,
674
- ]))
972
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
973
+ max_instance_count=1,
974
+ available_memory="256M",
975
+ timeout_seconds=60,
976
+ ))
977
+ ```
978
+ ### Cloudfunctions2 Cmek Docs
979
+
980
+ ```python
981
+ import pulumi
982
+ import pulumi_gcp as gcp
983
+
984
+ project = "my-project-name"
985
+ project_get_project = gcp.organizations.get_project()
986
+ bucket = gcp.storage.Bucket("bucket",
987
+ name=f"{project}-gcf-source",
988
+ location="US",
989
+ uniform_bucket_level_access=True)
990
+ object = gcp.storage.BucketObject("object",
991
+ name="function-source.zip",
992
+ bucket=bucket.name,
993
+ source=pulumi.FileAsset("function-source.zip"))
994
+ ea_sa = gcp.projects.ServiceIdentity("ea_sa",
995
+ project=project_get_project.project_id,
996
+ service="eventarc.googleapis.com")
997
+ unencoded_ar_repo = gcp.artifactregistry.Repository("unencoded-ar-repo",
998
+ repository_id="ar-repo",
999
+ location="us-central1",
1000
+ format="DOCKER")
1001
+ encoded_ar_repo = gcp.artifactregistry.Repository("encoded-ar-repo",
1002
+ location="us-central1",
1003
+ repository_id="cmek-repo",
1004
+ format="DOCKER",
1005
+ kms_key_name="cmek-key")
1006
+ binding = gcp.artifactregistry.RepositoryIamBinding("binding",
1007
+ location=encoded_ar_repo.location,
1008
+ repository=encoded_ar_repo.name,
1009
+ role="roles/artifactregistry.admin",
1010
+ members=[f"serviceAccount:service-{project_get_project.number}@gcf-admin-robot.iam.gserviceaccount.com"])
1011
+ gcf_cmek_keyuser = gcp.kms.CryptoKeyIAMBinding("gcf_cmek_keyuser",
1012
+ crypto_key_id="cmek-key",
1013
+ role="roles/cloudkms.cryptoKeyEncrypterDecrypter",
1014
+ members=[
1015
+ f"serviceAccount:service-{project_get_project.number}@gcf-admin-robot.iam.gserviceaccount.com",
1016
+ f"serviceAccount:service-{project_get_project.number}@gcp-sa-artifactregistry.iam.gserviceaccount.com",
1017
+ f"serviceAccount:service-{project_get_project.number}@gs-project-accounts.iam.gserviceaccount.com",
1018
+ f"serviceAccount:service-{project_get_project.number}@serverless-robot-prod.iam.gserviceaccount.com",
1019
+ ea_sa.email.apply(lambda email: f"serviceAccount:{email}"),
1020
+ ])
1021
+ function = gcp.cloudfunctionsv2.Function("function",
1022
+ name="function-cmek",
1023
+ location="us-central1",
1024
+ description="CMEK function",
1025
+ kms_key_name="cmek-key",
1026
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1027
+ runtime="nodejs16",
1028
+ entry_point="helloHttp",
1029
+ docker_repository=encoded_ar_repo.id,
1030
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1031
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1032
+ bucket=bucket.name,
1033
+ object=object.name,
1034
+ ),
1035
+ ),
1036
+ ),
1037
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1038
+ max_instance_count=1,
1039
+ available_memory="256M",
1040
+ timeout_seconds=60,
1041
+ ))
675
1042
  ```
676
1043
 
677
1044
  ## Import
@@ -738,6 +1105,164 @@ class Function(pulumi.CustomResource):
738
1105
  * [API documentation](https://cloud.google.com/functions/docs/reference/rest/v2beta/projects.locations.functions)
739
1106
 
740
1107
  ## Example Usage
1108
+ ### Cloudfunctions2 Basic
1109
+
1110
+ ```python
1111
+ import pulumi
1112
+ import pulumi_gcp as gcp
1113
+
1114
+ project = "my-project-name"
1115
+ bucket = gcp.storage.Bucket("bucket",
1116
+ name=f"{project}-gcf-source",
1117
+ location="US",
1118
+ uniform_bucket_level_access=True)
1119
+ object = gcp.storage.BucketObject("object",
1120
+ name="function-source.zip",
1121
+ bucket=bucket.name,
1122
+ source=pulumi.FileAsset("function-source.zip"))
1123
+ function = gcp.cloudfunctionsv2.Function("function",
1124
+ name="function-v2",
1125
+ location="us-central1",
1126
+ description="a new function",
1127
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1128
+ runtime="nodejs16",
1129
+ entry_point="helloHttp",
1130
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1131
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1132
+ bucket=bucket.name,
1133
+ object=object.name,
1134
+ ),
1135
+ ),
1136
+ ),
1137
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1138
+ max_instance_count=1,
1139
+ available_memory="256M",
1140
+ timeout_seconds=60,
1141
+ ))
1142
+ pulumi.export("functionUri", function.service_config.uri)
1143
+ ```
1144
+ ### Cloudfunctions2 Full
1145
+
1146
+ ```python
1147
+ import pulumi
1148
+ import pulumi_gcp as gcp
1149
+
1150
+ project = "my-project-name"
1151
+ account = gcp.serviceaccount.Account("account",
1152
+ account_id="gcf-sa",
1153
+ display_name="Test Service Account")
1154
+ topic = gcp.pubsub.Topic("topic", name="functions2-topic")
1155
+ bucket = gcp.storage.Bucket("bucket",
1156
+ name=f"{project}-gcf-source",
1157
+ location="US",
1158
+ uniform_bucket_level_access=True)
1159
+ object = gcp.storage.BucketObject("object",
1160
+ name="function-source.zip",
1161
+ bucket=bucket.name,
1162
+ source=pulumi.FileAsset("function-source.zip"))
1163
+ function = gcp.cloudfunctionsv2.Function("function",
1164
+ name="gcf-function",
1165
+ location="us-central1",
1166
+ description="a new function",
1167
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1168
+ runtime="nodejs16",
1169
+ entry_point="helloPubSub",
1170
+ environment_variables={
1171
+ "BUILD_CONFIG_TEST": "build_test",
1172
+ },
1173
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1174
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1175
+ bucket=bucket.name,
1176
+ object=object.name,
1177
+ ),
1178
+ ),
1179
+ ),
1180
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1181
+ max_instance_count=3,
1182
+ min_instance_count=1,
1183
+ available_memory="4Gi",
1184
+ timeout_seconds=60,
1185
+ max_instance_request_concurrency=80,
1186
+ available_cpu="4",
1187
+ environment_variables={
1188
+ "SERVICE_CONFIG_TEST": "config_test",
1189
+ },
1190
+ ingress_settings="ALLOW_INTERNAL_ONLY",
1191
+ all_traffic_on_latest_revision=True,
1192
+ service_account_email=account.email,
1193
+ ),
1194
+ event_trigger=gcp.cloudfunctionsv2.FunctionEventTriggerArgs(
1195
+ trigger_region="us-central1",
1196
+ event_type="google.cloud.pubsub.topic.v1.messagePublished",
1197
+ pubsub_topic=topic.id,
1198
+ retry_policy="RETRY_POLICY_RETRY",
1199
+ ))
1200
+ ```
1201
+ ### Cloudfunctions2 Scheduler Auth
1202
+
1203
+ ```python
1204
+ import pulumi
1205
+ import pulumi_gcp as gcp
1206
+
1207
+ project = "my-project-name"
1208
+ account = gcp.serviceaccount.Account("account",
1209
+ account_id="gcf-sa",
1210
+ display_name="Test Service Account")
1211
+ bucket = gcp.storage.Bucket("bucket",
1212
+ name=f"{project}-gcf-source",
1213
+ location="US",
1214
+ uniform_bucket_level_access=True)
1215
+ object = gcp.storage.BucketObject("object",
1216
+ name="function-source.zip",
1217
+ bucket=bucket.name,
1218
+ source=pulumi.FileAsset("function-source.zip"))
1219
+ function = gcp.cloudfunctionsv2.Function("function",
1220
+ name="gcf-function",
1221
+ location="us-central1",
1222
+ description="a new function",
1223
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1224
+ runtime="nodejs16",
1225
+ entry_point="helloHttp",
1226
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1227
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1228
+ bucket=bucket.name,
1229
+ object=object.name,
1230
+ ),
1231
+ ),
1232
+ ),
1233
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1234
+ min_instance_count=1,
1235
+ available_memory="256M",
1236
+ timeout_seconds=60,
1237
+ service_account_email=account.email,
1238
+ ))
1239
+ invoker = gcp.cloudfunctionsv2.FunctionIamMember("invoker",
1240
+ project=function.project,
1241
+ location=function.location,
1242
+ cloud_function=function.name,
1243
+ role="roles/cloudfunctions.invoker",
1244
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
1245
+ cloud_run_invoker = gcp.cloudrun.IamMember("cloud_run_invoker",
1246
+ project=function.project,
1247
+ location=function.location,
1248
+ service=function.name,
1249
+ role="roles/run.invoker",
1250
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
1251
+ invoke_cloud_function = gcp.cloudscheduler.Job("invoke_cloud_function",
1252
+ name="invoke-gcf-function",
1253
+ description="Schedule the HTTPS trigger for cloud function",
1254
+ schedule="0 0 * * *",
1255
+ project=function.project,
1256
+ region=function.location,
1257
+ http_target=gcp.cloudscheduler.JobHttpTargetArgs(
1258
+ uri=function.service_config.uri,
1259
+ http_method="POST",
1260
+ oidc_token=gcp.cloudscheduler.JobHttpTargetOidcTokenArgs(
1261
+ audience=function.service_config.apply(lambda service_config: f"{service_config.uri}/"),
1262
+ service_account_email=account.email,
1263
+ ),
1264
+ ))
1265
+ ```
741
1266
  ### Cloudfunctions2 Basic Gcs
742
1267
 
743
1268
  ```python
@@ -745,13 +1270,15 @@ class Function(pulumi.CustomResource):
745
1270
  import pulumi_gcp as gcp
746
1271
 
747
1272
  source_bucket = gcp.storage.Bucket("source-bucket",
1273
+ name="gcf-source-bucket",
748
1274
  location="US",
749
1275
  uniform_bucket_level_access=True)
750
1276
  object = gcp.storage.BucketObject("object",
1277
+ name="function-source.zip",
751
1278
  bucket=source_bucket.name,
752
1279
  source=pulumi.FileAsset("function-source.zip"))
753
- # Add path to the zipped function source code
754
1280
  trigger_bucket = gcp.storage.Bucket("trigger-bucket",
1281
+ name="gcf-trigger-bucket",
755
1282
  location="us-central1",
756
1283
  uniform_bucket_level_access=True)
757
1284
  gcs_account = gcp.storage.get_project_service_account()
@@ -768,19 +1295,17 @@ class Function(pulumi.CustomResource):
768
1295
  invoking = gcp.projects.IAMMember("invoking",
769
1296
  project="my-project-name",
770
1297
  role="roles/run.invoker",
771
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
772
- opts=pulumi.ResourceOptions(depends_on=[gcs_pubsub_publishing]))
1298
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
773
1299
  event_receiving = gcp.projects.IAMMember("event-receiving",
774
1300
  project="my-project-name",
775
1301
  role="roles/eventarc.eventReceiver",
776
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
777
- opts=pulumi.ResourceOptions(depends_on=[invoking]))
1302
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
778
1303
  artifactregistry_reader = gcp.projects.IAMMember("artifactregistry-reader",
779
1304
  project="my-project-name",
780
1305
  role="roles/artifactregistry.reader",
781
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
782
- opts=pulumi.ResourceOptions(depends_on=[event_receiving]))
1306
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
783
1307
  function = gcp.cloudfunctionsv2.Function("function",
1308
+ name="gcf-function",
784
1309
  location="us-central1",
785
1310
  description="a new function",
786
1311
  build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
@@ -817,11 +1342,7 @@ class Function(pulumi.CustomResource):
817
1342
  attribute="bucket",
818
1343
  value=trigger_bucket.name,
819
1344
  )],
820
- ),
821
- opts=pulumi.ResourceOptions(depends_on=[
822
- event_receiving,
823
- artifactregistry_reader,
824
- ]))
1345
+ ))
825
1346
  ```
826
1347
  ### Cloudfunctions2 Basic Auditlogs
827
1348
 
@@ -834,12 +1355,13 @@ class Function(pulumi.CustomResource):
834
1355
  # and the docs:
835
1356
  # https://cloud.google.com/eventarc/docs/path-patterns
836
1357
  source_bucket = gcp.storage.Bucket("source-bucket",
1358
+ name="gcf-source-bucket",
837
1359
  location="US",
838
1360
  uniform_bucket_level_access=True)
839
1361
  object = gcp.storage.BucketObject("object",
1362
+ name="function-source.zip",
840
1363
  bucket=source_bucket.name,
841
1364
  source=pulumi.FileAsset("function-source.zip"))
842
- # Add path to the zipped function source code
843
1365
  account = gcp.serviceaccount.Account("account",
844
1366
  account_id="gcf-sa",
845
1367
  display_name="Test Service Account - used for both the cloud function and eventarc trigger in the test")
@@ -847,6 +1369,7 @@ class Function(pulumi.CustomResource):
847
1369
  # Here we use Audit Logs to monitor the bucket so path patterns can be used in the example of
848
1370
  # google_cloudfunctions2_function below (Audit Log events have path pattern support)
849
1371
  audit_log_bucket = gcp.storage.Bucket("audit-log-bucket",
1372
+ name="gcf-auditlog-bucket",
850
1373
  location="us-central1",
851
1374
  uniform_bucket_level_access=True)
852
1375
  # Permissions on the service account used by the function and Eventarc trigger
@@ -857,14 +1380,13 @@ class Function(pulumi.CustomResource):
857
1380
  event_receiving = gcp.projects.IAMMember("event-receiving",
858
1381
  project="my-project-name",
859
1382
  role="roles/eventarc.eventReceiver",
860
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
861
- opts=pulumi.ResourceOptions(depends_on=[invoking]))
1383
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
862
1384
  artifactregistry_reader = gcp.projects.IAMMember("artifactregistry-reader",
863
1385
  project="my-project-name",
864
1386
  role="roles/artifactregistry.reader",
865
- member=account.email.apply(lambda email: f"serviceAccount:{email}"),
866
- opts=pulumi.ResourceOptions(depends_on=[event_receiving]))
1387
+ member=account.email.apply(lambda email: f"serviceAccount:{email}"))
867
1388
  function = gcp.cloudfunctionsv2.Function("function",
1389
+ name="gcf-function",
868
1390
  location="us-central1",
869
1391
  description="a new function",
870
1392
  build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
@@ -912,11 +1434,223 @@ class Function(pulumi.CustomResource):
912
1434
  operator="match-path-pattern",
913
1435
  ),
914
1436
  ],
1437
+ ))
1438
+ ```
1439
+ ### Cloudfunctions2 Secret Env
1440
+
1441
+ ```python
1442
+ import pulumi
1443
+ import pulumi_gcp as gcp
1444
+
1445
+ project = "my-project-name"
1446
+ bucket = gcp.storage.Bucket("bucket",
1447
+ name=f"{project}-gcf-source",
1448
+ location="US",
1449
+ uniform_bucket_level_access=True)
1450
+ object = gcp.storage.BucketObject("object",
1451
+ name="function-source.zip",
1452
+ bucket=bucket.name,
1453
+ source=pulumi.FileAsset("function-source.zip"))
1454
+ secret = gcp.secretmanager.Secret("secret",
1455
+ secret_id="secret",
1456
+ replication=gcp.secretmanager.SecretReplicationArgs(
1457
+ user_managed=gcp.secretmanager.SecretReplicationUserManagedArgs(
1458
+ replicas=[gcp.secretmanager.SecretReplicationUserManagedReplicaArgs(
1459
+ location="us-central1",
1460
+ )],
1461
+ ),
1462
+ ))
1463
+ function = gcp.cloudfunctionsv2.Function("function",
1464
+ name="function-secret",
1465
+ location="us-central1",
1466
+ description="a new function",
1467
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1468
+ runtime="nodejs16",
1469
+ entry_point="helloHttp",
1470
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1471
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1472
+ bucket=bucket.name,
1473
+ object=object.name,
1474
+ ),
1475
+ ),
1476
+ ),
1477
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1478
+ max_instance_count=1,
1479
+ available_memory="256M",
1480
+ timeout_seconds=60,
1481
+ secret_environment_variables=[gcp.cloudfunctionsv2.FunctionServiceConfigSecretEnvironmentVariableArgs(
1482
+ key="TEST",
1483
+ project_id=project,
1484
+ secret=secret.secret_id,
1485
+ version="latest",
1486
+ )],
1487
+ ))
1488
+ secret_secret_version = gcp.secretmanager.SecretVersion("secret",
1489
+ secret=secret.name,
1490
+ secret_data="secret",
1491
+ enabled=True)
1492
+ ```
1493
+ ### Cloudfunctions2 Secret Volume
1494
+
1495
+ ```python
1496
+ import pulumi
1497
+ import pulumi_gcp as gcp
1498
+
1499
+ project = "my-project-name"
1500
+ bucket = gcp.storage.Bucket("bucket",
1501
+ name=f"{project}-gcf-source",
1502
+ location="US",
1503
+ uniform_bucket_level_access=True)
1504
+ object = gcp.storage.BucketObject("object",
1505
+ name="function-source.zip",
1506
+ bucket=bucket.name,
1507
+ source=pulumi.FileAsset("function-source.zip"))
1508
+ secret = gcp.secretmanager.Secret("secret",
1509
+ secret_id="secret",
1510
+ replication=gcp.secretmanager.SecretReplicationArgs(
1511
+ user_managed=gcp.secretmanager.SecretReplicationUserManagedArgs(
1512
+ replicas=[gcp.secretmanager.SecretReplicationUserManagedReplicaArgs(
1513
+ location="us-central1",
1514
+ )],
1515
+ ),
1516
+ ))
1517
+ function = gcp.cloudfunctionsv2.Function("function",
1518
+ name="function-secret",
1519
+ location="us-central1",
1520
+ description="a new function",
1521
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1522
+ runtime="nodejs16",
1523
+ entry_point="helloHttp",
1524
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1525
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1526
+ bucket=bucket.name,
1527
+ object=object.name,
1528
+ ),
1529
+ ),
1530
+ ),
1531
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1532
+ max_instance_count=1,
1533
+ available_memory="256M",
1534
+ timeout_seconds=60,
1535
+ secret_volumes=[gcp.cloudfunctionsv2.FunctionServiceConfigSecretVolumeArgs(
1536
+ mount_path="/etc/secrets",
1537
+ project_id=project,
1538
+ secret=secret.secret_id,
1539
+ )],
1540
+ ))
1541
+ secret_secret_version = gcp.secretmanager.SecretVersion("secret",
1542
+ secret=secret.name,
1543
+ secret_data="secret",
1544
+ enabled=True)
1545
+ ```
1546
+ ### Cloudfunctions2 Private Workerpool
1547
+
1548
+ ```python
1549
+ import pulumi
1550
+ import pulumi_gcp as gcp
1551
+
1552
+ project = "my-project-name"
1553
+ bucket = gcp.storage.Bucket("bucket",
1554
+ name=f"{project}-gcf-source",
1555
+ location="US",
1556
+ uniform_bucket_level_access=True)
1557
+ object = gcp.storage.BucketObject("object",
1558
+ name="function-source.zip",
1559
+ bucket=bucket.name,
1560
+ source=pulumi.FileAsset("function-source.zip"))
1561
+ pool = gcp.cloudbuild.WorkerPool("pool",
1562
+ name="workerpool",
1563
+ location="us-central1",
1564
+ worker_config=gcp.cloudbuild.WorkerPoolWorkerConfigArgs(
1565
+ disk_size_gb=100,
1566
+ machine_type="e2-standard-8",
1567
+ no_external_ip=False,
1568
+ ))
1569
+ function = gcp.cloudfunctionsv2.Function("function",
1570
+ name="function-workerpool",
1571
+ location="us-central1",
1572
+ description="a new function",
1573
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1574
+ runtime="nodejs16",
1575
+ entry_point="helloHttp",
1576
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1577
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1578
+ bucket=bucket.name,
1579
+ object=object.name,
1580
+ ),
1581
+ ),
1582
+ worker_pool=pool.id,
915
1583
  ),
916
- opts=pulumi.ResourceOptions(depends_on=[
917
- event_receiving,
918
- artifactregistry_reader,
919
- ]))
1584
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1585
+ max_instance_count=1,
1586
+ available_memory="256M",
1587
+ timeout_seconds=60,
1588
+ ))
1589
+ ```
1590
+ ### Cloudfunctions2 Cmek Docs
1591
+
1592
+ ```python
1593
+ import pulumi
1594
+ import pulumi_gcp as gcp
1595
+
1596
+ project = "my-project-name"
1597
+ project_get_project = gcp.organizations.get_project()
1598
+ bucket = gcp.storage.Bucket("bucket",
1599
+ name=f"{project}-gcf-source",
1600
+ location="US",
1601
+ uniform_bucket_level_access=True)
1602
+ object = gcp.storage.BucketObject("object",
1603
+ name="function-source.zip",
1604
+ bucket=bucket.name,
1605
+ source=pulumi.FileAsset("function-source.zip"))
1606
+ ea_sa = gcp.projects.ServiceIdentity("ea_sa",
1607
+ project=project_get_project.project_id,
1608
+ service="eventarc.googleapis.com")
1609
+ unencoded_ar_repo = gcp.artifactregistry.Repository("unencoded-ar-repo",
1610
+ repository_id="ar-repo",
1611
+ location="us-central1",
1612
+ format="DOCKER")
1613
+ encoded_ar_repo = gcp.artifactregistry.Repository("encoded-ar-repo",
1614
+ location="us-central1",
1615
+ repository_id="cmek-repo",
1616
+ format="DOCKER",
1617
+ kms_key_name="cmek-key")
1618
+ binding = gcp.artifactregistry.RepositoryIamBinding("binding",
1619
+ location=encoded_ar_repo.location,
1620
+ repository=encoded_ar_repo.name,
1621
+ role="roles/artifactregistry.admin",
1622
+ members=[f"serviceAccount:service-{project_get_project.number}@gcf-admin-robot.iam.gserviceaccount.com"])
1623
+ gcf_cmek_keyuser = gcp.kms.CryptoKeyIAMBinding("gcf_cmek_keyuser",
1624
+ crypto_key_id="cmek-key",
1625
+ role="roles/cloudkms.cryptoKeyEncrypterDecrypter",
1626
+ members=[
1627
+ f"serviceAccount:service-{project_get_project.number}@gcf-admin-robot.iam.gserviceaccount.com",
1628
+ f"serviceAccount:service-{project_get_project.number}@gcp-sa-artifactregistry.iam.gserviceaccount.com",
1629
+ f"serviceAccount:service-{project_get_project.number}@gs-project-accounts.iam.gserviceaccount.com",
1630
+ f"serviceAccount:service-{project_get_project.number}@serverless-robot-prod.iam.gserviceaccount.com",
1631
+ ea_sa.email.apply(lambda email: f"serviceAccount:{email}"),
1632
+ ])
1633
+ function = gcp.cloudfunctionsv2.Function("function",
1634
+ name="function-cmek",
1635
+ location="us-central1",
1636
+ description="CMEK function",
1637
+ kms_key_name="cmek-key",
1638
+ build_config=gcp.cloudfunctionsv2.FunctionBuildConfigArgs(
1639
+ runtime="nodejs16",
1640
+ entry_point="helloHttp",
1641
+ docker_repository=encoded_ar_repo.id,
1642
+ source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceArgs(
1643
+ storage_source=gcp.cloudfunctionsv2.FunctionBuildConfigSourceStorageSourceArgs(
1644
+ bucket=bucket.name,
1645
+ object=object.name,
1646
+ ),
1647
+ ),
1648
+ ),
1649
+ service_config=gcp.cloudfunctionsv2.FunctionServiceConfigArgs(
1650
+ max_instance_count=1,
1651
+ available_memory="256M",
1652
+ timeout_seconds=60,
1653
+ ))
920
1654
  ```
921
1655
 
922
1656
  ## Import