{"id":31445059,"url":"https://github.com/launchbynttdata/tf-azurerm-module_reference-postgresql_server","last_synced_at":"2026-05-15T22:33:26.463Z","repository":{"id":309161318,"uuid":"883196807","full_name":"launchbynttdata/tf-azurerm-module_reference-postgresql_server","owner":"launchbynttdata","description":null,"archived":false,"fork":false,"pushed_at":"2026-04-14T20:02:35.000Z","size":120,"stargazers_count":0,"open_issues_count":2,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-04-14T22:07:39.775Z","etag":null,"topics":["azure","infrastructure-as-code","platform-automation","reference","terraform"],"latest_commit_sha":null,"homepage":null,"language":"HCL","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/launchbynttdata.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":"CODEOWNERS","security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":"NOTICE","maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2024-11-04T14:43:25.000Z","updated_at":"2026-04-13T16:10:19.000Z","dependencies_parsed_at":"2025-08-10T09:20:02.509Z","dependency_job_id":"70c89554-3f91-42ed-891f-9bcb8c1cf3dd","html_url":"https://github.com/launchbynttdata/tf-azurerm-module_reference-postgresql_server","commit_stats":null,"previous_names":["launchbynttdata/tf-azurerm-module_reference-postgresql_server"],"tags_count":8,"template":false,"template_full_name":null,"purl":"pkg:github/launchbynttdata/tf-azurerm-module_reference-postgresql_server","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/launchbynttdata%2Ftf-azurerm-module_reference-postgresql_server","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/launchbynttdata%2Ftf-azurerm-module_reference-postgresql_server/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/launchbynttdata%2Ftf-azurerm-module_reference-postgresql_server/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/launchbynttdata%2Ftf-azurerm-module_reference-postgresql_server/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/launchbynttdata","download_url":"https://codeload.github.com/launchbynttdata/tf-azurerm-module_reference-postgresql_server/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/launchbynttdata%2Ftf-azurerm-module_reference-postgresql_server/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33082027,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-15T20:25:35.270Z","status":"ssl_error","status_checked_at":"2026-05-15T20:25:34.732Z","response_time":103,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["azure","infrastructure-as-code","platform-automation","reference","terraform"],"created_at":"2025-09-30T22:02:58.816Z","updated_at":"2026-05-15T22:33:26.457Z","avatar_url":"https://github.com/launchbynttdata.png","language":"HCL","funding_links":[],"categories":[],"sub_categories":[],"readme":"# tf-azurerm-module_reference-postgresql_server\n\n[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)\n[![License: CC BY-NC-ND 4.0](https://img.shields.io/badge/License-CC_BY--NC--ND_4.0-lightgrey.svg)](https://creativecommons.org/licenses/by-nc-nd/4.0/)\n\n## Overview\n\nThis module deploys a Azure Database for PostgreSQL Flexible Server and any related resources\n\n## Pre-Commit hooks\n\n[.pre-commit-config.yaml](.pre-commit-config.yaml) file defines certain `pre-commit` hooks that are relevant to terraform, golang and common linting tasks. There are no custom hooks added.\n\n`commitlint` hook enforces commit message in certain format. The commit contains the following structural elements, to communicate intent to the consumers of your commit messages:\n\n- **fix**: a commit of the type `fix` patches a bug in your codebase (this correlates with PATCH in Semantic Versioning).\n- **feat**: a commit of the type `feat` introduces a new feature to the codebase (this correlates with MINOR in Semantic Versioning).\n- **BREAKING CHANGE**: a commit that has a footer `BREAKING CHANGE:`, or appends a `!` after the type/scope, introduces a breaking API change (correlating with MAJOR in Semantic Versioning). A BREAKING CHANGE can be part of commits of any type.\nfooters other than BREAKING CHANGE: \u003cdescription\u003e may be provided and follow a convention similar to git trailer format.\n- **build**: a commit of the type `build` adds changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm)\n- **chore**: a commit of the type `chore` adds changes that don't modify src or test files\n- **ci**: a commit of the type `ci` adds changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs)\n- **docs**: a commit of the type `docs` adds documentation only changes\n- **perf**: a commit of the type `perf` adds code change that improves performance\n- **refactor**: a commit of the type `refactor` adds code change that neither fixes a bug nor adds a feature\n- **revert**: a commit of the type `revert` reverts a previous commit\n- **style**: a commit of the type `style` adds code changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)\n- **test**: a commit of the type `test` adds missing tests or correcting existing tests\n\nBase configuration used for this project is [commitlint-config-conventional (based on the Angular convention)](https://github.com/conventional-changelog/commitlint/tree/master/@commitlint/config-conventional#type-enum)\n\nIf you are a developer using vscode, [this](https://marketplace.visualstudio.com/items?itemName=joshbolduc.commitlint) plugin may be helpful.\n\n`detect-secrets-hook` prevents new secrets from being introduced into the baseline. TODO: INSERT DOC LINK ABOUT HOOKS\n\nIn order for `pre-commit` hooks to work properly\n\n- You need to have the pre-commit package manager installed. [Here](https://pre-commit.com/#install) are the installation instructions.\n- `pre-commit` would install all the hooks when commit message is added by default except for `commitlint` hook. `commitlint` hook would need to be installed manually using the command below\n\n```\npre-commit install --hook-type commit-msg\n```\n\n## To test the resource group module locally\n\n1. For development/enhancements to this module locally, you'll need to install all of its components. This is controlled by the `configure` target in the project's [`Makefile`](./Makefile). Before you can run `configure`, familiarize yourself with the variables in the `Makefile` and ensure they're pointing to the right places.\n\n```\nmake configure\n```\n\nThis adds in several files and directories that are ignored by `git`. They expose many new Make targets.\n\n2. _THIS STEP APPLIES ONLY TO MICROSOFT AZURE. IF YOU ARE USING A DIFFERENT PLATFORM PLEASE SKIP THIS STEP._ The first target you care about is `env`. This is the common interface for setting up environment variables. The values of the environment variables will be used to authenticate with cloud provider from local development workstation.\n\n`make configure` command will bring down `azure_env.sh` file on local workstation. Devloper would need to modify this file, replace the environment variable values with relevant values.\n\nThese environment variables are used by `terratest` integration suit.\n\nService principle used for authentication(value of ARM_CLIENT_ID) should have below privileges on resource group within the subscription.\n\n```\n\"Microsoft.Resources/subscriptions/resourceGroups/write\"\n\"Microsoft.Resources/subscriptions/resourceGroups/read\"\n\"Microsoft.Resources/subscriptions/resourceGroups/delete\"\n```\n\nThen run this make target to set the environment variables on developer workstation.\n\n```\nmake env\n```\n\n3. The first target you care about is `check`.\n\n**Pre-requisites**\nBefore running this target it is important to ensure that, developer has created files mentioned below on local workstation under root directory of git repository that contains code for primitives/segments. Note that these files are `azure` specific. If primitive/segment under development uses any other cloud provider than azure, this section may not be relevant.\n\n- A file named `provider.tf` with contents below\n\n```\nprovider \"azurerm\" {\n  features {}\n}\n```\n\n- A file named `terraform.tfvars` which contains key value pair of variables used.\n\nNote that since these files are added in `gitignore` they would not be checked in into primitive/segment's git repo.\n\nAfter creating these files, for running tests associated with the primitive/segment, run\n\n```\nmake check\n```\n\nIf `make check` target is successful, developer is good to commit the code to primitive/segment's git repo.\n\n`make check` target\n\n- runs `terraform commands` to `lint`,`validate` and `plan` terraform code.\n- runs `conftests`. `conftests` make sure `policy` checks are successful.\n- runs `terratest`. This is integration test suit.\n- runs `opa` tests\n\u003c!-- BEGIN_TF_DOCS --\u003e\n## Requirements\n\n| Name | Version |\n|------|---------|\n| \u003ca name=\"requirement_terraform\"\u003e\u003c/a\u003e [terraform](#requirement\\_terraform) | ~\u003e 1.0 |\n| \u003ca name=\"requirement_azurerm\"\u003e\u003c/a\u003e [azurerm](#requirement\\_azurerm) | ~\u003e 3.113 |\n\n## Providers\n\nNo providers.\n\n## Modules\n\n| Name | Source | Version |\n|------|--------|---------|\n| \u003ca name=\"module_resource_names\"\u003e\u003c/a\u003e [resource\\_names](#module\\_resource\\_names) | terraform.registry.launch.nttdata.com/module_library/resource_name/launch | ~\u003e 2.0 |\n| \u003ca name=\"module_resource_group\"\u003e\u003c/a\u003e [resource\\_group](#module\\_resource\\_group) | terraform.registry.launch.nttdata.com/module_primitive/resource_group/azurerm | ~\u003e 1.0 |\n| \u003ca name=\"module_postgresql_server\"\u003e\u003c/a\u003e [postgresql\\_server](#module\\_postgresql\\_server) | terraform.registry.launch.nttdata.com/module_primitive/postgresql_server/azurerm | ~\u003e 1.1 |\n| \u003ca name=\"module_postgresql_server_configuration\"\u003e\u003c/a\u003e [postgresql\\_server\\_configuration](#module\\_postgresql\\_server\\_configuration) | terraform.registry.launch.nttdata.com/module_primitive/postgresql_server_configuration/azurerm | ~\u003e 1.0 |\n| \u003ca name=\"module_postgresql_server_ad_administrator\"\u003e\u003c/a\u003e [postgresql\\_server\\_ad\\_administrator](#module\\_postgresql\\_server\\_ad\\_administrator) | terraform.registry.launch.nttdata.com/module_primitive/postgresql_server_ad_administrator/azurerm | ~\u003e 1.0 |\n| \u003ca name=\"module_private_endpoint\"\u003e\u003c/a\u003e [private\\_endpoint](#module\\_private\\_endpoint) | terraform.registry.launch.nttdata.com/module_primitive/private_endpoint/azurerm | ~\u003e 1.0 |\n| \u003ca name=\"module_monitor_action_group\"\u003e\u003c/a\u003e [monitor\\_action\\_group](#module\\_monitor\\_action\\_group) | terraform.registry.launch.nttdata.com/module_primitive/monitor_action_group/azurerm | ~\u003e 1.0.0 |\n| \u003ca name=\"module_monitor_metric_alert\"\u003e\u003c/a\u003e [monitor\\_metric\\_alert](#module\\_monitor\\_metric\\_alert) | terraform.registry.launch.nttdata.com/module_primitive/monitor_metric_alert/azurerm | ~\u003e 2.0 |\n\n## Resources\n\nNo resources.\n\n## Inputs\n\n| Name | Description | Type | Default | Required |\n|------|-------------|------|---------|:--------:|\n| \u003ca name=\"input_resource_names_map\"\u003e\u003c/a\u003e [resource\\_names\\_map](#input\\_resource\\_names\\_map) | A map of key to resource\\_name that will be used by tf-launch-module\\_library-resource\\_name to generate resource names | \u003cpre\u003emap(object({\u003cbr\u003e    name       = string\u003cbr\u003e    max_length = optional(number, 60)\u003cbr\u003e  }))\u003c/pre\u003e | \u003cpre\u003e{\u003cbr\u003e  \"postgresql_server\": {\u003cbr\u003e    \"max_length\": 60,\u003cbr\u003e    \"name\": \"psql\"\u003cbr\u003e  },\u003cbr\u003e  \"private_endpoint\": {\u003cbr\u003e    \"max_length\": 80,\u003cbr\u003e    \"name\": \"pe\"\u003cbr\u003e  },\u003cbr\u003e  \"private_service_connection\": {\u003cbr\u003e    \"max_length\": 80,\u003cbr\u003e    \"name\": \"pesc\"\u003cbr\u003e  },\u003cbr\u003e  \"resource_group\": {\u003cbr\u003e    \"max_length\": 60,\u003cbr\u003e    \"name\": \"rg\"\u003cbr\u003e  }\u003cbr\u003e}\u003c/pre\u003e | no |\n| \u003ca name=\"input_instance_env\"\u003e\u003c/a\u003e [instance\\_env](#input\\_instance\\_env) | Number that represents the instance of the environment. | `number` | `0` | no |\n| \u003ca name=\"input_instance_resource\"\u003e\u003c/a\u003e [instance\\_resource](#input\\_instance\\_resource) | Number that represents the instance of the resource. | `number` | `0` | no |\n| \u003ca name=\"input_logical_product_family\"\u003e\u003c/a\u003e [logical\\_product\\_family](#input\\_logical\\_product\\_family) | (Required) Name of the product family for which the resource is created.\u003cbr\u003e    Example: org\\_name, department\\_name. | `string` | `\"launch\"` | no |\n| \u003ca name=\"input_logical_product_service\"\u003e\u003c/a\u003e [logical\\_product\\_service](#input\\_logical\\_product\\_service) | (Required) Name of the product service for which the resource is created.\u003cbr\u003e    For example, backend, frontend, middleware etc. | `string` | `\"database\"` | no |\n| \u003ca name=\"input_class_env\"\u003e\u003c/a\u003e [class\\_env](#input\\_class\\_env) | (Required) Environment where resource is going to be deployed. For example. dev, qa, uat | `string` | `\"dev\"` | no |\n| \u003ca name=\"input_use_azure_region_abbr\"\u003e\u003c/a\u003e [use\\_azure\\_region\\_abbr](#input\\_use\\_azure\\_region\\_abbr) | Abbreviate the region in the resource names | `bool` | `true` | no |\n| \u003ca name=\"input_location\"\u003e\u003c/a\u003e [location](#input\\_location) | Location of the Postgres Flexible Server | `string` | `\"eastus\"` | no |\n| \u003ca name=\"input_sku_name\"\u003e\u003c/a\u003e [sku\\_name](#input\\_sku\\_name) | The name of the SKU used by this Postgres Flexible Server | `string` | `\"B_Standard_B1ms\"` | no |\n| \u003ca name=\"input_create_mode\"\u003e\u003c/a\u003e [create\\_mode](#input\\_create\\_mode) | The creation mode. Possible values are Default, GeoRestore, PointInTimeRestore, Replica, and Update | `string` | `\"Default\"` | no |\n| \u003ca name=\"input_postgres_version\"\u003e\u003c/a\u003e [postgres\\_version](#input\\_postgres\\_version) | Version of the Postgres Flexible Server. Required when `create_mode` is Default | `string` | `\"16\"` | no |\n| \u003ca name=\"input_server_configuration\"\u003e\u003c/a\u003e [server\\_configuration](#input\\_server\\_configuration) | Map of configurations to apply to the postgres flexible server | `map(string)` | `{}` | no |\n| \u003ca name=\"input_delegated_subnet_id\"\u003e\u003c/a\u003e [delegated\\_subnet\\_id](#input\\_delegated\\_subnet\\_id) | The ID of the subnet to which the Postgres Flexible Server is delegated | `string` | `null` | no |\n| \u003ca name=\"input_private_dns_zone_id\"\u003e\u003c/a\u003e [private\\_dns\\_zone\\_id](#input\\_private\\_dns\\_zone\\_id) | The ID of the private DNS zone. Required when `delegated_subnet_id` is set | `string` | `null` | no |\n| \u003ca name=\"input_public_network_access_enabled\"\u003e\u003c/a\u003e [public\\_network\\_access\\_enabled](#input\\_public\\_network\\_access\\_enabled) | Whether or not public network access is allowed for this server | `bool` | `false` | no |\n| \u003ca name=\"input_authentication\"\u003e\u003c/a\u003e [authentication](#input\\_authentication) | active\\_directory\\_auth\\_enabled = Whether or not Active Directory authentication is enabled for this server\u003cbr\u003epassword\\_auth\\_enabled         = Whether or not password authentication is enabled for this server\u003cbr\u003etenant\\_id                     = The tenant ID of the Active Directory to use for authentication | \u003cpre\u003eobject({\u003cbr\u003e    active_directory_auth_enabled = optional(bool)\u003cbr\u003e    password_auth_enabled         = optional(bool)\u003cbr\u003e    tenant_id                     = optional(string)\u003cbr\u003e  })\u003c/pre\u003e | `null` | no |\n| \u003ca name=\"input_ad_administrator\"\u003e\u003c/a\u003e [ad\\_administrator](#input\\_ad\\_administrator) | tenant\\_id      = The tenant ID of the AD administrator\u003cbr\u003eobject\\_id      = The object ID of the AD administrator\u003cbr\u003eprincipal\\_name = The name of the princiapl to assign as AD administrator\u003cbr\u003eprincipal\\_type = The type of princiapl to assign as AD administrator | \u003cpre\u003eobject({\u003cbr\u003e    tenant_id      = string\u003cbr\u003e    object_id      = string\u003cbr\u003e    principal_name = string\u003cbr\u003e    principal_type = string\u003cbr\u003e  })\u003c/pre\u003e | `null` | no |\n| \u003ca name=\"input_administrator_login\"\u003e\u003c/a\u003e [administrator\\_login](#input\\_administrator\\_login) | The administrator login for the Postgres Flexible Server.\u003cbr\u003eRequired when `create_mode` is Default and `authentication.password_auth_enabled` is true | `string` | `null` | no |\n| \u003ca name=\"input_administrator_password\"\u003e\u003c/a\u003e [administrator\\_password](#input\\_administrator\\_password) | The administrator password for the Postgres Flexible Server.\u003cbr\u003eRequired when `create_mode` is Default and `authentication.password_auth_enabled` is true | `string` | `null` | no |\n| \u003ca name=\"input_backup_retention_days\"\u003e\u003c/a\u003e [backup\\_retention\\_days](#input\\_backup\\_retention\\_days) | The backup retention days for the Postgres Flexible Server, between 7 and 35 days | `number` | `7` | no |\n| \u003ca name=\"input_geo_redundant_backup_enabled\"\u003e\u003c/a\u003e [geo\\_redundant\\_backup\\_enabled](#input\\_geo\\_redundant\\_backup\\_enabled) | Whether or not geo-redundant backups are enabled for this server | `bool` | `false` | no |\n| \u003ca name=\"input_zone\"\u003e\u003c/a\u003e [zone](#input\\_zone) | The zone of the Postgres Flexible Server | `string` | `null` | no |\n| \u003ca name=\"input_high_availability\"\u003e\u003c/a\u003e [high\\_availability](#input\\_high\\_availability) | mode                      = The high availability mode. Possible values are SameZone or ZoneRedundant\u003cbr\u003estandby\\_availability\\_zone = The availability zone for the standby server | \u003cpre\u003eobject({\u003cbr\u003e    mode                      = string\u003cbr\u003e    standby_availability_zone = optional(string)\u003cbr\u003e  })\u003c/pre\u003e | `null` | no |\n| \u003ca name=\"input_identity_ids\"\u003e\u003c/a\u003e [identity\\_ids](#input\\_identity\\_ids) | Specifies a list of User Assigned Managed Identity IDs to be assigned | `list(string)` | `null` | no |\n| \u003ca name=\"input_maintenance_window\"\u003e\u003c/a\u003e [maintenance\\_window](#input\\_maintenance\\_window) | The maintenance window of the Postgres Flexible Server\u003cbr\u003eday\\_of\\_week = The day of the week when maintenance should be performed\u003cbr\u003estart\\_hour   = The start hour of the maintenance window\u003cbr\u003estart\\_minute = The start minute of the maintenance window | \u003cpre\u003eobject({\u003cbr\u003e    day_of_week  = optional(string, 0)\u003cbr\u003e    start_hour   = optional(number, 0)\u003cbr\u003e    start_minute = optional(number, 0)\u003cbr\u003e  })\u003c/pre\u003e | \u003cpre\u003e{\u003cbr\u003e  \"day_of_week\": 0,\u003cbr\u003e  \"start_hour\": 0,\u003cbr\u003e  \"start_minute\": 0\u003cbr\u003e}\u003c/pre\u003e | no |\n| \u003ca name=\"input_source_server_id\"\u003e\u003c/a\u003e [source\\_server\\_id](#input\\_source\\_server\\_id) | The ID of the source Postgres Flexible Server to restore from. Required when `create_mode` is GeoRestore, PointInTimeRestore, or Replica | `string` | `null` | no |\n| \u003ca name=\"input_storage_mb\"\u003e\u003c/a\u003e [storage\\_mb](#input\\_storage\\_mb) | The storage capacity of the Postgres Flexible Server in megabytes | `number` | `32768` | no |\n| \u003ca name=\"input_storage_tier\"\u003e\u003c/a\u003e [storage\\_tier](#input\\_storage\\_tier) | The storage tier of the Postgres Flexible Server. Default value based on `storage_mb` | `string` | `null` | no |\n| \u003ca name=\"input_tags\"\u003e\u003c/a\u003e [tags](#input\\_tags) | A mapping of tags to assign to the resource. | `map(string)` | `{}` | no |\n| \u003ca name=\"input_create_private_endpoint\"\u003e\u003c/a\u003e [create\\_private\\_endpoint](#input\\_create\\_private\\_endpoint) | Whether or not to create a Private Endpoint for the Postgres Flexible Server | `bool` | `false` | no |\n| \u003ca name=\"input_private_endpoint_subnet_id\"\u003e\u003c/a\u003e [private\\_endpoint\\_subnet\\_id](#input\\_private\\_endpoint\\_subnet\\_id) | The ID of the subnet to which the Postgres Flexible Server private endpoint is connected | `string` | `null` | no |\n| \u003ca name=\"input_private_endpoint_dns_zone_ids\"\u003e\u003c/a\u003e [private\\_endpoint\\_dns\\_zone\\_ids](#input\\_private\\_endpoint\\_dns\\_zone\\_ids) | A list of Private DNS Zone IDs to link with the Private Endpoint. | `list(string)` | `[]` | no |\n| \u003ca name=\"input_private_endpoint_dns_zone_group_name\"\u003e\u003c/a\u003e [private\\_endpoint\\_dns\\_zone\\_group\\_name](#input\\_private\\_endpoint\\_dns\\_zone\\_group\\_name) | Specifies the Name of the Private DNS Zone Group. | `string` | `\"postgresqlServer\"` | no |\n| \u003ca name=\"input_private_endpoint_is_manual_connection\"\u003e\u003c/a\u003e [private\\_endpoint\\_is\\_manual\\_connection](#input\\_private\\_endpoint\\_is\\_manual\\_connection) | Does the Private Endpoint require Manual Approval from the remote resource owner? Changing this forces a new resource\u003cbr\u003e    to be created. | `bool` | `false` | no |\n| \u003ca name=\"input_private_endpoint_subresource_names\"\u003e\u003c/a\u003e [private\\_endpoint\\_subresource\\_names](#input\\_private\\_endpoint\\_subresource\\_names) | A list of subresource names which the Private Endpoint is able to connect to. subresource\\_names corresponds to group\\_id.\u003cbr\u003e    Possible values are detailed in the product documentation in the Subresources column.\u003cbr\u003e    https://docs.microsoft.com/azure/private-link/private-endpoint-overview#private-link-resource | `list(string)` | \u003cpre\u003e[\u003cbr\u003e  \"postgresqlServer\"\u003cbr\u003e]\u003c/pre\u003e | no |\n| \u003ca name=\"input_private_endpoint_request_message\"\u003e\u003c/a\u003e [private\\_endpoint\\_request\\_message](#input\\_private\\_endpoint\\_request\\_message) | A message passed to the owner of the remote resource when the private endpoint attempts to establish the connection\u003cbr\u003e    to the remote resource. The request message can be a maximum of 140 characters in length.\u003cbr\u003e    Only valid if `is_manual_connection=true` | `string` | `\"\"` | no |\n| \u003ca name=\"input_action_group\"\u003e\u003c/a\u003e [action\\_group](#input\\_action\\_group) | Optional action group configuration. If null, monitor\\_action\\_group module will not be created. | \u003cpre\u003eobject({\u003cbr\u003e    name            = string\u003cbr\u003e    short_name      = string\u003cbr\u003e    email_receivers = optional(list(object({ name = string, email_address = string })), [])\u003cbr\u003e    arm_role_receivers = optional(list(object({\u003cbr\u003e      name             = string\u003cbr\u003e      role_id          = string\u003cbr\u003e      object_id        = string\u003cbr\u003e      use_common_alert = optional(bool, false)\u003cbr\u003e    })), [])\u003cbr\u003e  })\u003c/pre\u003e | `null` | no |\n| \u003ca name=\"input_resource_group_name\"\u003e\u003c/a\u003e [resource\\_group\\_name](#input\\_resource\\_group\\_name) | Optional resource group name for monitor resources. If empty, the generated resource\\_group name is used. | `string` | `\"\"` | no |\n| \u003ca name=\"input_action_group_ids\"\u003e\u003c/a\u003e [action\\_group\\_ids](#input\\_action\\_group\\_ids) | List of pre-existing Action Group resource IDs to attach to alert rules (in addition to any created by this module). | `list(string)` | `[]` | no |\n| \u003ca name=\"input_metric_alerts\"\u003e\u003c/a\u003e [metric\\_alerts](#input\\_metric\\_alerts) | Map of metric alert definitions for PostgreSQL server monitoring. Each alert must define either criteria or dynamic\\_criteria. | \u003cpre\u003emap(object({\u003cbr\u003e    description        = string\u003cbr\u003e    action_groups      = optional(set(string), [])\u003cbr\u003e    frequency          = optional(string, \"PT1M\")\u003cbr\u003e    severity           = optional(number, 3)\u003cbr\u003e    enabled            = optional(bool, true)\u003cbr\u003e    webhook_properties = optional(map(string))\u003cbr\u003e\u003cbr\u003e    criteria = optional(list(object({\u003cbr\u003e      metric_namespace       = string\u003cbr\u003e      metric_name            = string\u003cbr\u003e      aggregation            = string\u003cbr\u003e      operator               = string\u003cbr\u003e      threshold              = number\u003cbr\u003e      skip_metric_validation = optional(bool, false)\u003cbr\u003e      dimensions = optional(list(object({\u003cbr\u003e        name     = string\u003cbr\u003e        operator = string\u003cbr\u003e        values   = list(string)\u003cbr\u003e      })))\u003cbr\u003e    })))\u003cbr\u003e\u003cbr\u003e    dynamic_criteria = optional(object({\u003cbr\u003e      metric_namespace       = string\u003cbr\u003e      metric_name            = string\u003cbr\u003e      aggregation            = string\u003cbr\u003e      operator               = string\u003cbr\u003e      alert_sensitivity      = string\u003cbr\u003e      ignore_data_before     = optional(string)\u003cbr\u003e      skip_metric_validation = optional(bool, false)\u003cbr\u003e      dimensions = optional(list(object({\u003cbr\u003e        name     = string\u003cbr\u003e        operator = string\u003cbr\u003e        values   = list(string)\u003cbr\u003e      })))\u003cbr\u003e    }))\u003cbr\u003e  }))\u003c/pre\u003e | `{}` | no |\n| \u003ca name=\"input_auto_grow_enabled\"\u003e\u003c/a\u003e [auto\\_grow\\_enabled](#input\\_auto\\_grow\\_enabled) | storage auto-grow for PostgreSQL Flexible Server. | `bool` | `false` | no |\n\n## Outputs\n\n| Name | Description |\n|------|-------------|\n| \u003ca name=\"output_id\"\u003e\u003c/a\u003e [id](#output\\_id) | n/a |\n| \u003ca name=\"output_name\"\u003e\u003c/a\u003e [name](#output\\_name) | n/a |\n| \u003ca name=\"output_fqdn\"\u003e\u003c/a\u003e [fqdn](#output\\_fqdn) | n/a |\n| \u003ca name=\"output_resource_group_name\"\u003e\u003c/a\u003e [resource\\_group\\_name](#output\\_resource\\_group\\_name) | n/a |\n| \u003ca name=\"output_admin_tenant_id\"\u003e\u003c/a\u003e [admin\\_tenant\\_id](#output\\_admin\\_tenant\\_id) | n/a |\n| \u003ca name=\"output_admin_object_id\"\u003e\u003c/a\u003e [admin\\_object\\_id](#output\\_admin\\_object\\_id) | n/a |\n| \u003ca name=\"output_admin_principal_name\"\u003e\u003c/a\u003e [admin\\_principal\\_name](#output\\_admin\\_principal\\_name) | n/a |\n| \u003ca name=\"output_delegated_subnet_id\"\u003e\u003c/a\u003e [delegated\\_subnet\\_id](#output\\_delegated\\_subnet\\_id) | n/a |\n| \u003ca name=\"output_private_dns_zone_id\"\u003e\u003c/a\u003e [private\\_dns\\_zone\\_id](#output\\_private\\_dns\\_zone\\_id) | n/a |\n| \u003ca name=\"output_source_server_id\"\u003e\u003c/a\u003e [source\\_server\\_id](#output\\_source\\_server\\_id) | n/a |\n| \u003ca name=\"output_server_configuration\"\u003e\u003c/a\u003e [server\\_configuration](#output\\_server\\_configuration) | n/a |\n\u003c!-- END_TF_DOCS --\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flaunchbynttdata%2Ftf-azurerm-module_reference-postgresql_server","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flaunchbynttdata%2Ftf-azurerm-module_reference-postgresql_server","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flaunchbynttdata%2Ftf-azurerm-module_reference-postgresql_server/lists"}